| 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 | 
  | 
 
 
 
 
 
 | 23 | 
 #if !defined(__USB_H) && !defined(__USBDI_H) | 
 
 
 
 
 
 | 24 | 
  | 
 
 
 
 
 
 | 25 | 
 #ifdef __cplusplus | 
 
 
 
 
 
 | 26 | 
 extern "C" { | 
 
 
 
 
 
 | 27 | 
 #endif | 
 
 
 
 
 
 | 28 | 
  | 
 
 
 
 
 
 | 29 | 
 #if defined(_BATTERYCLASS_) | 
 
 
 
 
 
 | 30 | 
 # define USBCAMAPI | 
 
 
 
 
 
 | 31 | 
 #else | 
 
 
 
 
 
 | 32 | 
 # define USBCAMAPI DECLSPEC_IMPORT | 
 
 
 
 
 
 | 33 | 
 #endif | 
 
 
 
 
 
 | 34 | 
  | 
 
 
 
 
 
 | 35 | 
 typedef struct _pipe_config_descriptor { | 
 
 
 
 
 
 | 36 | 
   CHAR StreamAssociation; | 
 
 
 
 
 
 | 37 | 
   UCHAR PipeConfigFlags; | 
 
 
 
 
 
 | 38 | 
 } USBCAMD_Pipe_Config_Descriptor, *PUSBCAMD_Pipe_Config_Descriptor; | 
 
 
 
 
 
 | 39 | 
  | 
 
 
 
 
 
 | 40 | 
 #define USBCAMD_DATA_PIPE                 0x0001 | 
 
 
 
 
 
 | 41 | 
 #define USBCAMD_MULTIPLEX_PIPE            0x0002 | 
 
 
 
 
 
 | 42 | 
 #define USBCAMD_SYNC_PIPE                 0x0004 | 
 
 
 
 
 
 | 43 | 
 #define USBCAMD_DONT_CARE_PIPE            0x0008 | 
 
 
 
 
 
 | 44 | 
  | 
 
 
 
 
 
 | 45 | 
 #define USBCAMD_VIDEO_STREAM              0x1 | 
 
 
 
 
 
 | 46 | 
 #define USBCAMD_STILL_STREAM              0x2 | 
 
 
 
 
 
 | 47 | 
 #define USBCAMD_VIDEO_STILL_STREAM        (USBCAMD_VIDEO_STREAM | USBCAMD_STILL_STREAM) | 
 
 
 
 
 
 | 48 | 
  | 
 
 
 
 
 
 | 49 | 
 #define USBCAMD_PROCESSPACKETEX_DropFrame             0x0002 | 
 
 
 
 
 
 | 50 | 
 #define USBCAMD_PROCESSPACKETEX_NextFrameIsStill      0x0004 | 
 
 
 
 
 
 | 51 | 
 #define USBCAMD_PROCESSPACKETEX_CurrentFrameIsStill   0x0008 | 
 
 
 
 
 
 | 52 | 
  | 
 
 
 
 
 
 | 53 | 
 #define USBCAMD_STOP_STREAM               0x00000001 | 
 
 
 
 
 
 | 54 | 
 #define USBCAMD_START_STREAM              0x00000000 | 
 
 
 
 
 
 | 55 | 
  | 
 
 
 
 
 
 | 56 | 
 typedef enum { | 
 
 
 
 
 
 | 57 | 
   USBCAMD_CamControlFlag_NoVideoRawProcessing = 1, | 
 
 
 
 
 
 | 58 | 
   USBCAMD_CamControlFlag_NoStillRawProcessing = 2, | 
 
 
 
 
 
 | 59 | 
   USBCAMD_CamControlFlag_AssociatedFormat = 4, | 
 
 
 
 
 
 | 60 | 
   USBCAMD_CamControlFlag_EnableDeviceEvents = 8 | 
 
 
 
 
 
 | 61 | 
 } USBCAMD_CamControlFlags; | 
 
 
 
 
 
 | 62 | 
  | 
 
 
 
 
 
 | 63 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 64 | 
 (NTAPI *PCOMMAND_COMPLETE_FUNCTION)( | 
 
 
 
 
 
 | 65 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 66 | 
   PVOID CommandContext, | 
 
 
 
 
 
 | 67 | 
   NTSTATUS NtStatus); | 
 
 
 
 
 
 | 68 | 
  | 
 
 
 
 
 
 | 69 | 
 typedef VOID | 
 
 
 
 
 
 | 70 | 
 (NTAPI *PSTREAM_RECEIVE_PACKET)( | 
 
 
 
 
 
 | 71 | 
   PVOID Srb, | 
 
 
 
 
 
 | 72 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 73 | 
   PBOOLEAN Completed); | 
 
 
 
 
 
 | 74 | 
  | 
 
 
 
 
 
 | 75 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 76 | 
 (NTAPI *PCAM_INITIALIZE_ROUTINE)( | 
 
 
 
 
 
 | 77 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 78 | 
   PVOID DeviceContext); | 
 
 
 
 
 
 | 79 | 
  | 
 
 
 
 
 
 | 80 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 81 | 
 (NTAPI *PCAM_CONFIGURE_ROUTINE)( | 
 
 
 
 
 
 | 82 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 83 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 84 | 
   PUSBD_INTERFACE_INFORMATION Interface, | 
 
 
 
 
 
 | 85 | 
   PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor, | 
 
 
 
 
 
 | 86 | 
   PLONG DataPipeIndex, | 
 
 
 
 
 
 | 87 | 
   PLONG SyncPipeIndex); | 
 
 
 
 
 
 | 88 | 
  | 
 
 
 
 
 
 | 89 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 90 | 
 (NTAPI *PCAM_CONFIGURE_ROUTINE_EX)( | 
 
 
 
 
 
 | 91 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 92 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 93 | 
   PUSBD_INTERFACE_INFORMATION Interface, | 
 
 
 
 
 
 | 94 | 
   PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor, | 
 
 
 
 
 
 | 95 | 
   ULONG PipeConfigListSize, | 
 
 
 
 
 
 | 96 | 
   PUSBCAMD_Pipe_Config_Descriptor PipeConfig, | 
 
 
 
 
 
 | 97 | 
   PUSB_DEVICE_DESCRIPTOR DeviceDescriptor); | 
 
 
 
 
 
 | 98 | 
  | 
 
 
 
 
 
 | 99 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 100 | 
 (NTAPI *PCAM_START_CAPTURE_ROUTINE)( | 
 
 
 
 
 
 | 101 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 102 | 
   PVOID DeviceContext); | 
 
 
 
 
 
 | 103 | 
  | 
 
 
 
 
 
 | 104 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 105 | 
 (NTAPI *PCAM_START_CAPTURE_ROUTINE_EX)( | 
 
 
 
 
 
 | 106 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 107 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 108 | 
   ULONG StreamNumber); | 
 
 
 
 
 
 | 109 | 
  | 
 
 
 
 
 
 | 110 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 111 | 
 (NTAPI *PCAM_ALLOCATE_BW_ROUTINE)( | 
 
 
 
 
 
 | 112 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 113 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 114 | 
   PULONG RawFrameLength, | 
 
 
 
 
 
 | 115 | 
   PVOID Format); | 
 
 
 
 
 
 | 116 | 
  | 
 
 
 
 
 
 | 117 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 118 | 
 (NTAPI *PCAM_ALLOCATE_BW_ROUTINE_EX)( | 
 
 
 
 
 
 | 119 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 120 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 121 | 
   PULONG RawFrameLength, | 
 
 
 
 
 
 | 122 | 
   PVOID Format, | 
 
 
 
 
 
 | 123 | 
   ULONG StreamNumber); | 
 
 
 
 
 
 | 124 | 
  | 
 
 
 
 
 
 | 125 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 126 | 
 (NTAPI *PCAM_FREE_BW_ROUTINE)( | 
 
 
 
 
 
 | 127 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 128 | 
   PVOID DeviceContext); | 
 
 
 
 
 
 | 129 | 
  | 
 
 
 
 
 
 | 130 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 131 | 
 (NTAPI *PCAM_FREE_BW_ROUTINE_EX)( | 
 
 
 
 
 
 | 132 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 133 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 134 | 
   ULONG StreamNumber); | 
 
 
 
 
 
 | 135 | 
  | 
 
 
 
 
 
 | 136 | 
 typedef VOID | 
 
 
 
 
 
 | 137 | 
 (NTAPI *PADAPTER_RECEIVE_PACKET_ROUTINE)( | 
 
 
 
 
 
 | 138 | 
   PHW_STREAM_REQUEST_BLOCK Srb); | 
 
 
 
 
 
 | 139 | 
  | 
 
 
 
 
 
 | 140 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 141 | 
 (NTAPI *PCAM_STOP_CAPTURE_ROUTINE)( | 
 
 
 
 
 
 | 142 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 143 | 
   PVOID DeviceContext); | 
 
 
 
 
 
 | 144 | 
  | 
 
 
 
 
 
 | 145 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 146 | 
 (NTAPI *PCAM_STOP_CAPTURE_ROUTINE_EX)( | 
 
 
 
 
 
 | 147 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 148 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 149 | 
   ULONG StreamNumber); | 
 
 
 
 
 
 | 150 | 
  | 
 
 
 
 
 
 | 151 | 
 typedef ULONG | 
 
 
 
 
 
 | 152 | 
 (NTAPI *PCAM_PROCESS_PACKET_ROUTINE)( | 
 
 
 
 
 
 | 153 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 154 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 155 | 
   PVOID CurrentFrameContext, | 
 
 
 
 
 
 | 156 | 
   PUSBD_ISO_PACKET_DESCRIPTOR SyncPacket, | 
 
 
 
 
 
 | 157 | 
   PVOID SyncBuffer, | 
 
 
 
 
 
 | 158 | 
   PUSBD_ISO_PACKET_DESCRIPTOR DataPacket, | 
 
 
 
 
 
 | 159 | 
   PVOID DataBuffer, | 
 
 
 
 
 
 | 160 | 
   PBOOLEAN FrameComplete, | 
 
 
 
 
 
 | 161 | 
   PBOOLEAN NextFrameIsStill); | 
 
 
 
 
 
 | 162 | 
  | 
 
 
 
 
 
 | 163 | 
 typedef ULONG | 
 
 
 
 
 
 | 164 | 
 (NTAPI *PCAM_PROCESS_PACKET_ROUTINE_EX)( | 
 
 
 
 
 
 | 165 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 166 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 167 | 
   PVOID CurrentFrameContext, | 
 
 
 
 
 
 | 168 | 
   PUSBD_ISO_PACKET_DESCRIPTOR SyncPacket, | 
 
 
 
 
 
 | 169 | 
   PVOID SyncBuffer, | 
 
 
 
 
 
 | 170 | 
   PUSBD_ISO_PACKET_DESCRIPTOR DataPacket, | 
 
 
 
 
 
 | 171 | 
   PVOID DataBuffer, | 
 
 
 
 
 
 | 172 | 
   PBOOLEAN FrameComplete, | 
 
 
 
 
 
 | 173 | 
   PULONG PacketFlag, | 
 
 
 
 
 
 | 174 | 
   PULONG ValidDataOffset); | 
 
 
 
 
 
 | 175 | 
  | 
 
 
 
 
 
 | 176 | 
 typedef VOID | 
 
 
 
 
 
 | 177 | 
 (NTAPI *PCAM_NEW_FRAME_ROUTINE)( | 
 
 
 
 
 
 | 178 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 179 | 
   PVOID FrameContext); | 
 
 
 
 
 
 | 180 | 
  | 
 
 
 
 
 
 | 181 | 
 typedef VOID | 
 
 
 
 
 
 | 182 | 
 (NTAPI *PCAM_NEW_FRAME_ROUTINE_EX)( | 
 
 
 
 
 
 | 183 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 184 | 
   PVOID FrameContext, | 
 
 
 
 
 
 | 185 | 
   ULONG StreamNumber, | 
 
 
 
 
 
 | 186 | 
   PULONG FrameLength); | 
 
 
 
 
 
 | 187 | 
  | 
 
 
 
 
 
 | 188 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 189 | 
 (NTAPI *PCAM_PROCESS_RAW_FRAME_ROUTINE)( | 
 
 
 
 
 
 | 190 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 191 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 192 | 
   PVOID FrameContext, | 
 
 
 
 
 
 | 193 | 
   PVOID FrameBuffer, | 
 
 
 
 
 
 | 194 | 
   ULONG FrameLength, | 
 
 
 
 
 
 | 195 | 
   PVOID RawFrameBuffer, | 
 
 
 
 
 
 | 196 | 
   ULONG RawFrameLength, | 
 
 
 
 
 
 | 197 | 
   ULONG NumberOfPackets, | 
 
 
 
 
 
 | 198 | 
   PULONG BytesReturned); | 
 
 
 
 
 
 | 199 | 
  | 
 
 
 
 
 
 | 200 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 201 | 
 (NTAPI *PCAM_PROCESS_RAW_FRAME_ROUTINE_EX)( | 
 
 
 
 
 
 | 202 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 203 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 204 | 
   PVOID FrameContext, | 
 
 
 
 
 
 | 205 | 
   PVOID FrameBuffer, | 
 
 
 
 
 
 | 206 | 
   ULONG FrameLength, | 
 
 
 
 
 
 | 207 | 
   PVOID RawFrameBuffer, | 
 
 
 
 
 
 | 208 | 
   ULONG RawFrameLength, | 
 
 
 
 
 
 | 209 | 
   ULONG NumberOfPackets, | 
 
 
 
 
 
 | 210 | 
   PULONG BytesReturned, | 
 
 
 
 
 
 | 211 | 
   ULONG ActualRawFrameLength, | 
 
 
 
 
 
 | 212 | 
   ULONG StreamNumber); | 
 
 
 
 
 
 | 213 | 
  | 
 
 
 
 
 
 | 214 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 215 | 
 (NTAPI *PCAM_STATE_ROUTINE)( | 
 
 
 
 
 
 | 216 | 
   PDEVICE_OBJECT BusDeviceObject, | 
 
 
 
 
 
 | 217 | 
   PVOID DeviceContext); | 
 
 
 
 
 
 | 218 | 
  | 
 
 
 
 
 
 | 219 | 
 #if defined(DEBUG_LOG) | 
 
 
 
 
 
 | 220 | 
  | 
 
 
 
 
 
 | 221 | 
 USBCAMAPI | 
 
 
 
 
 
 | 222 | 
 VOID | 
 
 
 
 
 
 | 223 | 
 NTAPI | 
 
 
 
 
 
 | 224 | 
 USBCAMD_Debug_LogEntry( | 
 
 
 
 
 
 | 225 | 
   CHAR *Name, | 
 
 
 
 
 
 | 226 | 
   ULONG Info1, | 
 
 
 
 
 
 | 227 | 
   ULONG Info2, | 
 
 
 
 
 
 | 228 | 
   ULONG Info3); | 
 
 
 
 
 
 | 229 | 
  | 
 
 
 
 
 
 | 230 | 
 #define ILOGENTRY(sig, info1, info2, info3) \ | 
 
 
 
 
 
 | 231 | 
   USBCAMD_Debug_LogEntry(sig, (ULONG)info1, (ULONG)info2, (ULONG)info3) | 
 
 
 
 
 
 | 232 | 
  | 
 
 
 
 
 
 | 233 | 
 #else | 
 
 
 
 
 
 | 234 | 
  | 
 
 
 
 
 
 | 235 | 
 #define ILOGENTRY(sig, info1, info2, info3) | 
 
 
 
 
 
 | 236 | 
  | 
 
 
 
 
 
 | 237 | 
 #endif /* DEBUG_LOG */ | 
 
 
 
 
 
 | 238 | 
  | 
 
 
 
 
 
 | 239 | 
 typedef struct _USBCAMD_DEVICE_DATA { | 
 
 
 
 
 
 | 240 | 
   ULONG Sig; | 
 
 
 
 
 
 | 241 | 
   PCAM_INITIALIZE_ROUTINE CamInitialize; | 
 
 
 
 
 
 | 242 | 
   PCAM_INITIALIZE_ROUTINE CamUnInitialize; | 
 
 
 
 
 
 | 243 | 
   PCAM_PROCESS_PACKET_ROUTINE CamProcessUSBPacket; | 
 
 
 
 
 
 | 244 | 
   PCAM_NEW_FRAME_ROUTINE CamNewVideoFrame; | 
 
 
 
 
 
 | 245 | 
   PCAM_PROCESS_RAW_FRAME_ROUTINE CamProcessRawVideoFrame; | 
 
 
 
 
 
 | 246 | 
   PCAM_START_CAPTURE_ROUTINE CamStartCapture; | 
 
 
 
 
 
 | 247 | 
   PCAM_STOP_CAPTURE_ROUTINE CamStopCapture; | 
 
 
 
 
 
 | 248 | 
   PCAM_CONFIGURE_ROUTINE CamConfigure; | 
 
 
 
 
 
 | 249 | 
   PCAM_STATE_ROUTINE CamSaveState; | 
 
 
 
 
 
 | 250 | 
   PCAM_STATE_ROUTINE CamRestoreState; | 
 
 
 
 
 
 | 251 | 
   PCAM_ALLOCATE_BW_ROUTINE CamAllocateBandwidth; | 
 
 
 
 
 
 | 252 | 
   PCAM_FREE_BW_ROUTINE CamFreeBandwidth; | 
 
 
 
 
 
 | 253 | 
 } USBCAMD_DEVICE_DATA, *PUSBCAMD_DEVICE_DATA; | 
 
 
 
 
 
 | 254 | 
  | 
 
 
 
 
 
 | 255 | 
 typedef struct _USBCAMD_DEVICE_DATA2 { | 
 
 
 
 
 
 | 256 | 
   ULONG Sig; | 
 
 
 
 
 
 | 257 | 
   PCAM_INITIALIZE_ROUTINE CamInitialize; | 
 
 
 
 
 
 | 258 | 
   PCAM_INITIALIZE_ROUTINE CamUnInitialize; | 
 
 
 
 
 
 | 259 | 
   PCAM_PROCESS_PACKET_ROUTINE_EX CamProcessUSBPacketEx; | 
 
 
 
 
 
 | 260 | 
   PCAM_NEW_FRAME_ROUTINE_EX CamNewVideoFrameEx; | 
 
 
 
 
 
 | 261 | 
   PCAM_PROCESS_RAW_FRAME_ROUTINE_EX CamProcessRawVideoFrameEx; | 
 
 
 
 
 
 | 262 | 
   PCAM_START_CAPTURE_ROUTINE_EX CamStartCaptureEx; | 
 
 
 
 
 
 | 263 | 
   PCAM_STOP_CAPTURE_ROUTINE_EX CamStopCaptureEx; | 
 
 
 
 
 
 | 264 | 
   PCAM_CONFIGURE_ROUTINE_EX CamConfigureEx; | 
 
 
 
 
 
 | 265 | 
   PCAM_STATE_ROUTINE CamSaveState; | 
 
 
 
 
 
 | 266 | 
   PCAM_STATE_ROUTINE CamRestoreState; | 
 
 
 
 
 
 | 267 | 
   PCAM_ALLOCATE_BW_ROUTINE_EX CamAllocateBandwidthEx; | 
 
 
 
 
 
 | 268 | 
   PCAM_FREE_BW_ROUTINE_EX CamFreeBandwidthEx; | 
 
 
 
 
 
 | 269 | 
 } USBCAMD_DEVICE_DATA2, *PUSBCAMD_DEVICE_DATA2; | 
 
 
 
 
 
 | 270 | 
  | 
 
 
 
 
 
 | 271 | 
 DEFINE_GUID(GUID_USBCAMD_INTERFACE, | 
 
 
 
 
 
 | 272 | 
   0x2bcb75c0, 0xb27f, 0x11d1, 0xba, 0x41, 0x0, 0xa0, 0xc9, 0xd, 0x2b, 0x5); | 
 
 
 
 
 
 | 273 | 
  | 
 
 
 
 
 
 | 274 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 275 | 
 (NTAPI *PFNUSBCAMD_SetVideoFormat)( | 
 
 
 
 
 
 | 276 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 277 | 
   PHW_STREAM_REQUEST_BLOCK pSrb); | 
 
 
 
 
 
 | 278 | 
  | 
 
 
 
 
 
 | 279 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 280 | 
 (NTAPI *PFNUSBCAMD_WaitOnDeviceEvent)( | 
 
 
 
 
 
 | 281 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 282 | 
   ULONG PipeIndex, | 
 
 
 
 
 
 | 283 | 
   PVOID Buffer, | 
 
 
 
 
 
 | 284 | 
   ULONG BufferLength, | 
 
 
 
 
 
 | 285 | 
   PCOMMAND_COMPLETE_FUNCTION EventComplete, | 
 
 
 
 
 
 | 286 | 
   PVOID EventContext, | 
 
 
 
 
 
 | 287 | 
   BOOLEAN LoopBack); | 
 
 
 
 
 
 | 288 | 
  | 
 
 
 
 
 
 | 289 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 290 | 
 (NTAPI *PFNUSBCAMD_CancelBulkReadWrite)( | 
 
 
 
 
 
 | 291 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 292 | 
   ULONG PipeIndex); | 
 
 
 
 
 
 | 293 | 
  | 
 
 
 
 
 
 | 294 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 295 | 
 (NTAPI *PFNUSBCAMD_SetIsoPipeState)( | 
 
 
 
 
 
 | 296 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 297 | 
   ULONG PipeStateFlags); | 
 
 
 
 
 
 | 298 | 
  | 
 
 
 
 
 
 | 299 | 
 typedef NTSTATUS | 
 
 
 
 
 
 | 300 | 
 (NTAPI *PFNUSBCAMD_BulkReadWrite)( | 
 
 
 
 
 
 | 301 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 302 | 
   USHORT PipeIndex, | 
 
 
 
 
 
 | 303 | 
   PVOID Buffer, | 
 
 
 
 
 
 | 304 | 
   ULONG BufferLength, | 
 
 
 
 
 
 | 305 | 
   PCOMMAND_COMPLETE_FUNCTION CommandComplete, | 
 
 
 
 
 
 | 306 | 
   PVOID CommandContext); | 
 
 
 
 
 
 | 307 | 
  | 
 
 
 
 
 
 | 308 | 
 #define USBCAMD_VERSION_200               0x200 | 
 
 
 
 
 
 | 309 | 
  | 
 
 
 
 
 
 | 310 | 
 typedef struct _USBCAMD_INTERFACE { | 
 
 
 
 
 
 | 311 | 
   INTERFACE Interface; | 
 
 
 
 
 
 | 312 | 
   PFNUSBCAMD_WaitOnDeviceEvent USBCAMD_WaitOnDeviceEvent; | 
 
 
 
 
 
 | 313 | 
   PFNUSBCAMD_BulkReadWrite USBCAMD_BulkReadWrite; | 
 
 
 
 
 
 | 314 | 
   PFNUSBCAMD_SetVideoFormat USBCAMD_SetVideoFormat; | 
 
 
 
 
 
 | 315 | 
   PFNUSBCAMD_SetIsoPipeState USBCAMD_SetIsoPipeState; | 
 
 
 
 
 
 | 316 | 
   PFNUSBCAMD_CancelBulkReadWrite USBCAMD_CancelBulkReadWrite; | 
 
 
 
 
 
 | 317 | 
 } USBCAMD_INTERFACE, *PUSBCAMD_INTERFACE; | 
 
 
 
 
 
 | 318 | 
  | 
 
 
 
 
 
 | 319 | 
 /* FIXME : Do we need USBCAMAPI here ? */ | 
 
 
 
 
 
 | 320 | 
  | 
 
 
 
 
 
 | 321 | 
 USBCAMAPI | 
 
 
 
 
 
 | 322 | 
 ULONG | 
 
 
 
 
 
 | 323 | 
 NTAPI | 
 
 
 
 
 
 | 324 | 
 USBCAMD_DriverEntry( | 
 
 
 
 
 
 | 325 | 
   PVOID Context1, | 
 
 
 
 
 
 | 326 | 
   PVOID Context2, | 
 
 
 
 
 
 | 327 | 
   ULONG DeviceContextSize, | 
 
 
 
 
 
 | 328 | 
   ULONG FrameContextSize, | 
 
 
 
 
 
 | 329 | 
   PADAPTER_RECEIVE_PACKET_ROUTINE ReceivePacket); | 
 
 
 
 
 
 | 330 | 
  | 
 
 
 
 
 
 | 331 | 
 USBCAMAPI | 
 
 
 
 
 
 | 332 | 
 PVOID | 
 
 
 
 
 
 | 333 | 
 NTAPI | 
 
 
 
 
 
 | 334 | 
 USBCAMD_AdapterReceivePacket( | 
 
 
 
 
 
 | 335 | 
   PHW_STREAM_REQUEST_BLOCK Srb, | 
 
 
 
 
 
 | 336 | 
   PUSBCAMD_DEVICE_DATA DeviceData, | 
 
 
 
 
 
 | 337 | 
   PDEVICE_OBJECT *DeviceObject, | 
 
 
 
 
 
 | 338 | 
   BOOLEAN NeedsCompletion); | 
 
 
 
 
 
 | 339 | 
  | 
 
 
 
 
 
 | 340 | 
 USBCAMAPI | 
 
 
 
 
 
 | 341 | 
 NTSTATUS | 
 
 
 
 
 
 | 342 | 
 NTAPI | 
 
 
 
 
 
 | 343 | 
 USBCAMD_ControlVendorCommand( | 
 
 
 
 
 
 | 344 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 345 | 
   UCHAR Request, | 
 
 
 
 
 
 | 346 | 
   USHORT Value, | 
 
 
 
 
 
 | 347 | 
   USHORT Index, | 
 
 
 
 
 
 | 348 | 
   PVOID Buffer, | 
 
 
 
 
 
 | 349 | 
   PULONG BufferLength, | 
 
 
 
 
 
 | 350 | 
   BOOLEAN GetData, | 
 
 
 
 
 
 | 351 | 
   PCOMMAND_COMPLETE_FUNCTION CommandComplete, | 
 
 
 
 
 
 | 352 | 
   PVOID CommandContext); | 
 
 
 
 
 
 | 353 | 
  | 
 
 
 
 
 
 | 354 | 
 USBCAMAPI | 
 
 
 
 
 
 | 355 | 
 NTSTATUS | 
 
 
 
 
 
 | 356 | 
 NTAPI | 
 
 
 
 
 
 | 357 | 
 USBCAMD_SelectAlternateInterface( | 
 
 
 
 
 
 | 358 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 359 | 
   PUSBD_INTERFACE_INFORMATION RequestInterface); | 
 
 
 
 
 
 | 360 | 
  | 
 
 
 
 
 
 | 361 | 
 USBCAMAPI | 
 
 
 
 
 
 | 362 | 
 NTSTATUS | 
 
 
 
 
 
 | 363 | 
 NTAPI | 
 
 
 
 
 
 | 364 | 
 USBCAMD_GetRegistryKeyValue( | 
 
 
 
 
 
 | 365 | 
   HANDLE Handle, | 
 
 
 
 
 
 | 366 | 
   PWCHAR KeyNameString, | 
 
 
 
 
 
 | 367 | 
   ULONG KeyNameStringLength, | 
 
 
 
 
 
 | 368 | 
   PVOID Data, | 
 
 
 
 
 
 | 369 | 
   ULONG DataLength); | 
 
 
 
 
 
 | 370 | 
  | 
 
 
 
 
 
 | 371 | 
 USBCAMAPI | 
 
 
 
 
 
 | 372 | 
 ULONG | 
 
 
 
 
 
 | 373 | 
 NTAPI | 
 
 
 
 
 
 | 374 | 
 USBCAMD_InitializeNewInterface( | 
 
 
 
 
 
 | 375 | 
   PVOID DeviceContext, | 
 
 
 
 
 
 | 376 | 
   PVOID DeviceData, | 
 
 
 
 
 
 | 377 | 
   ULONG Version, | 
 
 
 
 
 
 | 378 | 
   ULONG CamControlFlag); | 
 
 
 
 
 
 | 379 | 
  | 
 
 
 
 
 
 | 380 | 
 #ifdef __cplusplus | 
 
 
 
 
 
 | 381 | 
 } | 
 
 
 
 
 
 | 382 | 
 #endif | 
 
 
 
 
 
 | 383 | 
  | 
 
 
 
 
 
 | 384 | 
 #endif /* !defined(__USB_H) && !defined(__USBDI_H) */ |