usbcamdi.h 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. /*
  2. * usbcamdi.h
  3. *
  4. * USB Camera driver interface.
  5. *
  6. * This file is part of the ReactOS PSDK package.
  7. *
  8. * Contributors:
  9. * Created by Casper S. Hornstrup <chorns@users.sourceforge.net>
  10. *
  11. * THIS SOFTWARE IS NOT COPYRIGHTED
  12. *
  13. * This source code is offered for use in the public domain. You may
  14. * use, modify or distribute it freely.
  15. *
  16. * This code is distributed in the hope that it will be useful but
  17. * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
  18. * DISCLAIMED. This includes but is not limited to warranties of
  19. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  20. *
  21. */
  22. #if !defined(__USB_H) && !defined(__USBDI_H)
  23. #ifdef __cplusplus
  24. extern "C" {
  25. #endif
  26. #if defined(_BATTERYCLASS_)
  27. # define USBCAMAPI
  28. #else
  29. # define USBCAMAPI DECLSPEC_IMPORT
  30. #endif
  31. typedef struct _pipe_config_descriptor {
  32. CHAR StreamAssociation;
  33. UCHAR PipeConfigFlags;
  34. } USBCAMD_Pipe_Config_Descriptor, *PUSBCAMD_Pipe_Config_Descriptor;
  35. #define USBCAMD_DATA_PIPE 0x0001
  36. #define USBCAMD_MULTIPLEX_PIPE 0x0002
  37. #define USBCAMD_SYNC_PIPE 0x0004
  38. #define USBCAMD_DONT_CARE_PIPE 0x0008
  39. #define USBCAMD_VIDEO_STREAM 0x1
  40. #define USBCAMD_STILL_STREAM 0x2
  41. #define USBCAMD_VIDEO_STILL_STREAM (USBCAMD_VIDEO_STREAM | USBCAMD_STILL_STREAM)
  42. #define USBCAMD_PROCESSPACKETEX_DropFrame 0x0002
  43. #define USBCAMD_PROCESSPACKETEX_NextFrameIsStill 0x0004
  44. #define USBCAMD_PROCESSPACKETEX_CurrentFrameIsStill 0x0008
  45. #define USBCAMD_STOP_STREAM 0x00000001
  46. #define USBCAMD_START_STREAM 0x00000000
  47. typedef enum {
  48. USBCAMD_CamControlFlag_NoVideoRawProcessing = 1,
  49. USBCAMD_CamControlFlag_NoStillRawProcessing = 2,
  50. USBCAMD_CamControlFlag_AssociatedFormat = 4,
  51. USBCAMD_CamControlFlag_EnableDeviceEvents = 8
  52. } USBCAMD_CamControlFlags;
  53. typedef NTSTATUS
  54. (NTAPI *PCOMMAND_COMPLETE_FUNCTION)(
  55. PVOID DeviceContext,
  56. PVOID CommandContext,
  57. NTSTATUS NtStatus);
  58. typedef VOID
  59. (NTAPI *PSTREAM_RECEIVE_PACKET)(
  60. PVOID Srb,
  61. PVOID DeviceContext,
  62. PBOOLEAN Completed);
  63. typedef NTSTATUS
  64. (NTAPI *PCAM_INITIALIZE_ROUTINE)(
  65. PDEVICE_OBJECT BusDeviceObject,
  66. PVOID DeviceContext);
  67. typedef NTSTATUS
  68. (NTAPI *PCAM_CONFIGURE_ROUTINE)(
  69. PDEVICE_OBJECT BusDeviceObject,
  70. PVOID DeviceContext,
  71. PUSBD_INTERFACE_INFORMATION Interface,
  72. PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor,
  73. PLONG DataPipeIndex,
  74. PLONG SyncPipeIndex);
  75. typedef NTSTATUS
  76. (NTAPI *PCAM_CONFIGURE_ROUTINE_EX)(
  77. PDEVICE_OBJECT BusDeviceObject,
  78. PVOID DeviceContext,
  79. PUSBD_INTERFACE_INFORMATION Interface,
  80. PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor,
  81. ULONG PipeConfigListSize,
  82. PUSBCAMD_Pipe_Config_Descriptor PipeConfig,
  83. PUSB_DEVICE_DESCRIPTOR DeviceDescriptor);
  84. typedef NTSTATUS
  85. (NTAPI *PCAM_START_CAPTURE_ROUTINE)(
  86. PDEVICE_OBJECT BusDeviceObject,
  87. PVOID DeviceContext);
  88. typedef NTSTATUS
  89. (NTAPI *PCAM_START_CAPTURE_ROUTINE_EX)(
  90. PDEVICE_OBJECT BusDeviceObject,
  91. PVOID DeviceContext,
  92. ULONG StreamNumber);
  93. typedef NTSTATUS
  94. (NTAPI *PCAM_ALLOCATE_BW_ROUTINE)(
  95. PDEVICE_OBJECT BusDeviceObject,
  96. PVOID DeviceContext,
  97. PULONG RawFrameLength,
  98. PVOID Format);
  99. typedef NTSTATUS
  100. (NTAPI *PCAM_ALLOCATE_BW_ROUTINE_EX)(
  101. PDEVICE_OBJECT BusDeviceObject,
  102. PVOID DeviceContext,
  103. PULONG RawFrameLength,
  104. PVOID Format,
  105. ULONG StreamNumber);
  106. typedef NTSTATUS
  107. (NTAPI *PCAM_FREE_BW_ROUTINE)(
  108. PDEVICE_OBJECT BusDeviceObject,
  109. PVOID DeviceContext);
  110. typedef NTSTATUS
  111. (NTAPI *PCAM_FREE_BW_ROUTINE_EX)(
  112. PDEVICE_OBJECT BusDeviceObject,
  113. PVOID DeviceContext,
  114. ULONG StreamNumber);
  115. typedef VOID
  116. (NTAPI *PADAPTER_RECEIVE_PACKET_ROUTINE)(
  117. PHW_STREAM_REQUEST_BLOCK Srb);
  118. typedef NTSTATUS
  119. (NTAPI *PCAM_STOP_CAPTURE_ROUTINE)(
  120. PDEVICE_OBJECT BusDeviceObject,
  121. PVOID DeviceContext);
  122. typedef NTSTATUS
  123. (NTAPI *PCAM_STOP_CAPTURE_ROUTINE_EX)(
  124. PDEVICE_OBJECT BusDeviceObject,
  125. PVOID DeviceContext,
  126. ULONG StreamNumber);
  127. typedef ULONG
  128. (NTAPI *PCAM_PROCESS_PACKET_ROUTINE)(
  129. PDEVICE_OBJECT BusDeviceObject,
  130. PVOID DeviceContext,
  131. PVOID CurrentFrameContext,
  132. PUSBD_ISO_PACKET_DESCRIPTOR SyncPacket,
  133. PVOID SyncBuffer,
  134. PUSBD_ISO_PACKET_DESCRIPTOR DataPacket,
  135. PVOID DataBuffer,
  136. PBOOLEAN FrameComplete,
  137. PBOOLEAN NextFrameIsStill);
  138. typedef ULONG
  139. (NTAPI *PCAM_PROCESS_PACKET_ROUTINE_EX)(
  140. PDEVICE_OBJECT BusDeviceObject,
  141. PVOID DeviceContext,
  142. PVOID CurrentFrameContext,
  143. PUSBD_ISO_PACKET_DESCRIPTOR SyncPacket,
  144. PVOID SyncBuffer,
  145. PUSBD_ISO_PACKET_DESCRIPTOR DataPacket,
  146. PVOID DataBuffer,
  147. PBOOLEAN FrameComplete,
  148. PULONG PacketFlag,
  149. PULONG ValidDataOffset);
  150. typedef VOID
  151. (NTAPI *PCAM_NEW_FRAME_ROUTINE)(
  152. PVOID DeviceContext,
  153. PVOID FrameContext);
  154. typedef VOID
  155. (NTAPI *PCAM_NEW_FRAME_ROUTINE_EX)(
  156. PVOID DeviceContext,
  157. PVOID FrameContext,
  158. ULONG StreamNumber,
  159. PULONG FrameLength);
  160. typedef NTSTATUS
  161. (NTAPI *PCAM_PROCESS_RAW_FRAME_ROUTINE)(
  162. PDEVICE_OBJECT BusDeviceObject,
  163. PVOID DeviceContext,
  164. PVOID FrameContext,
  165. PVOID FrameBuffer,
  166. ULONG FrameLength,
  167. PVOID RawFrameBuffer,
  168. ULONG RawFrameLength,
  169. ULONG NumberOfPackets,
  170. PULONG BytesReturned);
  171. typedef NTSTATUS
  172. (NTAPI *PCAM_PROCESS_RAW_FRAME_ROUTINE_EX)(
  173. PDEVICE_OBJECT BusDeviceObject,
  174. PVOID DeviceContext,
  175. PVOID FrameContext,
  176. PVOID FrameBuffer,
  177. ULONG FrameLength,
  178. PVOID RawFrameBuffer,
  179. ULONG RawFrameLength,
  180. ULONG NumberOfPackets,
  181. PULONG BytesReturned,
  182. ULONG ActualRawFrameLength,
  183. ULONG StreamNumber);
  184. typedef NTSTATUS
  185. (NTAPI *PCAM_STATE_ROUTINE)(
  186. PDEVICE_OBJECT BusDeviceObject,
  187. PVOID DeviceContext);
  188. #if defined(DEBUG_LOG)
  189. USBCAMAPI
  190. VOID
  191. NTAPI
  192. USBCAMD_Debug_LogEntry(
  193. CHAR *Name,
  194. ULONG Info1,
  195. ULONG Info2,
  196. ULONG Info3);
  197. #define ILOGENTRY(sig, info1, info2, info3) \
  198. USBCAMD_Debug_LogEntry(sig, (ULONG)info1, (ULONG)info2, (ULONG)info3)
  199. #else
  200. #define ILOGENTRY(sig, info1, info2, info3)
  201. #endif /* DEBUG_LOG */
  202. typedef struct _USBCAMD_DEVICE_DATA {
  203. ULONG Sig;
  204. PCAM_INITIALIZE_ROUTINE CamInitialize;
  205. PCAM_INITIALIZE_ROUTINE CamUnInitialize;
  206. PCAM_PROCESS_PACKET_ROUTINE CamProcessUSBPacket;
  207. PCAM_NEW_FRAME_ROUTINE CamNewVideoFrame;
  208. PCAM_PROCESS_RAW_FRAME_ROUTINE CamProcessRawVideoFrame;
  209. PCAM_START_CAPTURE_ROUTINE CamStartCapture;
  210. PCAM_STOP_CAPTURE_ROUTINE CamStopCapture;
  211. PCAM_CONFIGURE_ROUTINE CamConfigure;
  212. PCAM_STATE_ROUTINE CamSaveState;
  213. PCAM_STATE_ROUTINE CamRestoreState;
  214. PCAM_ALLOCATE_BW_ROUTINE CamAllocateBandwidth;
  215. PCAM_FREE_BW_ROUTINE CamFreeBandwidth;
  216. } USBCAMD_DEVICE_DATA, *PUSBCAMD_DEVICE_DATA;
  217. typedef struct _USBCAMD_DEVICE_DATA2 {
  218. ULONG Sig;
  219. PCAM_INITIALIZE_ROUTINE CamInitialize;
  220. PCAM_INITIALIZE_ROUTINE CamUnInitialize;
  221. PCAM_PROCESS_PACKET_ROUTINE_EX CamProcessUSBPacketEx;
  222. PCAM_NEW_FRAME_ROUTINE_EX CamNewVideoFrameEx;
  223. PCAM_PROCESS_RAW_FRAME_ROUTINE_EX CamProcessRawVideoFrameEx;
  224. PCAM_START_CAPTURE_ROUTINE_EX CamStartCaptureEx;
  225. PCAM_STOP_CAPTURE_ROUTINE_EX CamStopCaptureEx;
  226. PCAM_CONFIGURE_ROUTINE_EX CamConfigureEx;
  227. PCAM_STATE_ROUTINE CamSaveState;
  228. PCAM_STATE_ROUTINE CamRestoreState;
  229. PCAM_ALLOCATE_BW_ROUTINE_EX CamAllocateBandwidthEx;
  230. PCAM_FREE_BW_ROUTINE_EX CamFreeBandwidthEx;
  231. } USBCAMD_DEVICE_DATA2, *PUSBCAMD_DEVICE_DATA2;
  232. DEFINE_GUID(GUID_USBCAMD_INTERFACE,
  233. 0x2bcb75c0, 0xb27f, 0x11d1, 0xba, 0x41, 0x0, 0xa0, 0xc9, 0xd, 0x2b, 0x5);
  234. typedef NTSTATUS
  235. (NTAPI *PFNUSBCAMD_SetVideoFormat)(
  236. PVOID DeviceContext,
  237. PHW_STREAM_REQUEST_BLOCK pSrb);
  238. typedef NTSTATUS
  239. (NTAPI *PFNUSBCAMD_WaitOnDeviceEvent)(
  240. PVOID DeviceContext,
  241. ULONG PipeIndex,
  242. PVOID Buffer,
  243. ULONG BufferLength,
  244. PCOMMAND_COMPLETE_FUNCTION EventComplete,
  245. PVOID EventContext,
  246. BOOLEAN LoopBack);
  247. typedef NTSTATUS
  248. (NTAPI *PFNUSBCAMD_CancelBulkReadWrite)(
  249. PVOID DeviceContext,
  250. ULONG PipeIndex);
  251. typedef NTSTATUS
  252. (NTAPI *PFNUSBCAMD_SetIsoPipeState)(
  253. PVOID DeviceContext,
  254. ULONG PipeStateFlags);
  255. typedef NTSTATUS
  256. (NTAPI *PFNUSBCAMD_BulkReadWrite)(
  257. PVOID DeviceContext,
  258. USHORT PipeIndex,
  259. PVOID Buffer,
  260. ULONG BufferLength,
  261. PCOMMAND_COMPLETE_FUNCTION CommandComplete,
  262. PVOID CommandContext);
  263. #define USBCAMD_VERSION_200 0x200
  264. typedef struct _USBCAMD_INTERFACE {
  265. INTERFACE Interface;
  266. PFNUSBCAMD_WaitOnDeviceEvent USBCAMD_WaitOnDeviceEvent;
  267. PFNUSBCAMD_BulkReadWrite USBCAMD_BulkReadWrite;
  268. PFNUSBCAMD_SetVideoFormat USBCAMD_SetVideoFormat;
  269. PFNUSBCAMD_SetIsoPipeState USBCAMD_SetIsoPipeState;
  270. PFNUSBCAMD_CancelBulkReadWrite USBCAMD_CancelBulkReadWrite;
  271. } USBCAMD_INTERFACE, *PUSBCAMD_INTERFACE;
  272. /* FIXME : Do we need USBCAMAPI here ? */
  273. USBCAMAPI
  274. ULONG
  275. NTAPI
  276. USBCAMD_DriverEntry(
  277. PVOID Context1,
  278. PVOID Context2,
  279. ULONG DeviceContextSize,
  280. ULONG FrameContextSize,
  281. PADAPTER_RECEIVE_PACKET_ROUTINE ReceivePacket);
  282. USBCAMAPI
  283. PVOID
  284. NTAPI
  285. USBCAMD_AdapterReceivePacket(
  286. PHW_STREAM_REQUEST_BLOCK Srb,
  287. PUSBCAMD_DEVICE_DATA DeviceData,
  288. PDEVICE_OBJECT *DeviceObject,
  289. BOOLEAN NeedsCompletion);
  290. USBCAMAPI
  291. NTSTATUS
  292. NTAPI
  293. USBCAMD_ControlVendorCommand(
  294. PVOID DeviceContext,
  295. UCHAR Request,
  296. USHORT Value,
  297. USHORT Index,
  298. PVOID Buffer,
  299. PULONG BufferLength,
  300. BOOLEAN GetData,
  301. PCOMMAND_COMPLETE_FUNCTION CommandComplete,
  302. PVOID CommandContext);
  303. USBCAMAPI
  304. NTSTATUS
  305. NTAPI
  306. USBCAMD_SelectAlternateInterface(
  307. PVOID DeviceContext,
  308. PUSBD_INTERFACE_INFORMATION RequestInterface);
  309. USBCAMAPI
  310. NTSTATUS
  311. NTAPI
  312. USBCAMD_GetRegistryKeyValue(
  313. HANDLE Handle,
  314. PWCHAR KeyNameString,
  315. ULONG KeyNameStringLength,
  316. PVOID Data,
  317. ULONG DataLength);
  318. USBCAMAPI
  319. ULONG
  320. NTAPI
  321. USBCAMD_InitializeNewInterface(
  322. PVOID DeviceContext,
  323. PVOID DeviceData,
  324. ULONG Version,
  325. ULONG CamControlFlag);
  326. #ifdef __cplusplus
  327. }
  328. #endif
  329. #endif /* !defined(__USB_H) && !defined(__USBDI_H) */