| /* |
| * Windows backend for libusb 1.0 |
| * Copyright © 2009-2012 Pete Batard <pete@akeo.ie> |
| * With contributions from Michael Plante, Orin Eman et al. |
| * Parts of this code adapted from libusb-win32-v1 by Stephan Meyer |
| * Major code testing contribution by Xiaofan Chen |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2.1 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Lesser General Public License for more details. |
| * |
| * You should have received a copy of the GNU Lesser General Public |
| * License along with this library; if not, write to the Free Software |
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
| */ |
| |
| #ifndef LIBUSB_WINDOWS_WINUSB_H |
| #define LIBUSB_WINDOWS_WINUSB_H |
| |
| #include <devioctl.h> |
| #include <guiddef.h> |
| |
| #include "windows_common.h" |
| |
| #define MAX_CTRL_BUFFER_LENGTH 4096 |
| #define MAX_USB_STRING_LENGTH 128 |
| #define MAX_HID_REPORT_SIZE 1024 |
| #define MAX_HID_DESCRIPTOR_SIZE 256 |
| #define MAX_GUID_STRING_LENGTH 40 |
| #define MAX_PATH_LENGTH 256 |
| #define MAX_KEY_LENGTH 256 |
| #define LIST_SEPARATOR ';' |
| |
| // Handle code for HID interface that have been claimed ("dibs") |
| #define INTERFACE_CLAIMED ((HANDLE)(intptr_t)0xD1B5) |
| // Additional return code for HID operations that completed synchronously |
| #define LIBUSB_COMPLETED (LIBUSB_SUCCESS + 1) |
| |
| // http://msdn.microsoft.com/en-us/library/ff545978.aspx |
| // http://msdn.microsoft.com/en-us/library/ff545972.aspx |
| // http://msdn.microsoft.com/en-us/library/ff545982.aspx |
| static const GUID GUID_DEVINTERFACE_USB_HOST_CONTROLLER = {0x3ABF6F2D, 0x71C4, 0x462A, {0x8A, 0x92, 0x1E, 0x68, 0x61, 0xE6, 0xAF, 0x27}}; |
| static const GUID GUID_DEVINTERFACE_USB_HUB = {0xF18A0E88, 0xC30C, 0x11D0, {0x88, 0x15, 0x00, 0xA0, 0xC9, 0x06, 0xBE, 0xD8}}; |
| static const GUID GUID_DEVINTERFACE_USB_DEVICE = {0xA5DCBF10, 0x6530, 0x11D2, {0x90, 0x1F, 0x00, 0xC0, 0x4F, 0xB9, 0x51, 0xED}}; |
| static const GUID GUID_DEVINTERFACE_LIBUSB0_FILTER = {0xF9F3FF14, 0xAE21, 0x48A0, {0x8A, 0x25, 0x80, 0x11, 0xA7, 0xA9, 0x31, 0xD9}}; |
| |
| // The following define MUST be == sizeof(USB_DESCRIPTOR_REQUEST) |
| #define USB_DESCRIPTOR_REQUEST_SIZE 12U |
| |
| /* |
| * Multiple USB API backend support |
| */ |
| #define USB_API_UNSUPPORTED 0 |
| #define USB_API_HUB 1 |
| #define USB_API_COMPOSITE 2 |
| #define USB_API_WINUSBX 3 |
| #define USB_API_HID 4 |
| #define USB_API_MAX 5 |
| |
| // Sub-APIs for WinUSB-like driver APIs (WinUSB, libusbK, libusb-win32 through the libusbK DLL) |
| // Must have the same values as the KUSB_DRVID enum from libusbk.h |
| #define SUB_API_NOTSET -1 |
| #define SUB_API_LIBUSBK 0 |
| #define SUB_API_LIBUSB0 1 |
| #define SUB_API_WINUSB 2 |
| #define SUB_API_MAX 3 |
| |
| struct windows_usb_api_backend { |
| const uint8_t id; |
| const char * const designation; |
| const char * const * const driver_name_list; // Driver name, without .sys, e.g. "usbccgp" |
| const uint8_t nb_driver_names; |
| bool (*init)(struct libusb_context *ctx); |
| void (*exit)(void); |
| int (*open)(int sub_api, struct libusb_device_handle *dev_handle); |
| void (*close)(int sub_api, struct libusb_device_handle *dev_handle); |
| int (*configure_endpoints)(int sub_api, struct libusb_device_handle *dev_handle, uint8_t iface); |
| int (*claim_interface)(int sub_api, struct libusb_device_handle *dev_handle, uint8_t iface); |
| int (*set_interface_altsetting)(int sub_api, struct libusb_device_handle *dev_handle, uint8_t iface, uint8_t altsetting); |
| int (*release_interface)(int sub_api, struct libusb_device_handle *dev_handle, uint8_t iface); |
| int (*clear_halt)(int sub_api, struct libusb_device_handle *dev_handle, unsigned char endpoint); |
| int (*reset_device)(int sub_api, struct libusb_device_handle *dev_handle); |
| int (*submit_bulk_transfer)(int sub_api, struct usbi_transfer *itransfer); |
| int (*submit_iso_transfer)(int sub_api, struct usbi_transfer *itransfer); |
| int (*submit_control_transfer)(int sub_api, struct usbi_transfer *itransfer); |
| int (*cancel_transfer)(int sub_api, struct usbi_transfer *itransfer); |
| enum libusb_transfer_status (*copy_transfer_data)(int sub_api, struct usbi_transfer *itransfer, DWORD length); |
| }; |
| |
| extern const struct windows_usb_api_backend usb_api_backend[USB_API_MAX]; |
| |
| #define PRINT_UNSUPPORTED_API(fname) \ |
| usbi_dbg("unsupported API call for '%s' " \ |
| "(unrecognized device driver)", #fname) |
| |
| #define CHECK_SUPPORTED_API(apip, fname) \ |
| do { \ |
| if ((apip)->fname == NULL) { \ |
| PRINT_UNSUPPORTED_API(fname); \ |
| return LIBUSB_ERROR_NOT_SUPPORTED; \ |
| } \ |
| } while (0) |
| |
| /* |
| * private structures definition |
| * with inline pseudo constructors/destructors |
| */ |
| |
| // TODO (v2+): move hid desc to libusb.h? |
| struct libusb_hid_descriptor { |
| uint8_t bLength; |
| uint8_t bDescriptorType; |
| uint16_t bcdHID; |
| uint8_t bCountryCode; |
| uint8_t bNumDescriptors; |
| uint8_t bClassDescriptorType; |
| uint16_t wClassDescriptorLength; |
| }; |
| |
| #define LIBUSB_DT_HID_SIZE 9 |
| #define HID_MAX_CONFIG_DESC_SIZE (LIBUSB_DT_CONFIG_SIZE + LIBUSB_DT_INTERFACE_SIZE \ |
| + LIBUSB_DT_HID_SIZE + 2 * LIBUSB_DT_ENDPOINT_SIZE) |
| #define HID_MAX_REPORT_SIZE 1024 |
| #define HID_IN_EP 0x81 |
| #define HID_OUT_EP 0x02 |
| #define LIBUSB_REQ_RECIPIENT(request_type) ((request_type) & 0x1F) |
| #define LIBUSB_REQ_TYPE(request_type) ((request_type) & (0x03 << 5)) |
| #define LIBUSB_REQ_IN(request_type) ((request_type) & LIBUSB_ENDPOINT_IN) |
| #define LIBUSB_REQ_OUT(request_type) (!LIBUSB_REQ_IN(request_type)) |
| |
| // The following are used for HID reports IOCTLs |
| #define HID_IN_CTL_CODE(id) \ |
| CTL_CODE(FILE_DEVICE_KEYBOARD, (id), METHOD_IN_DIRECT, FILE_ANY_ACCESS) |
| #define HID_OUT_CTL_CODE(id) \ |
| CTL_CODE(FILE_DEVICE_KEYBOARD, (id), METHOD_OUT_DIRECT, FILE_ANY_ACCESS) |
| |
| #define IOCTL_HID_GET_FEATURE HID_OUT_CTL_CODE(100) |
| #define IOCTL_HID_GET_INPUT_REPORT HID_OUT_CTL_CODE(104) |
| #define IOCTL_HID_SET_FEATURE HID_IN_CTL_CODE(100) |
| #define IOCTL_HID_SET_OUTPUT_REPORT HID_IN_CTL_CODE(101) |
| |
| enum libusb_hid_request_type { |
| HID_REQ_GET_REPORT = 0x01, |
| HID_REQ_GET_IDLE = 0x02, |
| HID_REQ_GET_PROTOCOL = 0x03, |
| HID_REQ_SET_REPORT = 0x09, |
| HID_REQ_SET_IDLE = 0x0A, |
| HID_REQ_SET_PROTOCOL = 0x0B |
| }; |
| |
| enum libusb_hid_report_type { |
| HID_REPORT_TYPE_INPUT = 0x01, |
| HID_REPORT_TYPE_OUTPUT = 0x02, |
| HID_REPORT_TYPE_FEATURE = 0x03 |
| }; |
| |
| struct hid_device_priv { |
| uint16_t vid; |
| uint16_t pid; |
| uint8_t config; |
| uint8_t nb_interfaces; |
| bool uses_report_ids[3]; // input, ouptput, feature |
| uint16_t input_report_size; |
| uint16_t output_report_size; |
| uint16_t feature_report_size; |
| uint16_t usage; |
| uint16_t usagePage; |
| WCHAR string[3][MAX_USB_STRING_LENGTH]; |
| uint8_t string_index[3]; // man, prod, ser |
| }; |
| |
| static inline struct winusb_device_priv *winusb_device_priv_init(struct libusb_device *dev) |
| { |
| struct winusb_device_priv *priv = usbi_get_device_priv(dev); |
| int i; |
| |
| priv->apib = &usb_api_backend[USB_API_UNSUPPORTED]; |
| priv->sub_api = SUB_API_NOTSET; |
| for (i = 0; i < USB_MAXINTERFACES; i++) { |
| priv->usb_interface[i].apib = &usb_api_backend[USB_API_UNSUPPORTED]; |
| priv->usb_interface[i].sub_api = SUB_API_NOTSET; |
| } |
| |
| return priv; |
| } |
| |
| static inline void winusb_device_priv_release(struct libusb_device *dev) |
| { |
| struct winusb_device_priv *priv = usbi_get_device_priv(dev); |
| int i; |
| |
| free(priv->dev_id); |
| free(priv->path); |
| if ((dev->device_descriptor.bNumConfigurations > 0) && (priv->config_descriptor != NULL)) { |
| for (i = 0; i < dev->device_descriptor.bNumConfigurations; i++) { |
| if (priv->config_descriptor[i] == NULL) |
| continue; |
| free((UCHAR *)priv->config_descriptor[i] - USB_DESCRIPTOR_REQUEST_SIZE); |
| } |
| } |
| free(priv->config_descriptor); |
| free(priv->hid); |
| for (i = 0; i < USB_MAXINTERFACES; i++) { |
| free(priv->usb_interface[i].path); |
| free(priv->usb_interface[i].endpoint); |
| } |
| } |
| |
| // used to match a device driver (including filter drivers) against a supported API |
| struct driver_lookup { |
| char list[MAX_KEY_LENGTH + 1]; // REG_MULTI_SZ list of services (driver) names |
| const DWORD reg_prop; // SPDRP registry key to use to retrieve list |
| const char *designation; // internal designation (for debug output) |
| }; |
| |
| /* |
| * Windows DDK API definitions. Most of it copied from MinGW's includes |
| */ |
| typedef DWORD DEVNODE, DEVINST; |
| typedef DEVNODE *PDEVNODE, *PDEVINST; |
| typedef DWORD RETURN_TYPE; |
| typedef RETURN_TYPE CONFIGRET; |
| |
| #define CR_SUCCESS 0x00000000 |
| |
| /* Cfgmgr32 dependencies */ |
| DLL_DECLARE_HANDLE(Cfgmgr32); |
| DLL_DECLARE_FUNC(WINAPI, CONFIGRET, CM_Get_Parent, (PDEVINST, DEVINST, ULONG)); |
| DLL_DECLARE_FUNC(WINAPI, CONFIGRET, CM_Get_Child, (PDEVINST, DEVINST, ULONG)); |
| |
| /* AdvAPI32 dependencies */ |
| DLL_DECLARE_HANDLE(AdvAPI32); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, LONG, p, RegQueryValueExW, (HKEY, LPCWSTR, LPDWORD, LPDWORD, LPBYTE, LPDWORD)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, LONG, p, RegCloseKey, (HKEY)); |
| |
| /* OLE32 dependency */ |
| DLL_DECLARE_HANDLE(OLE32); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, HRESULT, p, IIDFromString, (LPCOLESTR, LPIID)); |
| |
| /* SetupAPI dependencies */ |
| DLL_DECLARE_HANDLE(SetupAPI); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, HDEVINFO, p, SetupDiGetClassDevsA, (LPCGUID, PCSTR, HWND, DWORD)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, BOOL, p, SetupDiEnumDeviceInfo, (HDEVINFO, DWORD, PSP_DEVINFO_DATA)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, BOOL, p, SetupDiEnumDeviceInterfaces, (HDEVINFO, PSP_DEVINFO_DATA, |
| LPCGUID, DWORD, PSP_DEVICE_INTERFACE_DATA)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, BOOL, p, SetupDiGetDeviceInstanceIdA, (HDEVINFO, PSP_DEVINFO_DATA, |
| PCSTR, DWORD, PDWORD)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, BOOL, p, SetupDiGetDeviceInterfaceDetailA, (HDEVINFO, PSP_DEVICE_INTERFACE_DATA, |
| PSP_DEVICE_INTERFACE_DETAIL_DATA_A, DWORD, PDWORD, PSP_DEVINFO_DATA)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, BOOL, p, SetupDiGetDeviceRegistryPropertyA, (HDEVINFO, |
| PSP_DEVINFO_DATA, DWORD, PDWORD, PBYTE, DWORD, PDWORD)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, BOOL, p, SetupDiDestroyDeviceInfoList, (HDEVINFO)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, HKEY, p, SetupDiOpenDevRegKey, (HDEVINFO, PSP_DEVINFO_DATA, DWORD, DWORD, DWORD, REGSAM)); |
| DLL_DECLARE_FUNC_PREFIXED(WINAPI, HKEY, p, SetupDiOpenDeviceInterfaceRegKey, (HDEVINFO, PSP_DEVICE_INTERFACE_DATA, DWORD, DWORD)); |
| |
| #define FILE_DEVICE_USB FILE_DEVICE_UNKNOWN |
| |
| #define USB_GET_NODE_INFORMATION 258 |
| #define USB_GET_DESCRIPTOR_FROM_NODE_CONNECTION 260 |
| #define USB_GET_NODE_CONNECTION_INFORMATION_EX 274 |
| #define USB_GET_NODE_CONNECTION_INFORMATION_EX_V2 279 |
| |
| #define USB_CTL_CODE(id) \ |
| CTL_CODE(FILE_DEVICE_USB, (id), METHOD_BUFFERED, FILE_ANY_ACCESS) |
| |
| #define IOCTL_USB_GET_NODE_INFORMATION \ |
| USB_CTL_CODE(USB_GET_NODE_INFORMATION) |
| |
| #define IOCTL_USB_GET_DESCRIPTOR_FROM_NODE_CONNECTION \ |
| USB_CTL_CODE(USB_GET_DESCRIPTOR_FROM_NODE_CONNECTION) |
| |
| #define IOCTL_USB_GET_NODE_CONNECTION_INFORMATION_EX \ |
| USB_CTL_CODE(USB_GET_NODE_CONNECTION_INFORMATION_EX) |
| |
| #define IOCTL_USB_GET_NODE_CONNECTION_INFORMATION_EX_V2 \ |
| USB_CTL_CODE(USB_GET_NODE_CONNECTION_INFORMATION_EX_V2) |
| |
| typedef enum _USB_CONNECTION_STATUS { |
| NoDeviceConnected, |
| DeviceConnected, |
| DeviceFailedEnumeration, |
| DeviceGeneralFailure, |
| DeviceCausedOvercurrent, |
| DeviceNotEnoughPower, |
| DeviceNotEnoughBandwidth, |
| DeviceHubNestedTooDeeply, |
| DeviceInLegacyHub, |
| DeviceEnumerating, |
| DeviceReset |
| } USB_CONNECTION_STATUS; |
| |
| typedef enum _USB_DEVICE_SPEED { |
| UsbLowSpeed = 0, |
| UsbFullSpeed, |
| UsbHighSpeed, |
| UsbSuperSpeed, |
| UsbSuperSpeedPlus // Not in Microsoft headers |
| } USB_DEVICE_SPEED; |
| |
| typedef enum _USB_HUB_NODE { |
| UsbHub, |
| UsbMIParent |
| } USB_HUB_NODE; |
| |
| #if defined(_MSC_VER) |
| // disable /W4 MSVC warnings that are benign |
| #pragma warning(push) |
| #pragma warning(disable:4214) // bit field types other than int |
| #endif |
| |
| // Most of the structures below need to be packed |
| #include <pshpack1.h> |
| |
| typedef struct _USB_HUB_DESCRIPTOR { |
| UCHAR bDescriptorLength; |
| UCHAR bDescriptorType; |
| UCHAR bNumberOfPorts; |
| USHORT wHubCharacteristics; |
| UCHAR bPowerOnToPowerGood; |
| UCHAR bHubControlCurrent; |
| UCHAR bRemoveAndPowerMask[64]; |
| } USB_HUB_DESCRIPTOR, *PUSB_HUB_DESCRIPTOR; |
| |
| typedef struct _USB_HUB_INFORMATION { |
| USB_HUB_DESCRIPTOR HubDescriptor; |
| BOOLEAN HubIsBusPowered; |
| } USB_HUB_INFORMATION, *PUSB_HUB_INFORMATION; |
| |
| typedef struct _USB_NODE_INFORMATION { |
| USB_HUB_NODE NodeType; |
| union { |
| USB_HUB_INFORMATION HubInformation; |
| // USB_MI_PARENT_INFORMATION MiParentInformation; |
| } u; |
| } USB_NODE_INFORMATION, *PUSB_NODE_INFORMATION; |
| |
| typedef struct _USB_DESCRIPTOR_REQUEST { |
| ULONG ConnectionIndex; |
| struct { |
| UCHAR bmRequest; |
| UCHAR bRequest; |
| USHORT wValue; |
| USHORT wIndex; |
| USHORT wLength; |
| } SetupPacket; |
| // UCHAR Data[0]; |
| } USB_DESCRIPTOR_REQUEST, *PUSB_DESCRIPTOR_REQUEST; |
| |
| typedef struct _USB_CONFIGURATION_DESCRIPTOR_SHORT { |
| USB_DESCRIPTOR_REQUEST req; |
| USB_CONFIGURATION_DESCRIPTOR desc; |
| } USB_CONFIGURATION_DESCRIPTOR_SHORT; |
| |
| typedef struct USB_INTERFACE_DESCRIPTOR { |
| UCHAR bLength; |
| UCHAR bDescriptorType; |
| UCHAR bInterfaceNumber; |
| UCHAR bAlternateSetting; |
| UCHAR bNumEndpoints; |
| UCHAR bInterfaceClass; |
| UCHAR bInterfaceSubClass; |
| UCHAR bInterfaceProtocol; |
| UCHAR iInterface; |
| } USB_INTERFACE_DESCRIPTOR, *PUSB_INTERFACE_DESCRIPTOR; |
| |
| typedef struct _USB_NODE_CONNECTION_INFORMATION_EX { |
| ULONG ConnectionIndex; |
| USB_DEVICE_DESCRIPTOR DeviceDescriptor; |
| UCHAR CurrentConfigurationValue; |
| UCHAR Speed; |
| BOOLEAN DeviceIsHub; |
| USHORT DeviceAddress; |
| ULONG NumberOfOpenPipes; |
| USB_CONNECTION_STATUS ConnectionStatus; |
| // USB_PIPE_INFO PipeList[0]; |
| } USB_NODE_CONNECTION_INFORMATION_EX, *PUSB_NODE_CONNECTION_INFORMATION_EX; |
| |
| typedef union _USB_PROTOCOLS { |
| ULONG ul; |
| struct { |
| ULONG Usb110:1; |
| ULONG Usb200:1; |
| ULONG Usb300:1; |
| ULONG ReservedMBZ:29; |
| }; |
| } USB_PROTOCOLS, *PUSB_PROTOCOLS; |
| |
| typedef union _USB_NODE_CONNECTION_INFORMATION_EX_V2_FLAGS { |
| ULONG ul; |
| struct { |
| ULONG DeviceIsOperatingAtSuperSpeedOrHigher:1; |
| ULONG DeviceIsSuperSpeedCapableOrHigher:1; |
| ULONG DeviceIsOperatingAtSuperSpeedPlusOrHigher:1; |
| ULONG DeviceIsSuperSpeedPlusCapableOrHigher:1; |
| ULONG ReservedMBZ:28; |
| }; |
| } USB_NODE_CONNECTION_INFORMATION_EX_V2_FLAGS, *PUSB_NODE_CONNECTION_INFORMATION_EX_V2_FLAGS; |
| |
| typedef struct _USB_NODE_CONNECTION_INFORMATION_EX_V2 { |
| ULONG ConnectionIndex; |
| ULONG Length; |
| USB_PROTOCOLS SupportedUsbProtocols; |
| USB_NODE_CONNECTION_INFORMATION_EX_V2_FLAGS Flags; |
| } USB_NODE_CONNECTION_INFORMATION_EX_V2, *PUSB_NODE_CONNECTION_INFORMATION_EX_V2; |
| |
| #include <poppack.h> |
| |
| #if defined(_MSC_VER) |
| // Restore original warnings |
| #pragma warning(pop) |
| #endif |
| |
| /* winusb.dll interface */ |
| |
| /* pipe policies */ |
| #define SHORT_PACKET_TERMINATE 0x01 |
| #define AUTO_CLEAR_STALL 0x02 |
| #define PIPE_TRANSFER_TIMEOUT 0x03 |
| #define IGNORE_SHORT_PACKETS 0x04 |
| #define ALLOW_PARTIAL_READS 0x05 |
| #define AUTO_FLUSH 0x06 |
| #define RAW_IO 0x07 |
| #define MAXIMUM_TRANSFER_SIZE 0x08 |
| /* libusbK */ |
| #define ISO_ALWAYS_START_ASAP 0x21 |
| |
| typedef struct _USBD_ISO_PACKET_DESCRIPTOR { |
| ULONG Offset; |
| ULONG Length; |
| USBD_STATUS Status; |
| } USBD_ISO_PACKET_DESCRIPTOR, *PUSBD_ISO_PACKET_DESCRIPTOR; |
| |
| typedef enum _USBD_PIPE_TYPE { |
| UsbdPipeTypeControl, |
| UsbdPipeTypeIsochronous, |
| UsbdPipeTypeBulk, |
| UsbdPipeTypeInterrupt |
| } USBD_PIPE_TYPE; |
| |
| typedef struct { |
| USBD_PIPE_TYPE PipeType; |
| UCHAR PipeId; |
| USHORT MaximumPacketSize; |
| UCHAR Interval; |
| ULONG MaximumBytesPerInterval; |
| } WINUSB_PIPE_INFORMATION_EX, *PWINUSB_PIPE_INFORMATION_EX; |
| |
| #include <pshpack1.h> |
| |
| typedef struct _WINUSB_SETUP_PACKET { |
| UCHAR RequestType; |
| UCHAR Request; |
| USHORT Value; |
| USHORT Index; |
| USHORT Length; |
| } WINUSB_SETUP_PACKET, *PWINUSB_SETUP_PACKET; |
| |
| #include <poppack.h> |
| |
| typedef PVOID WINUSB_INTERFACE_HANDLE, *PWINUSB_INTERFACE_HANDLE; |
| typedef PVOID WINUSB_ISOCH_BUFFER_HANDLE, *PWINUSB_ISOCH_BUFFER_HANDLE; |
| |
| typedef BOOL (WINAPI *WinUsb_AbortPipe_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID |
| ); |
| typedef BOOL (WINAPI *WinUsb_ControlTransfer_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| WINUSB_SETUP_PACKET SetupPacket, |
| PUCHAR Buffer, |
| ULONG BufferLength, |
| PULONG LengthTransferred, |
| LPOVERLAPPED Overlapped |
| ); |
| typedef BOOL (WINAPI *WinUsb_FlushPipe_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID |
| ); |
| typedef BOOL (WINAPI *WinUsb_Free_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle |
| ); |
| typedef BOOL (WINAPI *WinUsb_GetAssociatedInterface_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR AssociatedInterfaceIndex, |
| PWINUSB_INTERFACE_HANDLE AssociatedInterfaceHandle |
| ); |
| typedef BOOL (WINAPI *WinUsb_Initialize_t)( |
| HANDLE DeviceHandle, |
| PWINUSB_INTERFACE_HANDLE InterfaceHandle |
| ); |
| typedef BOOL (WINAPI *WinUsb_QueryPipeEx_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR AlternateInterfaceHandle, |
| UCHAR PipeIndex, |
| PWINUSB_PIPE_INFORMATION_EX PipeInformationEx |
| ); |
| typedef BOOL (WINAPI *WinUsb_ReadIsochPipeAsap_t)( |
| PWINUSB_ISOCH_BUFFER_HANDLE BufferHandle, |
| ULONG Offset, |
| ULONG Length, |
| BOOL ContinueStream, |
| ULONG NumberOfPackets, |
| PUSBD_ISO_PACKET_DESCRIPTOR IsoPacketDescriptors, |
| LPOVERLAPPED Overlapped |
| ); |
| typedef BOOL (WINAPI *WinUsb_ReadPipe_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID, |
| PUCHAR Buffer, |
| ULONG BufferLength, |
| PULONG LengthTransferred, |
| LPOVERLAPPED Overlapped |
| ); |
| typedef BOOL (WINAPI *WinUsb_RegisterIsochBuffer_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID, |
| PVOID Buffer, |
| ULONG BufferLength, |
| PWINUSB_ISOCH_BUFFER_HANDLE BufferHandle |
| ); |
| typedef BOOL (WINAPI *WinUsb_ResetPipe_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID |
| ); |
| typedef BOOL (WINAPI *WinUsb_SetCurrentAlternateSetting_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR AlternateSetting |
| ); |
| typedef BOOL (WINAPI *WinUsb_SetPipePolicy_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID, |
| ULONG PolicyType, |
| ULONG ValueLength, |
| PVOID Value |
| ); |
| typedef BOOL (WINAPI *WinUsb_UnregisterIsochBuffer_t)( |
| WINUSB_ISOCH_BUFFER_HANDLE BufferHandle |
| ); |
| typedef BOOL (WINAPI *WinUsb_WriteIsochPipeAsap_t)( |
| WINUSB_ISOCH_BUFFER_HANDLE BufferHandle, |
| ULONG Offset, |
| ULONG Length, |
| BOOL ContinueStream, |
| LPOVERLAPPED Overlapped |
| ); |
| typedef BOOL (WINAPI *WinUsb_WritePipe_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID, |
| PUCHAR Buffer, |
| ULONG BufferLength, |
| PULONG LengthTransferred, |
| LPOVERLAPPED Overlapped |
| ); |
| |
| /* /!\ These must match the ones from the official libusbk.h */ |
| typedef enum _KUSB_FNID { |
| KUSB_FNID_Init, |
| KUSB_FNID_Free, |
| KUSB_FNID_ClaimInterface, |
| KUSB_FNID_ReleaseInterface, |
| KUSB_FNID_SetAltInterface, |
| KUSB_FNID_GetAltInterface, |
| KUSB_FNID_GetDescriptor, |
| KUSB_FNID_ControlTransfer, |
| KUSB_FNID_SetPowerPolicy, |
| KUSB_FNID_GetPowerPolicy, |
| KUSB_FNID_SetConfiguration, |
| KUSB_FNID_GetConfiguration, |
| KUSB_FNID_ResetDevice, |
| KUSB_FNID_Initialize, |
| KUSB_FNID_SelectInterface, |
| KUSB_FNID_GetAssociatedInterface, |
| KUSB_FNID_Clone, |
| KUSB_FNID_QueryInterfaceSettings, |
| KUSB_FNID_QueryDeviceInformation, |
| KUSB_FNID_SetCurrentAlternateSetting, |
| KUSB_FNID_GetCurrentAlternateSetting, |
| KUSB_FNID_QueryPipe, |
| KUSB_FNID_SetPipePolicy, |
| KUSB_FNID_GetPipePolicy, |
| KUSB_FNID_ReadPipe, |
| KUSB_FNID_WritePipe, |
| KUSB_FNID_ResetPipe, |
| KUSB_FNID_AbortPipe, |
| KUSB_FNID_FlushPipe, |
| KUSB_FNID_IsoReadPipe, |
| KUSB_FNID_IsoWritePipe, |
| KUSB_FNID_GetCurrentFrameNumber, |
| KUSB_FNID_GetOverlappedResult, |
| KUSB_FNID_GetProperty, |
| KUSB_FNID_COUNT, |
| } KUSB_FNID; |
| |
| typedef struct _KLIB_VERSION { |
| INT Major; |
| INT Minor; |
| INT Micro; |
| INT Nano; |
| } KLIB_VERSION, *PKLIB_VERSION; |
| |
| typedef BOOL (WINAPI *LibK_GetProcAddress_t)( |
| PVOID ProcAddress, |
| INT DriverID, |
| INT FunctionID |
| ); |
| |
| typedef VOID (WINAPI *LibK_GetVersion_t)( |
| PKLIB_VERSION Version |
| ); |
| |
| typedef BOOL (WINAPI *LibK_ResetDevice_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle |
| ); |
| |
| //KISO_PACKET is equivalent of libusb_iso_packet_descriptor except uses absolute "offset" field instead of sequential Lengths |
| typedef struct _KISO_PACKET { |
| UINT offset; |
| USHORT actual_length; //changed from libusbk_shared.h "Length" for clarity |
| USHORT status; |
| } KISO_PACKET, *PKISO_PACKET; |
| |
| typedef enum _KISO_FLAG { |
| KISO_FLAG_NONE = 0, |
| KISO_FLAG_SET_START_FRAME = 0x00000001, |
| } KISO_FLAG; |
| |
| //KISO_CONTEXT is the conceptual equivalent of libusb_transfer except is isochronous-specific and must match libusbk's version |
| typedef struct _KISO_CONTEXT { |
| KISO_FLAG Flags; |
| UINT StartFrame; |
| SHORT ErrorCount; |
| SHORT NumberOfPackets; |
| UINT UrbHdrStatus; |
| KISO_PACKET IsoPackets[0]; |
| } KISO_CONTEXT, *PKISO_CONTEXT; |
| |
| typedef BOOL(WINAPI *LibK_IsoReadPipe_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID, |
| PUCHAR Buffer, |
| ULONG BufferLength, |
| LPOVERLAPPED Overlapped, |
| PKISO_CONTEXT IsoContext |
| ); |
| |
| typedef BOOL(WINAPI *LibK_IsoWritePipe_t)( |
| WINUSB_INTERFACE_HANDLE InterfaceHandle, |
| UCHAR PipeID, |
| PUCHAR Buffer, |
| ULONG BufferLength, |
| LPOVERLAPPED Overlapped, |
| PKISO_CONTEXT IsoContext |
| ); |
| |
| struct winusb_interface { |
| HMODULE hDll; |
| WinUsb_AbortPipe_t AbortPipe; |
| WinUsb_ControlTransfer_t ControlTransfer; |
| WinUsb_FlushPipe_t FlushPipe; |
| WinUsb_Free_t Free; |
| WinUsb_GetAssociatedInterface_t GetAssociatedInterface; |
| WinUsb_Initialize_t Initialize; |
| WinUsb_ReadPipe_t ReadPipe; |
| WinUsb_ResetPipe_t ResetPipe; |
| WinUsb_SetCurrentAlternateSetting_t SetCurrentAlternateSetting; |
| WinUsb_SetPipePolicy_t SetPipePolicy; |
| WinUsb_WritePipe_t WritePipe; |
| union { |
| struct { |
| // Isochoronous functions for libusbK sub api: |
| LibK_IsoReadPipe_t IsoReadPipe; |
| LibK_IsoWritePipe_t IsoWritePipe; |
| // Reset device function for libusbK sub api: |
| LibK_ResetDevice_t ResetDevice; |
| }; |
| struct { |
| // Isochronous functions for WinUSB sub api: |
| WinUsb_QueryPipeEx_t QueryPipeEx; |
| WinUsb_ReadIsochPipeAsap_t ReadIsochPipeAsap; |
| WinUsb_RegisterIsochBuffer_t RegisterIsochBuffer; |
| WinUsb_UnregisterIsochBuffer_t UnregisterIsochBuffer; |
| WinUsb_WriteIsochPipeAsap_t WriteIsochPipeAsap; |
| }; |
| }; |
| }; |
| |
| /* hid.dll interface */ |
| |
| #define HIDP_STATUS_SUCCESS 0x110000 |
| typedef void * PHIDP_PREPARSED_DATA; |
| |
| #include <pshpack1.h> |
| |
| typedef struct _HIDD_ATTIRBUTES { |
| ULONG Size; |
| USHORT VendorID; |
| USHORT ProductID; |
| USHORT VersionNumber; |
| } HIDD_ATTRIBUTES, *PHIDD_ATTRIBUTES; |
| |
| #include <poppack.h> |
| |
| typedef USHORT USAGE; |
| typedef struct _HIDP_CAPS { |
| USAGE Usage; |
| USAGE UsagePage; |
| USHORT InputReportByteLength; |
| USHORT OutputReportByteLength; |
| USHORT FeatureReportByteLength; |
| USHORT Reserved[17]; |
| USHORT NumberLinkCollectionNodes; |
| USHORT NumberInputButtonCaps; |
| USHORT NumberInputValueCaps; |
| USHORT NumberInputDataIndices; |
| USHORT NumberOutputButtonCaps; |
| USHORT NumberOutputValueCaps; |
| USHORT NumberOutputDataIndices; |
| USHORT NumberFeatureButtonCaps; |
| USHORT NumberFeatureValueCaps; |
| USHORT NumberFeatureDataIndices; |
| } HIDP_CAPS, *PHIDP_CAPS; |
| |
| typedef enum _HIDP_REPORT_TYPE { |
| HidP_Input, |
| HidP_Output, |
| HidP_Feature |
| } HIDP_REPORT_TYPE; |
| |
| typedef struct _HIDP_VALUE_CAPS { |
| USAGE UsagePage; |
| UCHAR ReportID; |
| BOOLEAN IsAlias; |
| USHORT BitField; |
| USHORT LinkCollection; |
| USAGE LinkUsage; |
| USAGE LinkUsagePage; |
| BOOLEAN IsRange; |
| BOOLEAN IsStringRange; |
| BOOLEAN IsDesignatorRange; |
| BOOLEAN IsAbsolute; |
| BOOLEAN HasNull; |
| UCHAR Reserved; |
| USHORT BitSize; |
| USHORT ReportCount; |
| USHORT Reserved2[5]; |
| ULONG UnitsExp; |
| ULONG Units; |
| LONG LogicalMin, LogicalMax; |
| LONG PhysicalMin, PhysicalMax; |
| union { |
| struct { |
| USAGE UsageMin, UsageMax; |
| USHORT StringMin, StringMax; |
| USHORT DesignatorMin, DesignatorMax; |
| USHORT DataIndexMin, DataIndexMax; |
| } Range; |
| struct { |
| USAGE Usage, Reserved1; |
| USHORT StringIndex, Reserved2; |
| USHORT DesignatorIndex, Reserved3; |
| USHORT DataIndex, Reserved4; |
| } NotRange; |
| } u; |
| } HIDP_VALUE_CAPS, *PHIDP_VALUE_CAPS; |
| |
| DLL_DECLARE_HANDLE(hid); |
| DLL_DECLARE_FUNC(WINAPI, VOID, HidD_GetHidGuid, (LPGUID)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_GetAttributes, (HANDLE, PHIDD_ATTRIBUTES)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_GetPreparsedData, (HANDLE, PHIDP_PREPARSED_DATA *)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_FreePreparsedData, (PHIDP_PREPARSED_DATA)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_GetManufacturerString, (HANDLE, PVOID, ULONG)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_GetProductString, (HANDLE, PVOID, ULONG)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_GetSerialNumberString, (HANDLE, PVOID, ULONG)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_GetIndexedString, (HANDLE, ULONG, PVOID, ULONG)); |
| DLL_DECLARE_FUNC(WINAPI, LONG, HidP_GetCaps, (PHIDP_PREPARSED_DATA, PHIDP_CAPS)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_SetNumInputBuffers, (HANDLE, ULONG)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_GetPhysicalDescriptor, (HANDLE, PVOID, ULONG)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidD_FlushQueue, (HANDLE)); |
| DLL_DECLARE_FUNC(WINAPI, BOOL, HidP_GetValueCaps, (HIDP_REPORT_TYPE, PHIDP_VALUE_CAPS, PULONG, PHIDP_PREPARSED_DATA)); |
| |
| #endif |