usb 1.7.2-prebuild

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (183) hide show
  1. package/.github/workflows/prebuild.yml +62 -0
  2. package/.gitmodules +3 -0
  3. package/LICENSE +7 -0
  4. package/Readme.md +339 -0
  5. package/binding.gyp +90 -0
  6. package/libusb/.gitattributes +11 -0
  7. package/libusb/.private/README.txt +5 -0
  8. package/libusb/.private/bd.cmd +89 -0
  9. package/libusb/.private/bm.sh +54 -0
  10. package/libusb/.private/bwince.cmd +57 -0
  11. package/libusb/.private/post-rewrite.sh +28 -0
  12. package/libusb/.private/pre-commit.sh +42 -0
  13. package/libusb/.private/wbs.txt +61 -0
  14. package/libusb/.private/wbs_wince.txt +42 -0
  15. package/libusb/AUTHORS +78 -0
  16. package/libusb/COPYING +504 -0
  17. package/libusb/ChangeLog +211 -0
  18. package/libusb/INSTALL +234 -0
  19. package/libusb/INSTALL_WIN.txt +73 -0
  20. package/libusb/Makefile.am +28 -0
  21. package/libusb/NEWS +2 -0
  22. package/libusb/PORTING +94 -0
  23. package/libusb/README +28 -0
  24. package/libusb/README.git +41 -0
  25. package/libusb/TODO +2 -0
  26. package/libusb/Xcode/common.xcconfig +49 -0
  27. package/libusb/Xcode/debug.xcconfig +29 -0
  28. package/libusb/Xcode/libusb.xcconfig +21 -0
  29. package/libusb/Xcode/libusb.xcodeproj/project.pbxproj +1 -0
  30. package/libusb/Xcode/libusb_debug.xcconfig +21 -0
  31. package/libusb/Xcode/libusb_release.xcconfig +21 -0
  32. package/libusb/Xcode/release.xcconfig +30 -0
  33. package/libusb/android/README +114 -0
  34. package/libusb/android/jni/Android.mk +23 -0
  35. package/libusb/android/jni/Application.mk +24 -0
  36. package/libusb/android/jni/examples.mk +134 -0
  37. package/libusb/android/jni/libusb.mk +54 -0
  38. package/libusb/android/jni/tests.mk +56 -0
  39. package/libusb/autogen.sh +8 -0
  40. package/libusb/bootstrap.sh +19 -0
  41. package/libusb/configure.ac +304 -0
  42. package/libusb/doc/Makefile.am +9 -0
  43. package/libusb/doc/doxygen.cfg.in +1288 -0
  44. package/libusb/doc/libusb.png +0 -0
  45. package/libusb/examples/Makefile.am +19 -0
  46. package/libusb/examples/dpfp.c +506 -0
  47. package/libusb/examples/dpfp_threaded.c +544 -0
  48. package/libusb/examples/ezusb.c +831 -0
  49. package/libusb/examples/ezusb.h +120 -0
  50. package/libusb/examples/fxload.c +287 -0
  51. package/libusb/examples/getopt/getopt.c +1060 -0
  52. package/libusb/examples/getopt/getopt.h +180 -0
  53. package/libusb/examples/getopt/getopt1.c +188 -0
  54. package/libusb/examples/hotplugtest.c +104 -0
  55. package/libusb/examples/listdevs.c +71 -0
  56. package/libusb/examples/sam3u_benchmark.c +193 -0
  57. package/libusb/examples/xusb.c +1129 -0
  58. package/libusb/libusb/Makefile.am +75 -0
  59. package/libusb/libusb/core.c +2342 -0
  60. package/libusb/libusb/descriptor.c +1199 -0
  61. package/libusb/libusb/hotplug.c +327 -0
  62. package/libusb/libusb/hotplug.h +82 -0
  63. package/libusb/libusb/io.c +2631 -0
  64. package/libusb/libusb/libusb-1.0.def +166 -0
  65. package/libusb/libusb/libusb-1.0.rc +61 -0
  66. package/libusb/libusb/libusb.h +1998 -0
  67. package/libusb/libusb/libusbi.h +1040 -0
  68. package/libusb/libusb/os/darwin_usb.c +2009 -0
  69. package/libusb/libusb/os/darwin_usb.h +162 -0
  70. package/libusb/libusb/os/linux_netlink.c +369 -0
  71. package/libusb/libusb/os/linux_udev.c +307 -0
  72. package/libusb/libusb/os/linux_usbfs.c +2695 -0
  73. package/libusb/libusb/os/linux_usbfs.h +192 -0
  74. package/libusb/libusb/os/netbsd_usb.c +738 -0
  75. package/libusb/libusb/os/openbsd_usb.c +832 -0
  76. package/libusb/libusb/os/poll_posix.c +51 -0
  77. package/libusb/libusb/os/poll_posix.h +11 -0
  78. package/libusb/libusb/os/poll_windows.c +796 -0
  79. package/libusb/libusb/os/poll_windows.h +131 -0
  80. package/libusb/libusb/os/threads_posix.c +82 -0
  81. package/libusb/libusb/os/threads_posix.h +50 -0
  82. package/libusb/libusb/os/threads_windows.c +212 -0
  83. package/libusb/libusb/os/threads_windows.h +87 -0
  84. package/libusb/libusb/os/wince_usb.c +1032 -0
  85. package/libusb/libusb/os/wince_usb.h +131 -0
  86. package/libusb/libusb/os/windows_common.h +108 -0
  87. package/libusb/libusb/os/windows_usb.c +5347 -0
  88. package/libusb/libusb/os/windows_usb.h +971 -0
  89. package/libusb/libusb/strerror.c +199 -0
  90. package/libusb/libusb/sync.c +307 -0
  91. package/libusb/libusb/version.h +18 -0
  92. package/libusb/libusb/version_nano.h +1 -0
  93. package/libusb/libusb-1.0.pc.in +11 -0
  94. package/libusb/msvc/config.h +50 -0
  95. package/libusb/msvc/ddk_build.cmd +175 -0
  96. package/libusb/msvc/errno.h +102 -0
  97. package/libusb/msvc/fxload_2010.vcxproj +170 -0
  98. package/libusb/msvc/fxload_2010.vcxproj.filters +25 -0
  99. package/libusb/msvc/fxload_2012.vcxproj +174 -0
  100. package/libusb/msvc/fxload_2012.vcxproj.filters +25 -0
  101. package/libusb/msvc/fxload_2013.vcxproj +174 -0
  102. package/libusb/msvc/fxload_sources +23 -0
  103. package/libusb/msvc/getopt_2005.vcproj +288 -0
  104. package/libusb/msvc/getopt_2010.vcxproj +131 -0
  105. package/libusb/msvc/getopt_2010.vcxproj.filters +26 -0
  106. package/libusb/msvc/getopt_2012.vcxproj +136 -0
  107. package/libusb/msvc/getopt_2012.vcxproj.filters +26 -0
  108. package/libusb/msvc/getopt_2013.vcxproj +136 -0
  109. package/libusb/msvc/getopt_sources +20 -0
  110. package/libusb/msvc/hotplugtest_2010.vcxproj +163 -0
  111. package/libusb/msvc/hotplugtest_2010.vcxproj.filters +14 -0
  112. package/libusb/msvc/hotplugtest_2012.vcxproj +167 -0
  113. package/libusb/msvc/hotplugtest_2012.vcxproj.filters +14 -0
  114. package/libusb/msvc/hotplugtest_2013.vcxproj +167 -0
  115. package/libusb/msvc/hotplugtest_sources +20 -0
  116. package/libusb/msvc/inttypes.h +295 -0
  117. package/libusb/msvc/libusb.dsw +71 -0
  118. package/libusb/msvc/libusb_2005.sln +95 -0
  119. package/libusb/msvc/libusb_2010.sln +94 -0
  120. package/libusb/msvc/libusb_2012.sln +94 -0
  121. package/libusb/msvc/libusb_2013.sln +100 -0
  122. package/libusb/msvc/libusb_2015.sln +100 -0
  123. package/libusb/msvc/libusb_dll.dsp +194 -0
  124. package/libusb/msvc/libusb_dll_2005.vcproj +436 -0
  125. package/libusb/msvc/libusb_dll_2010.vcxproj +170 -0
  126. package/libusb/msvc/libusb_dll_2010.vcxproj.filters +81 -0
  127. package/libusb/msvc/libusb_dll_2012.vcxproj +175 -0
  128. package/libusb/msvc/libusb_dll_2012.vcxproj.filters +84 -0
  129. package/libusb/msvc/libusb_dll_2013.vcxproj +175 -0
  130. package/libusb/msvc/libusb_dll_wince.vcproj +1243 -0
  131. package/libusb/msvc/libusb_sources +38 -0
  132. package/libusb/msvc/libusb_static.dsp +174 -0
  133. package/libusb/msvc/libusb_static_2005.vcproj +362 -0
  134. package/libusb/msvc/libusb_static_2010.vcxproj +156 -0
  135. package/libusb/msvc/libusb_static_2010.vcxproj.filters +74 -0
  136. package/libusb/msvc/libusb_static_2012.vcxproj +160 -0
  137. package/libusb/msvc/libusb_static_2012.vcxproj.filters +74 -0
  138. package/libusb/msvc/libusb_static_2013.vcxproj +160 -0
  139. package/libusb/msvc/libusb_static_wince.vcproj +1185 -0
  140. package/libusb/msvc/libusb_wince.sln +246 -0
  141. package/libusb/msvc/listdevs.dsp +103 -0
  142. package/libusb/msvc/listdevs_2005.vcproj +360 -0
  143. package/libusb/msvc/listdevs_2010.vcxproj +165 -0
  144. package/libusb/msvc/listdevs_2010.vcxproj.filters +14 -0
  145. package/libusb/msvc/listdevs_2012.vcxproj +169 -0
  146. package/libusb/msvc/listdevs_2012.vcxproj.filters +14 -0
  147. package/libusb/msvc/listdevs_2013.vcxproj +169 -0
  148. package/libusb/msvc/listdevs_sources +19 -0
  149. package/libusb/msvc/listdevs_wince.vcproj +1120 -0
  150. package/libusb/msvc/missing.c +80 -0
  151. package/libusb/msvc/missing.h +32 -0
  152. package/libusb/msvc/stdint.h +256 -0
  153. package/libusb/msvc/stress_2005.vcproj +390 -0
  154. package/libusb/msvc/stress_2010.vcxproj +167 -0
  155. package/libusb/msvc/stress_2010.vcxproj.filters +25 -0
  156. package/libusb/msvc/stress_2012.vcxproj +171 -0
  157. package/libusb/msvc/stress_2012.vcxproj.filters +25 -0
  158. package/libusb/msvc/stress_2013.vcxproj +171 -0
  159. package/libusb/msvc/stress_wince.vcproj +1128 -0
  160. package/libusb/msvc/xusb.dsp +102 -0
  161. package/libusb/msvc/xusb_2005.vcproj +344 -0
  162. package/libusb/msvc/xusb_2010.vcxproj +163 -0
  163. package/libusb/msvc/xusb_2010.vcxproj.filters +14 -0
  164. package/libusb/msvc/xusb_2012.vcxproj +167 -0
  165. package/libusb/msvc/xusb_2012.vcxproj.filters +14 -0
  166. package/libusb/msvc/xusb_2013.vcxproj +167 -0
  167. package/libusb/msvc/xusb_sources +20 -0
  168. package/libusb/msvc/xusb_wince.vcproj +1120 -0
  169. package/libusb/tests/Makefile.am +6 -0
  170. package/libusb/tests/libusb_testlib.h +107 -0
  171. package/libusb/tests/stress.c +160 -0
  172. package/libusb/tests/testlib.c +281 -0
  173. package/libusb.gypi +136 -0
  174. package/libusb_config/config.h +1 -0
  175. package/package.json +69 -0
  176. package/src/device.cc +412 -0
  177. package/src/helpers.h +64 -0
  178. package/src/node_usb.cc +319 -0
  179. package/src/node_usb.h +120 -0
  180. package/src/transfer.cc +148 -0
  181. package/src/uv_async_queue.h +33 -0
  182. package/test/usb.coffee +191 -0
  183. package/usb.js +524 -0
@@ -0,0 +1,971 @@
1
+ /*
2
+ * Windows backend for libusb 1.0
3
+ * Copyright © 2009-2012 Pete Batard <pete@akeo.ie>
4
+ * With contributions from Michael Plante, Orin Eman et al.
5
+ * Parts of this code adapted from libusb-win32-v1 by Stephan Meyer
6
+ * Major code testing contribution by Xiaofan Chen
7
+ *
8
+ * This library is free software; you can redistribute it and/or
9
+ * modify it under the terms of the GNU Lesser General Public
10
+ * License as published by the Free Software Foundation; either
11
+ * version 2.1 of the License, or (at your option) any later version.
12
+ *
13
+ * This library is distributed in the hope that it will be useful,
14
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
15
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16
+ * Lesser General Public License for more details.
17
+ *
18
+ * You should have received a copy of the GNU Lesser General Public
19
+ * License along with this library; if not, write to the Free Software
20
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21
+ */
22
+
23
+ #pragma once
24
+
25
+ #include "windows_common.h"
26
+
27
+ #include "setupapi.h"
28
+ #include "winnt.h"
29
+
30
+ #ifndef PCTSTR
31
+ #ifdef UNICODE
32
+ typedef LPCWSTR PCTSTR;
33
+ #else
34
+ typedef LPCSTR PCTSTR;
35
+ #endif
36
+ #endif
37
+
38
+ #ifndef PTSTR
39
+ #ifdef UNICODE
40
+ typedef LPWSTR PTSTR;
41
+ #else
42
+ typedef LPSTR PTSTR;
43
+ #endif
44
+ #endif
45
+
46
+ #if !defined(HWND_MESSAGE)
47
+ #define HWND_MESSAGE ((HWND)(-3))
48
+ #endif
49
+
50
+ #if defined(_MSC_VER)
51
+ // disable /W4 MSVC warnings that are benign
52
+ #pragma warning(disable:4127) // conditional expression is constant
53
+ #pragma warning(disable:4100) // unreferenced formal parameter
54
+ #pragma warning(disable:4214) // bit field types other than int
55
+ #pragma warning(disable:4201) // nameless struct/union
56
+ #endif
57
+
58
+ // Missing from MSVC6 setupapi.h
59
+ #if !defined(SPDRP_ADDRESS)
60
+ #define SPDRP_ADDRESS 28
61
+ #endif
62
+ #if !defined(SPDRP_INSTALL_STATE)
63
+ #define SPDRP_INSTALL_STATE 34
64
+ #endif
65
+
66
+ // Missing from MinGW
67
+ #if !defined(FACILITY_SETUPAPI)
68
+ #define FACILITY_SETUPAPI 15
69
+ #endif
70
+
71
+ #if defined(__CYGWIN__ )
72
+ #define _stricmp stricmp
73
+ // cygwin produces a warning unless these prototypes are defined
74
+ extern int _snprintf(char *buffer, size_t count, const char *format, ...);
75
+ extern char *_strdup(const char *strSource);
76
+ // _beginthreadex is MSVCRT => unavailable for cygwin. Fallback to using CreateThread
77
+ #define _beginthreadex(a, b, c, d, e, f) CreateThread(a, b, (LPTHREAD_START_ROUTINE)c, d, e, f)
78
+ #endif
79
+
80
+ #define MAX_CTRL_BUFFER_LENGTH 4096
81
+ #define MAX_USB_HOST_CONTROLLERS 32
82
+ #define MAX_USB_DEVICES 256
83
+ #define MAX_USB_STRING_LENGTH 128
84
+ #define MAX_HID_REPORT_SIZE 1024
85
+ #define MAX_HID_DESCRIPTOR_SIZE 256
86
+ #define MAX_GUID_STRING_LENGTH 40
87
+ #define MAX_PATH_LENGTH 128
88
+ #define MAX_KEY_LENGTH 256
89
+ #define LIST_SEPARATOR ';'
90
+ #define HTAB_SIZE 1021
91
+
92
+ // Handle code for HID interface that have been claimed ("dibs")
93
+ #define INTERFACE_CLAIMED ((HANDLE)(intptr_t)0xD1B5)
94
+ // Additional return code for HID operations that completed synchronously
95
+ #define LIBUSB_COMPLETED (LIBUSB_SUCCESS + 1)
96
+
97
+ // http://msdn.microsoft.com/en-us/library/ff545978.aspx
98
+ // http://msdn.microsoft.com/en-us/library/ff545972.aspx
99
+ // http://msdn.microsoft.com/en-us/library/ff545982.aspx
100
+ #if !defined(GUID_DEVINTERFACE_USB_HOST_CONTROLLER)
101
+ const GUID GUID_DEVINTERFACE_USB_HOST_CONTROLLER = { 0x3ABF6F2D, 0x71C4, 0x462A, {0x8A, 0x92, 0x1E, 0x68, 0x61, 0xE6, 0xAF, 0x27} };
102
+ #endif
103
+ #if !defined(GUID_DEVINTERFACE_USB_DEVICE)
104
+ const GUID GUID_DEVINTERFACE_USB_DEVICE = { 0xA5DCBF10, 0x6530, 0x11D2, {0x90, 0x1F, 0x00, 0xC0, 0x4F, 0xB9, 0x51, 0xED} };
105
+ #endif
106
+ #if !defined(GUID_DEVINTERFACE_USB_HUB)
107
+ const GUID GUID_DEVINTERFACE_USB_HUB = { 0xF18A0E88, 0xC30C, 0x11D0, {0x88, 0x15, 0x00, 0xA0, 0xC9, 0x06, 0xBE, 0xD8} };
108
+ #endif
109
+ #if !defined(GUID_DEVINTERFACE_LIBUSB0_FILTER)
110
+ const GUID GUID_DEVINTERFACE_LIBUSB0_FILTER = { 0xF9F3FF14, 0xAE21, 0x48A0, {0x8A, 0x25, 0x80, 0x11, 0xA7, 0xA9, 0x31, 0xD9} };
111
+ #endif
112
+
113
+
114
+ /*
115
+ * Multiple USB API backend support
116
+ */
117
+ #define USB_API_UNSUPPORTED 0
118
+ #define USB_API_HUB 1
119
+ #define USB_API_COMPOSITE 2
120
+ #define USB_API_WINUSBX 3
121
+ #define USB_API_HID 4
122
+ #define USB_API_MAX 5
123
+ // The following is used to indicate if the HID or composite extra props have already been set.
124
+ #define USB_API_SET (1<<USB_API_MAX)
125
+
126
+ // Sub-APIs for WinUSB-like driver APIs (WinUSB, libusbK, libusb-win32 through the libusbK DLL)
127
+ // Must have the same values as the KUSB_DRVID enum from libusbk.h
128
+ #define SUB_API_NOTSET -1
129
+ #define SUB_API_LIBUSBK 0
130
+ #define SUB_API_LIBUSB0 1
131
+ #define SUB_API_WINUSB 2
132
+ #define SUB_API_MAX 3
133
+
134
+ #define WINUSBX_DRV_NAMES { "libusbK", "libusb0", "WinUSB"}
135
+
136
+ struct windows_usb_api_backend {
137
+ const uint8_t id;
138
+ const char* designation;
139
+ const char **driver_name_list; // Driver name, without .sys, e.g. "usbccgp"
140
+ const uint8_t nb_driver_names;
141
+ int (*init)(int sub_api, struct libusb_context *ctx);
142
+ int (*exit)(int sub_api);
143
+ int (*open)(int sub_api, struct libusb_device_handle *dev_handle);
144
+ void (*close)(int sub_api, struct libusb_device_handle *dev_handle);
145
+ int (*configure_endpoints)(int sub_api, struct libusb_device_handle *dev_handle, int iface);
146
+ int (*claim_interface)(int sub_api, struct libusb_device_handle *dev_handle, int iface);
147
+ int (*set_interface_altsetting)(int sub_api, struct libusb_device_handle *dev_handle, int iface, int altsetting);
148
+ int (*release_interface)(int sub_api, struct libusb_device_handle *dev_handle, int iface);
149
+ int (*clear_halt)(int sub_api, struct libusb_device_handle *dev_handle, unsigned char endpoint);
150
+ int (*reset_device)(int sub_api, struct libusb_device_handle *dev_handle);
151
+ int (*submit_bulk_transfer)(int sub_api, struct usbi_transfer *itransfer);
152
+ int (*submit_iso_transfer)(int sub_api, struct usbi_transfer *itransfer);
153
+ int (*submit_control_transfer)(int sub_api, struct usbi_transfer *itransfer);
154
+ int (*abort_control)(int sub_api, struct usbi_transfer *itransfer);
155
+ int (*abort_transfers)(int sub_api, struct usbi_transfer *itransfer);
156
+ int (*copy_transfer_data)(int sub_api, struct usbi_transfer *itransfer, uint32_t io_size);
157
+ };
158
+
159
+ extern const struct windows_usb_api_backend usb_api_backend[USB_API_MAX];
160
+
161
+ #define PRINT_UNSUPPORTED_API(fname) \
162
+ usbi_dbg("unsupported API call for '" \
163
+ #fname "' (unrecognized device driver)"); \
164
+ return LIBUSB_ERROR_NOT_SUPPORTED;
165
+
166
+ /*
167
+ * private structures definition
168
+ * with inline pseudo constructors/destructors
169
+ */
170
+
171
+ // TODO (v2+): move hid desc to libusb.h?
172
+ struct libusb_hid_descriptor {
173
+ uint8_t bLength;
174
+ uint8_t bDescriptorType;
175
+ uint16_t bcdHID;
176
+ uint8_t bCountryCode;
177
+ uint8_t bNumDescriptors;
178
+ uint8_t bClassDescriptorType;
179
+ uint16_t wClassDescriptorLength;
180
+ };
181
+ #define LIBUSB_DT_HID_SIZE 9
182
+ #define HID_MAX_CONFIG_DESC_SIZE (LIBUSB_DT_CONFIG_SIZE + LIBUSB_DT_INTERFACE_SIZE \
183
+ + LIBUSB_DT_HID_SIZE + 2 * LIBUSB_DT_ENDPOINT_SIZE)
184
+ #define HID_MAX_REPORT_SIZE 1024
185
+ #define HID_IN_EP 0x81
186
+ #define HID_OUT_EP 0x02
187
+ #define LIBUSB_REQ_RECIPIENT(request_type) ((request_type) & 0x1F)
188
+ #define LIBUSB_REQ_TYPE(request_type) ((request_type) & (0x03 << 5))
189
+ #define LIBUSB_REQ_IN(request_type) ((request_type) & LIBUSB_ENDPOINT_IN)
190
+ #define LIBUSB_REQ_OUT(request_type) (!LIBUSB_REQ_IN(request_type))
191
+
192
+ // The following are used for HID reports IOCTLs
193
+ #define HID_CTL_CODE(id) \
194
+ CTL_CODE (FILE_DEVICE_KEYBOARD, (id), METHOD_NEITHER, FILE_ANY_ACCESS)
195
+ #define HID_BUFFER_CTL_CODE(id) \
196
+ CTL_CODE (FILE_DEVICE_KEYBOARD, (id), METHOD_BUFFERED, FILE_ANY_ACCESS)
197
+ #define HID_IN_CTL_CODE(id) \
198
+ CTL_CODE (FILE_DEVICE_KEYBOARD, (id), METHOD_IN_DIRECT, FILE_ANY_ACCESS)
199
+ #define HID_OUT_CTL_CODE(id) \
200
+ CTL_CODE (FILE_DEVICE_KEYBOARD, (id), METHOD_OUT_DIRECT, FILE_ANY_ACCESS)
201
+
202
+ #define IOCTL_HID_GET_FEATURE HID_OUT_CTL_CODE(100)
203
+ #define IOCTL_HID_GET_INPUT_REPORT HID_OUT_CTL_CODE(104)
204
+ #define IOCTL_HID_SET_FEATURE HID_IN_CTL_CODE(100)
205
+ #define IOCTL_HID_SET_OUTPUT_REPORT HID_IN_CTL_CODE(101)
206
+
207
+ enum libusb_hid_request_type {
208
+ HID_REQ_GET_REPORT = 0x01,
209
+ HID_REQ_GET_IDLE = 0x02,
210
+ HID_REQ_GET_PROTOCOL = 0x03,
211
+ HID_REQ_SET_REPORT = 0x09,
212
+ HID_REQ_SET_IDLE = 0x0A,
213
+ HID_REQ_SET_PROTOCOL = 0x0B
214
+ };
215
+
216
+ enum libusb_hid_report_type {
217
+ HID_REPORT_TYPE_INPUT = 0x01,
218
+ HID_REPORT_TYPE_OUTPUT = 0x02,
219
+ HID_REPORT_TYPE_FEATURE = 0x03
220
+ };
221
+
222
+ struct hid_device_priv {
223
+ uint16_t vid;
224
+ uint16_t pid;
225
+ uint8_t config;
226
+ uint8_t nb_interfaces;
227
+ bool uses_report_ids[3]; // input, ouptput, feature
228
+ uint16_t input_report_size;
229
+ uint16_t output_report_size;
230
+ uint16_t feature_report_size;
231
+ WCHAR string[3][MAX_USB_STRING_LENGTH];
232
+ uint8_t string_index[3]; // man, prod, ser
233
+ };
234
+
235
+ typedef struct libusb_device_descriptor USB_DEVICE_DESCRIPTOR, *PUSB_DEVICE_DESCRIPTOR;
236
+ struct windows_device_priv {
237
+ DWORD devinst; // device instance
238
+ char *device_id; // device instance id string
239
+ uint8_t depth; // distance to HCD
240
+ uint8_t port; // port number on the hub
241
+ uint8_t active_config;
242
+ struct windows_usb_api_backend const *apib;
243
+ char *path; // device interface path
244
+ int sub_api; // for WinUSB-like APIs
245
+ struct {
246
+ char *path; // each interface needs a device interface path,
247
+ struct windows_usb_api_backend const *apib; // an API backend (multiple drivers support),
248
+ int sub_api;
249
+ int8_t nb_endpoints; // and a set of endpoint addresses (USB_MAXENDPOINTS)
250
+ uint8_t *endpoint;
251
+ bool restricted_functionality; // indicates if the interface functionality is restricted
252
+ // by Windows (eg. HID keyboards or mice cannot do R/W)
253
+ } usb_interface[USB_MAXINTERFACES];
254
+ struct hid_device_priv *hid;
255
+ USB_DEVICE_DESCRIPTOR dev_descriptor;
256
+ unsigned char **config_descriptor; // list of pointers to the cached config descriptors
257
+ };
258
+
259
+ static inline struct windows_device_priv *_device_priv(struct libusb_device *dev) {
260
+ if (dev == NULL) return NULL;
261
+ return (struct windows_device_priv *)dev->os_priv;
262
+ }
263
+
264
+ static inline void windows_device_priv_init(libusb_device* dev);
265
+ static inline void windows_device_priv_release(libusb_device* dev);
266
+
267
+ struct interface_handle_t {
268
+ HANDLE dev_handle; // WinUSB needs an extra handle for the file
269
+ HANDLE api_handle; // used by the API to communicate with the device
270
+ };
271
+
272
+ struct windows_device_handle_priv {
273
+ int active_interface;
274
+ struct interface_handle_t interface_handle[USB_MAXINTERFACES];
275
+ int autoclaim_count[USB_MAXINTERFACES]; // For auto-release
276
+ };
277
+
278
+ static inline struct windows_device_handle_priv *_device_handle_priv(
279
+ struct libusb_device_handle *handle)
280
+ {
281
+ return (struct windows_device_handle_priv *) handle->os_priv;
282
+ }
283
+
284
+ // used for async polling functions
285
+ struct windows_transfer_priv {
286
+ struct winfd pollable_fd;
287
+ uint8_t interface_number;
288
+ uint8_t *hid_buffer; // 1 byte extended data buffer, required for HID
289
+ uint8_t *hid_dest; // transfer buffer destination, required for HID
290
+ size_t hid_expected_size;
291
+ };
292
+
293
+ // used to match a device driver (including filter drivers) against a supported API
294
+ struct driver_lookup {
295
+ char list[MAX_KEY_LENGTH+1];// REG_MULTI_SZ list of services (driver) names
296
+ const DWORD reg_prop; // SPDRP registry key to use to retreive list
297
+ const char* designation; // internal designation (for debug output)
298
+ };
299
+
300
+ /* OLE32 dependency */
301
+ DLL_DECLARE_PREFIXED(WINAPI, HRESULT, p, CLSIDFromString, (LPCOLESTR, LPCLSID));
302
+
303
+ /* This call is only available from XP SP2 */
304
+ DLL_DECLARE_PREFIXED(WINAPI, BOOL, p, IsWow64Process, (HANDLE, PBOOL));
305
+
306
+ /* SetupAPI dependencies */
307
+ DLL_DECLARE_PREFIXED(WINAPI, HDEVINFO, p, SetupDiGetClassDevsA, (const GUID*, PCSTR, HWND, DWORD));
308
+ DLL_DECLARE_PREFIXED(WINAPI, HDEVINFO, p, SetupDiGetClassDevsExA, (const GUID*, PCSTR, HWND, DWORD, HDEVINFO, PCTSTR, PVOID));
309
+ DLL_DECLARE_PREFIXED(WINAPI, BOOL, p, SetupDiEnumDeviceInfo, (HDEVINFO, DWORD, PSP_DEVINFO_DATA));
310
+ DLL_DECLARE_PREFIXED(WINAPI, BOOL, p, SetupDiEnumDeviceInterfaces, (HDEVINFO, PSP_DEVINFO_DATA,
311
+ const GUID*, DWORD, PSP_DEVICE_INTERFACE_DATA));
312
+ DLL_DECLARE_PREFIXED(WINAPI, BOOL, p, SetupDiGetDeviceInterfaceDetailA, (HDEVINFO, PSP_DEVICE_INTERFACE_DATA,
313
+ PSP_DEVICE_INTERFACE_DETAIL_DATA_A, DWORD, PDWORD, PSP_DEVINFO_DATA));
314
+ DLL_DECLARE_PREFIXED(WINAPI, BOOL, p, SetupDiDestroyDeviceInfoList, (HDEVINFO));
315
+ DLL_DECLARE_PREFIXED(WINAPI, HKEY, p, SetupDiOpenDevRegKey, (HDEVINFO, PSP_DEVINFO_DATA, DWORD, DWORD, DWORD, REGSAM));
316
+ DLL_DECLARE_PREFIXED(WINAPI, BOOL, p, SetupDiGetDeviceRegistryPropertyA, (HDEVINFO,
317
+ PSP_DEVINFO_DATA, DWORD, PDWORD, PBYTE, DWORD, PDWORD));
318
+ DLL_DECLARE_PREFIXED(WINAPI, HKEY, p, SetupDiOpenDeviceInterfaceRegKey, (HDEVINFO, PSP_DEVICE_INTERFACE_DATA, DWORD, DWORD));
319
+ DLL_DECLARE_PREFIXED(WINAPI, LONG, p, RegQueryValueExW, (HKEY, LPCWSTR, LPDWORD, LPDWORD, LPBYTE, LPDWORD));
320
+ DLL_DECLARE_PREFIXED(WINAPI, LONG, p, RegCloseKey, (HKEY));
321
+
322
+ /* User32 dependencies */
323
+ DLL_DECLARE_PREFIXED(WINAPI, ATOM, p, RegisterClassExA, (const WNDCLASSEXA*));
324
+ DLL_DECLARE_PREFIXED(WINAPI, HDEVNOTIFY, p, RegisterDeviceNotificationA, (HANDLE, LPVOID, DWORD));
325
+ DLL_DECLARE_PREFIXED(WINAPI, BOOL, p, UnregisterDeviceNotification, (HDEVNOTIFY));
326
+ DLL_DECLARE_PREFIXED(WINAPI, BOOL, p, UnregisterClassA, (LPCSTR, HINSTANCE));
327
+
328
+ /*
329
+ * Windows DDK API definitions. Most of it copied from MinGW's includes
330
+ */
331
+ typedef DWORD DEVNODE, DEVINST;
332
+ typedef DEVNODE *PDEVNODE, *PDEVINST;
333
+ typedef DWORD RETURN_TYPE;
334
+ typedef RETURN_TYPE CONFIGRET;
335
+
336
+ #define CR_SUCCESS 0x00000000
337
+ #define CR_NO_SUCH_DEVNODE 0x0000000D
338
+
339
+ #define DEVICE_NOTIFY_WINDOW_HANDLE 0x00000000
340
+ #define DEVICE_NOTIFY_ALL_INTERFACE_CLASSES 0x00000004
341
+
342
+ #define DBT_DEVICEARRIVAL 0x8000
343
+ #define DBT_DEVICEREMOVECOMPLETE 0x8004
344
+ #define DBT_DEVTYP_DEVICEINTERFACE 0x00000005
345
+
346
+ #define USB_DEVICE_DESCRIPTOR_TYPE LIBUSB_DT_DEVICE
347
+ #define USB_CONFIGURATION_DESCRIPTOR_TYPE LIBUSB_DT_CONFIG
348
+ #define USB_STRING_DESCRIPTOR_TYPE LIBUSB_DT_STRING
349
+ #define USB_INTERFACE_DESCRIPTOR_TYPE LIBUSB_DT_INTERFACE
350
+ #define USB_ENDPOINT_DESCRIPTOR_TYPE LIBUSB_DT_ENDPOINT
351
+
352
+ #define USB_REQUEST_GET_STATUS LIBUSB_REQUEST_GET_STATUS
353
+ #define USB_REQUEST_CLEAR_FEATURE LIBUSB_REQUEST_CLEAR_FEATURE
354
+ #define USB_REQUEST_SET_FEATURE LIBUSB_REQUEST_SET_FEATURE
355
+ #define USB_REQUEST_SET_ADDRESS LIBUSB_REQUEST_SET_ADDRESS
356
+ #define USB_REQUEST_GET_DESCRIPTOR LIBUSB_REQUEST_GET_DESCRIPTOR
357
+ #define USB_REQUEST_SET_DESCRIPTOR LIBUSB_REQUEST_SET_DESCRIPTOR
358
+ #define USB_REQUEST_GET_CONFIGURATION LIBUSB_REQUEST_GET_CONFIGURATION
359
+ #define USB_REQUEST_SET_CONFIGURATION LIBUSB_REQUEST_SET_CONFIGURATION
360
+ #define USB_REQUEST_GET_INTERFACE LIBUSB_REQUEST_GET_INTERFACE
361
+ #define USB_REQUEST_SET_INTERFACE LIBUSB_REQUEST_SET_INTERFACE
362
+ #define USB_REQUEST_SYNC_FRAME LIBUSB_REQUEST_SYNCH_FRAME
363
+
364
+ #define USB_GET_NODE_INFORMATION 258
365
+ #define USB_GET_DESCRIPTOR_FROM_NODE_CONNECTION 260
366
+ #define USB_GET_NODE_CONNECTION_NAME 261
367
+ #define USB_GET_HUB_CAPABILITIES 271
368
+ #if !defined(USB_GET_NODE_CONNECTION_INFORMATION_EX)
369
+ #define USB_GET_NODE_CONNECTION_INFORMATION_EX 274
370
+ #endif
371
+ #if !defined(USB_GET_HUB_CAPABILITIES_EX)
372
+ #define USB_GET_HUB_CAPABILITIES_EX 276
373
+ #endif
374
+ #if !defined(USB_GET_NODE_CONNECTION_INFORMATION_EX_V2)
375
+ #define USB_GET_NODE_CONNECTION_INFORMATION_EX_V2 279
376
+ #endif
377
+
378
+ #ifndef METHOD_BUFFERED
379
+ #define METHOD_BUFFERED 0
380
+ #endif
381
+ #ifndef FILE_ANY_ACCESS
382
+ #define FILE_ANY_ACCESS 0x00000000
383
+ #endif
384
+ #ifndef FILE_DEVICE_UNKNOWN
385
+ #define FILE_DEVICE_UNKNOWN 0x00000022
386
+ #endif
387
+ #ifndef FILE_DEVICE_USB
388
+ #define FILE_DEVICE_USB FILE_DEVICE_UNKNOWN
389
+ #endif
390
+
391
+ #ifndef CTL_CODE
392
+ #define CTL_CODE(DeviceType, Function, Method, Access)( \
393
+ ((DeviceType) << 16) | ((Access) << 14) | ((Function) << 2) | (Method))
394
+ #endif
395
+
396
+ typedef enum USB_CONNECTION_STATUS {
397
+ NoDeviceConnected,
398
+ DeviceConnected,
399
+ DeviceFailedEnumeration,
400
+ DeviceGeneralFailure,
401
+ DeviceCausedOvercurrent,
402
+ DeviceNotEnoughPower,
403
+ DeviceNotEnoughBandwidth,
404
+ DeviceHubNestedTooDeeply,
405
+ DeviceInLegacyHub
406
+ } USB_CONNECTION_STATUS, *PUSB_CONNECTION_STATUS;
407
+
408
+ typedef enum USB_HUB_NODE {
409
+ UsbHub,
410
+ UsbMIParent
411
+ } USB_HUB_NODE;
412
+
413
+ /* Cfgmgr32.dll interface */
414
+ DLL_DECLARE(WINAPI, CONFIGRET, CM_Get_Parent, (PDEVINST, DEVINST, ULONG));
415
+ DLL_DECLARE(WINAPI, CONFIGRET, CM_Get_Child, (PDEVINST, DEVINST, ULONG));
416
+ DLL_DECLARE(WINAPI, CONFIGRET, CM_Get_Sibling, (PDEVINST, DEVINST, ULONG));
417
+ DLL_DECLARE(WINAPI, CONFIGRET, CM_Get_Device_IDA, (DEVINST, PCHAR, ULONG, ULONG));
418
+ DLL_DECLARE(WINAPI, CONFIGRET, CM_Get_Device_ID_Size, (PULONG, DEVINST, ULONG));
419
+
420
+ #define IOCTL_USB_GET_HUB_CAPABILITIES_EX \
421
+ CTL_CODE( FILE_DEVICE_USB, USB_GET_HUB_CAPABILITIES_EX, METHOD_BUFFERED, FILE_ANY_ACCESS)
422
+
423
+ #define IOCTL_USB_GET_HUB_CAPABILITIES \
424
+ CTL_CODE(FILE_DEVICE_USB, USB_GET_HUB_CAPABILITIES, METHOD_BUFFERED, FILE_ANY_ACCESS)
425
+
426
+ #define IOCTL_USB_GET_DESCRIPTOR_FROM_NODE_CONNECTION \
427
+ CTL_CODE(FILE_DEVICE_USB, USB_GET_DESCRIPTOR_FROM_NODE_CONNECTION, METHOD_BUFFERED, FILE_ANY_ACCESS)
428
+
429
+ #define IOCTL_USB_GET_ROOT_HUB_NAME \
430
+ CTL_CODE(FILE_DEVICE_USB, HCD_GET_ROOT_HUB_NAME, METHOD_BUFFERED, FILE_ANY_ACCESS)
431
+
432
+ #define IOCTL_USB_GET_NODE_INFORMATION \
433
+ CTL_CODE(FILE_DEVICE_USB, USB_GET_NODE_INFORMATION, METHOD_BUFFERED, FILE_ANY_ACCESS)
434
+
435
+ #define IOCTL_USB_GET_NODE_CONNECTION_INFORMATION_EX \
436
+ CTL_CODE(FILE_DEVICE_USB, USB_GET_NODE_CONNECTION_INFORMATION_EX, METHOD_BUFFERED, FILE_ANY_ACCESS)
437
+
438
+ #define IOCTL_USB_GET_NODE_CONNECTION_INFORMATION_EX_V2 \
439
+ CTL_CODE(FILE_DEVICE_USB, USB_GET_NODE_CONNECTION_INFORMATION_EX_V2, METHOD_BUFFERED, FILE_ANY_ACCESS)
440
+
441
+ #define IOCTL_USB_GET_NODE_CONNECTION_ATTRIBUTES \
442
+ CTL_CODE(FILE_DEVICE_USB, USB_GET_NODE_CONNECTION_ATTRIBUTES, METHOD_BUFFERED, FILE_ANY_ACCESS)
443
+
444
+ #define IOCTL_USB_GET_NODE_CONNECTION_NAME \
445
+ CTL_CODE(FILE_DEVICE_USB, USB_GET_NODE_CONNECTION_NAME, METHOD_BUFFERED, FILE_ANY_ACCESS)
446
+
447
+ // Most of the structures below need to be packed
448
+ #pragma pack(push, 1)
449
+
450
+ typedef struct USB_INTERFACE_DESCRIPTOR {
451
+ UCHAR bLength;
452
+ UCHAR bDescriptorType;
453
+ UCHAR bInterfaceNumber;
454
+ UCHAR bAlternateSetting;
455
+ UCHAR bNumEndpoints;
456
+ UCHAR bInterfaceClass;
457
+ UCHAR bInterfaceSubClass;
458
+ UCHAR bInterfaceProtocol;
459
+ UCHAR iInterface;
460
+ } USB_INTERFACE_DESCRIPTOR, *PUSB_INTERFACE_DESCRIPTOR;
461
+
462
+ typedef struct USB_CONFIGURATION_DESCRIPTOR {
463
+ UCHAR bLength;
464
+ UCHAR bDescriptorType;
465
+ USHORT wTotalLength;
466
+ UCHAR bNumInterfaces;
467
+ UCHAR bConfigurationValue;
468
+ UCHAR iConfiguration;
469
+ UCHAR bmAttributes;
470
+ UCHAR MaxPower;
471
+ } USB_CONFIGURATION_DESCRIPTOR, *PUSB_CONFIGURATION_DESCRIPTOR;
472
+
473
+ typedef struct USB_CONFIGURATION_DESCRIPTOR_SHORT {
474
+ struct {
475
+ ULONG ConnectionIndex;
476
+ struct {
477
+ UCHAR bmRequest;
478
+ UCHAR bRequest;
479
+ USHORT wValue;
480
+ USHORT wIndex;
481
+ USHORT wLength;
482
+ } SetupPacket;
483
+ } req;
484
+ USB_CONFIGURATION_DESCRIPTOR data;
485
+ } USB_CONFIGURATION_DESCRIPTOR_SHORT;
486
+
487
+ typedef struct USB_ENDPOINT_DESCRIPTOR {
488
+ UCHAR bLength;
489
+ UCHAR bDescriptorType;
490
+ UCHAR bEndpointAddress;
491
+ UCHAR bmAttributes;
492
+ USHORT wMaxPacketSize;
493
+ UCHAR bInterval;
494
+ } USB_ENDPOINT_DESCRIPTOR, *PUSB_ENDPOINT_DESCRIPTOR;
495
+
496
+ typedef struct USB_DESCRIPTOR_REQUEST {
497
+ ULONG ConnectionIndex;
498
+ struct {
499
+ UCHAR bmRequest;
500
+ UCHAR bRequest;
501
+ USHORT wValue;
502
+ USHORT wIndex;
503
+ USHORT wLength;
504
+ } SetupPacket;
505
+ // UCHAR Data[0];
506
+ } USB_DESCRIPTOR_REQUEST, *PUSB_DESCRIPTOR_REQUEST;
507
+
508
+ typedef struct USB_HUB_DESCRIPTOR {
509
+ UCHAR bDescriptorLength;
510
+ UCHAR bDescriptorType;
511
+ UCHAR bNumberOfPorts;
512
+ USHORT wHubCharacteristics;
513
+ UCHAR bPowerOnToPowerGood;
514
+ UCHAR bHubControlCurrent;
515
+ UCHAR bRemoveAndPowerMask[64];
516
+ } USB_HUB_DESCRIPTOR, *PUSB_HUB_DESCRIPTOR;
517
+
518
+ typedef struct USB_ROOT_HUB_NAME {
519
+ ULONG ActualLength;
520
+ WCHAR RootHubName[1];
521
+ } USB_ROOT_HUB_NAME, *PUSB_ROOT_HUB_NAME;
522
+
523
+ typedef struct USB_ROOT_HUB_NAME_FIXED {
524
+ ULONG ActualLength;
525
+ WCHAR RootHubName[MAX_PATH_LENGTH];
526
+ } USB_ROOT_HUB_NAME_FIXED;
527
+
528
+ typedef struct USB_NODE_CONNECTION_NAME {
529
+ ULONG ConnectionIndex;
530
+ ULONG ActualLength;
531
+ WCHAR NodeName[1];
532
+ } USB_NODE_CONNECTION_NAME, *PUSB_NODE_CONNECTION_NAME;
533
+
534
+ typedef struct USB_NODE_CONNECTION_NAME_FIXED {
535
+ ULONG ConnectionIndex;
536
+ ULONG ActualLength;
537
+ WCHAR NodeName[MAX_PATH_LENGTH];
538
+ } USB_NODE_CONNECTION_NAME_FIXED;
539
+
540
+ typedef struct USB_HUB_NAME_FIXED {
541
+ union {
542
+ USB_ROOT_HUB_NAME_FIXED root;
543
+ USB_NODE_CONNECTION_NAME_FIXED node;
544
+ } u;
545
+ } USB_HUB_NAME_FIXED;
546
+
547
+ typedef struct USB_HUB_INFORMATION {
548
+ USB_HUB_DESCRIPTOR HubDescriptor;
549
+ BOOLEAN HubIsBusPowered;
550
+ } USB_HUB_INFORMATION, *PUSB_HUB_INFORMATION;
551
+
552
+ typedef struct USB_MI_PARENT_INFORMATION {
553
+ ULONG NumberOfInterfaces;
554
+ } USB_MI_PARENT_INFORMATION, *PUSB_MI_PARENT_INFORMATION;
555
+
556
+ typedef struct USB_NODE_INFORMATION {
557
+ USB_HUB_NODE NodeType;
558
+ union {
559
+ USB_HUB_INFORMATION HubInformation;
560
+ USB_MI_PARENT_INFORMATION MiParentInformation;
561
+ } u;
562
+ } USB_NODE_INFORMATION, *PUSB_NODE_INFORMATION;
563
+
564
+ typedef struct USB_PIPE_INFO {
565
+ USB_ENDPOINT_DESCRIPTOR EndpointDescriptor;
566
+ ULONG ScheduleOffset;
567
+ } USB_PIPE_INFO, *PUSB_PIPE_INFO;
568
+
569
+ typedef struct USB_NODE_CONNECTION_INFORMATION_EX {
570
+ ULONG ConnectionIndex;
571
+ USB_DEVICE_DESCRIPTOR DeviceDescriptor;
572
+ UCHAR CurrentConfigurationValue;
573
+ UCHAR Speed;
574
+ BOOLEAN DeviceIsHub;
575
+ USHORT DeviceAddress;
576
+ ULONG NumberOfOpenPipes;
577
+ USB_CONNECTION_STATUS ConnectionStatus;
578
+ // USB_PIPE_INFO PipeList[0];
579
+ } USB_NODE_CONNECTION_INFORMATION_EX, *PUSB_NODE_CONNECTION_INFORMATION_EX;
580
+
581
+ typedef union _USB_PROTOCOLS {
582
+ ULONG ul;
583
+ struct {
584
+ ULONG Usb110:1;
585
+ ULONG Usb200:1;
586
+ ULONG Usb300:1;
587
+ ULONG ReservedMBZ:29;
588
+ };
589
+ } USB_PROTOCOLS, *PUSB_PROTOCOLS;
590
+
591
+ typedef union _USB_NODE_CONNECTION_INFORMATION_EX_V2_FLAGS {
592
+ ULONG ul;
593
+ struct {
594
+ ULONG DeviceIsOperatingAtSuperSpeedOrHigher:1;
595
+ ULONG DeviceIsSuperSpeedCapableOrHigher:1;
596
+ ULONG ReservedMBZ:30;
597
+ };
598
+ } USB_NODE_CONNECTION_INFORMATION_EX_V2_FLAGS, *PUSB_NODE_CONNECTION_INFORMATION_EX_V2_FLAGS;
599
+
600
+ typedef struct _USB_NODE_CONNECTION_INFORMATION_EX_V2 {
601
+ ULONG ConnectionIndex;
602
+ ULONG Length;
603
+ USB_PROTOCOLS SupportedUsbProtocols;
604
+ USB_NODE_CONNECTION_INFORMATION_EX_V2_FLAGS Flags;
605
+ } USB_NODE_CONNECTION_INFORMATION_EX_V2, *PUSB_NODE_CONNECTION_INFORMATION_EX_V2;
606
+
607
+ typedef struct USB_HUB_CAP_FLAGS {
608
+ ULONG HubIsHighSpeedCapable:1;
609
+ ULONG HubIsHighSpeed:1;
610
+ ULONG HubIsMultiTtCapable:1;
611
+ ULONG HubIsMultiTt:1;
612
+ ULONG HubIsRoot:1;
613
+ ULONG HubIsArmedWakeOnConnect:1;
614
+ ULONG ReservedMBZ:26;
615
+ } USB_HUB_CAP_FLAGS, *PUSB_HUB_CAP_FLAGS;
616
+
617
+ typedef struct USB_HUB_CAPABILITIES {
618
+ ULONG HubIs2xCapable : 1;
619
+ } USB_HUB_CAPABILITIES, *PUSB_HUB_CAPABILITIES;
620
+
621
+ typedef struct USB_HUB_CAPABILITIES_EX {
622
+ USB_HUB_CAP_FLAGS CapabilityFlags;
623
+ } USB_HUB_CAPABILITIES_EX, *PUSB_HUB_CAPABILITIES_EX;
624
+
625
+ #pragma pack(pop)
626
+
627
+ typedef struct DEV_BROADCAST_DEVICEINTERFACE_A {
628
+ DWORD dbcc_size;
629
+ DWORD dbcc_devicetype;
630
+ DWORD dbcc_reserved;
631
+ GUID dbcc_classguid;
632
+ char dbcc_name[1];
633
+ } DEV_BROADCAST_DEVICEINTERFACE_A, *PDEV_BROADCAST_DEVICEINTERFACE_A;
634
+
635
+ /* winusb.dll interface */
636
+
637
+ #define SHORT_PACKET_TERMINATE 0x01
638
+ #define AUTO_CLEAR_STALL 0x02
639
+ #define PIPE_TRANSFER_TIMEOUT 0x03
640
+ #define IGNORE_SHORT_PACKETS 0x04
641
+ #define ALLOW_PARTIAL_READS 0x05
642
+ #define AUTO_FLUSH 0x06
643
+ #define RAW_IO 0x07
644
+ #define MAXIMUM_TRANSFER_SIZE 0x08
645
+ #define AUTO_SUSPEND 0x81
646
+ #define SUSPEND_DELAY 0x83
647
+ #define DEVICE_SPEED 0x01
648
+ #define LowSpeed 0x01
649
+ #define FullSpeed 0x02
650
+ #define HighSpeed 0x03
651
+
652
+ typedef enum USBD_PIPE_TYPE {
653
+ UsbdPipeTypeControl,
654
+ UsbdPipeTypeIsochronous,
655
+ UsbdPipeTypeBulk,
656
+ UsbdPipeTypeInterrupt
657
+ } USBD_PIPE_TYPE;
658
+
659
+ typedef struct {
660
+ USBD_PIPE_TYPE PipeType;
661
+ UCHAR PipeId;
662
+ USHORT MaximumPacketSize;
663
+ UCHAR Interval;
664
+ } WINUSB_PIPE_INFORMATION, *PWINUSB_PIPE_INFORMATION;
665
+
666
+ #pragma pack(1)
667
+ typedef struct {
668
+ UCHAR request_type;
669
+ UCHAR request;
670
+ USHORT value;
671
+ USHORT index;
672
+ USHORT length;
673
+ } WINUSB_SETUP_PACKET, *PWINUSB_SETUP_PACKET;
674
+ #pragma pack()
675
+
676
+ typedef void *WINUSB_INTERFACE_HANDLE, *PWINUSB_INTERFACE_HANDLE;
677
+
678
+ typedef BOOL (WINAPI *WinUsb_AbortPipe_t)(
679
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
680
+ UCHAR PipeID
681
+ );
682
+ typedef BOOL (WINAPI *WinUsb_ControlTransfer_t)(
683
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
684
+ WINUSB_SETUP_PACKET SetupPacket,
685
+ PUCHAR Buffer,
686
+ ULONG BufferLength,
687
+ PULONG LengthTransferred,
688
+ LPOVERLAPPED Overlapped
689
+ );
690
+ typedef BOOL (WINAPI *WinUsb_FlushPipe_t)(
691
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
692
+ UCHAR PipeID
693
+ );
694
+ typedef BOOL (WINAPI *WinUsb_Free_t)(
695
+ WINUSB_INTERFACE_HANDLE InterfaceHandle
696
+ );
697
+ typedef BOOL (WINAPI *WinUsb_GetAssociatedInterface_t)(
698
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
699
+ UCHAR AssociatedInterfaceIndex,
700
+ PWINUSB_INTERFACE_HANDLE AssociatedInterfaceHandle
701
+ );
702
+ typedef BOOL (WINAPI *WinUsb_GetCurrentAlternateSetting_t)(
703
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
704
+ PUCHAR AlternateSetting
705
+ );
706
+ typedef BOOL (WINAPI *WinUsb_GetDescriptor_t)(
707
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
708
+ UCHAR DescriptorType,
709
+ UCHAR Index,
710
+ USHORT LanguageID,
711
+ PUCHAR Buffer,
712
+ ULONG BufferLength,
713
+ PULONG LengthTransferred
714
+ );
715
+ typedef BOOL (WINAPI *WinUsb_GetOverlappedResult_t)(
716
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
717
+ LPOVERLAPPED lpOverlapped,
718
+ LPDWORD lpNumberOfBytesTransferred,
719
+ BOOL bWait
720
+ );
721
+ typedef BOOL (WINAPI *WinUsb_GetPipePolicy_t)(
722
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
723
+ UCHAR PipeID,
724
+ ULONG PolicyType,
725
+ PULONG ValueLength,
726
+ PVOID Value
727
+ );
728
+ typedef BOOL (WINAPI *WinUsb_GetPowerPolicy_t)(
729
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
730
+ ULONG PolicyType,
731
+ PULONG ValueLength,
732
+ PVOID Value
733
+ );
734
+ typedef BOOL (WINAPI *WinUsb_Initialize_t)(
735
+ HANDLE DeviceHandle,
736
+ PWINUSB_INTERFACE_HANDLE InterfaceHandle
737
+ );
738
+ typedef BOOL (WINAPI *WinUsb_QueryDeviceInformation_t)(
739
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
740
+ ULONG InformationType,
741
+ PULONG BufferLength,
742
+ PVOID Buffer
743
+ );
744
+ typedef BOOL (WINAPI *WinUsb_QueryInterfaceSettings_t)(
745
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
746
+ UCHAR AlternateSettingNumber,
747
+ PUSB_INTERFACE_DESCRIPTOR UsbAltInterfaceDescriptor
748
+ );
749
+ typedef BOOL (WINAPI *WinUsb_QueryPipe_t)(
750
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
751
+ UCHAR AlternateInterfaceNumber,
752
+ UCHAR PipeIndex,
753
+ PWINUSB_PIPE_INFORMATION PipeInformation
754
+ );
755
+ typedef BOOL (WINAPI *WinUsb_ReadPipe_t)(
756
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
757
+ UCHAR PipeID,
758
+ PUCHAR Buffer,
759
+ ULONG BufferLength,
760
+ PULONG LengthTransferred,
761
+ LPOVERLAPPED Overlapped
762
+ );
763
+ typedef BOOL (WINAPI *WinUsb_ResetPipe_t)(
764
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
765
+ UCHAR PipeID
766
+ );
767
+ typedef BOOL (WINAPI *WinUsb_SetCurrentAlternateSetting_t)(
768
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
769
+ UCHAR AlternateSetting
770
+ );
771
+ typedef BOOL (WINAPI *WinUsb_SetPipePolicy_t)(
772
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
773
+ UCHAR PipeID,
774
+ ULONG PolicyType,
775
+ ULONG ValueLength,
776
+ PVOID Value
777
+ );
778
+ typedef BOOL (WINAPI *WinUsb_SetPowerPolicy_t)(
779
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
780
+ ULONG PolicyType,
781
+ ULONG ValueLength,
782
+ PVOID Value
783
+ );
784
+ typedef BOOL (WINAPI *WinUsb_WritePipe_t)(
785
+ WINUSB_INTERFACE_HANDLE InterfaceHandle,
786
+ UCHAR PipeID,
787
+ PUCHAR Buffer,
788
+ ULONG BufferLength,
789
+ PULONG LengthTransferred,
790
+ LPOVERLAPPED Overlapped
791
+ );
792
+ typedef BOOL (WINAPI *WinUsb_ResetDevice_t)(
793
+ WINUSB_INTERFACE_HANDLE InterfaceHandle
794
+ );
795
+
796
+ /* /!\ These must match the ones from the official libusbk.h */
797
+ typedef enum _KUSB_FNID
798
+ {
799
+ KUSB_FNID_Init,
800
+ KUSB_FNID_Free,
801
+ KUSB_FNID_ClaimInterface,
802
+ KUSB_FNID_ReleaseInterface,
803
+ KUSB_FNID_SetAltInterface,
804
+ KUSB_FNID_GetAltInterface,
805
+ KUSB_FNID_GetDescriptor,
806
+ KUSB_FNID_ControlTransfer,
807
+ KUSB_FNID_SetPowerPolicy,
808
+ KUSB_FNID_GetPowerPolicy,
809
+ KUSB_FNID_SetConfiguration,
810
+ KUSB_FNID_GetConfiguration,
811
+ KUSB_FNID_ResetDevice,
812
+ KUSB_FNID_Initialize,
813
+ KUSB_FNID_SelectInterface,
814
+ KUSB_FNID_GetAssociatedInterface,
815
+ KUSB_FNID_Clone,
816
+ KUSB_FNID_QueryInterfaceSettings,
817
+ KUSB_FNID_QueryDeviceInformation,
818
+ KUSB_FNID_SetCurrentAlternateSetting,
819
+ KUSB_FNID_GetCurrentAlternateSetting,
820
+ KUSB_FNID_QueryPipe,
821
+ KUSB_FNID_SetPipePolicy,
822
+ KUSB_FNID_GetPipePolicy,
823
+ KUSB_FNID_ReadPipe,
824
+ KUSB_FNID_WritePipe,
825
+ KUSB_FNID_ResetPipe,
826
+ KUSB_FNID_AbortPipe,
827
+ KUSB_FNID_FlushPipe,
828
+ KUSB_FNID_IsoReadPipe,
829
+ KUSB_FNID_IsoWritePipe,
830
+ KUSB_FNID_GetCurrentFrameNumber,
831
+ KUSB_FNID_GetOverlappedResult,
832
+ KUSB_FNID_GetProperty,
833
+ KUSB_FNID_COUNT,
834
+ } KUSB_FNID;
835
+
836
+ typedef struct _KLIB_VERSION {
837
+ INT Major;
838
+ INT Minor;
839
+ INT Micro;
840
+ INT Nano;
841
+ } KLIB_VERSION;
842
+ typedef KLIB_VERSION* PKLIB_VERSION;
843
+
844
+ typedef BOOL (WINAPI *LibK_GetProcAddress_t)(
845
+ PVOID* ProcAddress,
846
+ ULONG DriverID,
847
+ ULONG FunctionID
848
+ );
849
+
850
+ typedef VOID (WINAPI *LibK_GetVersion_t)(
851
+ PKLIB_VERSION Version
852
+ );
853
+
854
+ struct winusb_interface {
855
+ bool initialized;
856
+ WinUsb_AbortPipe_t AbortPipe;
857
+ WinUsb_ControlTransfer_t ControlTransfer;
858
+ WinUsb_FlushPipe_t FlushPipe;
859
+ WinUsb_Free_t Free;
860
+ WinUsb_GetAssociatedInterface_t GetAssociatedInterface;
861
+ WinUsb_GetCurrentAlternateSetting_t GetCurrentAlternateSetting;
862
+ WinUsb_GetDescriptor_t GetDescriptor;
863
+ WinUsb_GetOverlappedResult_t GetOverlappedResult;
864
+ WinUsb_GetPipePolicy_t GetPipePolicy;
865
+ WinUsb_GetPowerPolicy_t GetPowerPolicy;
866
+ WinUsb_Initialize_t Initialize;
867
+ WinUsb_QueryDeviceInformation_t QueryDeviceInformation;
868
+ WinUsb_QueryInterfaceSettings_t QueryInterfaceSettings;
869
+ WinUsb_QueryPipe_t QueryPipe;
870
+ WinUsb_ReadPipe_t ReadPipe;
871
+ WinUsb_ResetPipe_t ResetPipe;
872
+ WinUsb_SetCurrentAlternateSetting_t SetCurrentAlternateSetting;
873
+ WinUsb_SetPipePolicy_t SetPipePolicy;
874
+ WinUsb_SetPowerPolicy_t SetPowerPolicy;
875
+ WinUsb_WritePipe_t WritePipe;
876
+ WinUsb_ResetDevice_t ResetDevice;
877
+ };
878
+
879
+ /* hid.dll interface */
880
+
881
+ #define HIDP_STATUS_SUCCESS 0x110000
882
+ typedef void* PHIDP_PREPARSED_DATA;
883
+
884
+ #pragma pack(1)
885
+ typedef struct {
886
+ ULONG Size;
887
+ USHORT VendorID;
888
+ USHORT ProductID;
889
+ USHORT VersionNumber;
890
+ } HIDD_ATTRIBUTES, *PHIDD_ATTRIBUTES;
891
+ #pragma pack()
892
+
893
+ typedef USHORT USAGE;
894
+ typedef struct {
895
+ USAGE Usage;
896
+ USAGE UsagePage;
897
+ USHORT InputReportByteLength;
898
+ USHORT OutputReportByteLength;
899
+ USHORT FeatureReportByteLength;
900
+ USHORT Reserved[17];
901
+ USHORT NumberLinkCollectionNodes;
902
+ USHORT NumberInputButtonCaps;
903
+ USHORT NumberInputValueCaps;
904
+ USHORT NumberInputDataIndices;
905
+ USHORT NumberOutputButtonCaps;
906
+ USHORT NumberOutputValueCaps;
907
+ USHORT NumberOutputDataIndices;
908
+ USHORT NumberFeatureButtonCaps;
909
+ USHORT NumberFeatureValueCaps;
910
+ USHORT NumberFeatureDataIndices;
911
+ } HIDP_CAPS, *PHIDP_CAPS;
912
+
913
+ typedef enum _HIDP_REPORT_TYPE {
914
+ HidP_Input,
915
+ HidP_Output,
916
+ HidP_Feature
917
+ } HIDP_REPORT_TYPE;
918
+
919
+ typedef struct _HIDP_VALUE_CAPS {
920
+ USAGE UsagePage;
921
+ UCHAR ReportID;
922
+ BOOLEAN IsAlias;
923
+ USHORT BitField;
924
+ USHORT LinkCollection;
925
+ USAGE LinkUsage;
926
+ USAGE LinkUsagePage;
927
+ BOOLEAN IsRange;
928
+ BOOLEAN IsStringRange;
929
+ BOOLEAN IsDesignatorRange;
930
+ BOOLEAN IsAbsolute;
931
+ BOOLEAN HasNull;
932
+ UCHAR Reserved;
933
+ USHORT BitSize;
934
+ USHORT ReportCount;
935
+ USHORT Reserved2[5];
936
+ ULONG UnitsExp;
937
+ ULONG Units;
938
+ LONG LogicalMin, LogicalMax;
939
+ LONG PhysicalMin, PhysicalMax;
940
+ union {
941
+ struct {
942
+ USAGE UsageMin, UsageMax;
943
+ USHORT StringMin, StringMax;
944
+ USHORT DesignatorMin, DesignatorMax;
945
+ USHORT DataIndexMin, DataIndexMax;
946
+ } Range;
947
+ struct {
948
+ USAGE Usage, Reserved1;
949
+ USHORT StringIndex, Reserved2;
950
+ USHORT DesignatorIndex, Reserved3;
951
+ USHORT DataIndex, Reserved4;
952
+ } NotRange;
953
+ } u;
954
+ } HIDP_VALUE_CAPS, *PHIDP_VALUE_CAPS;
955
+
956
+ DLL_DECLARE(WINAPI, BOOL, HidD_GetAttributes, (HANDLE, PHIDD_ATTRIBUTES));
957
+ DLL_DECLARE(WINAPI, VOID, HidD_GetHidGuid, (LPGUID));
958
+ DLL_DECLARE(WINAPI, BOOL, HidD_GetPreparsedData, (HANDLE, PHIDP_PREPARSED_DATA *));
959
+ DLL_DECLARE(WINAPI, BOOL, HidD_FreePreparsedData, (PHIDP_PREPARSED_DATA));
960
+ DLL_DECLARE(WINAPI, BOOL, HidD_GetManufacturerString, (HANDLE, PVOID, ULONG));
961
+ DLL_DECLARE(WINAPI, BOOL, HidD_GetProductString, (HANDLE, PVOID, ULONG));
962
+ DLL_DECLARE(WINAPI, BOOL, HidD_GetSerialNumberString, (HANDLE, PVOID, ULONG));
963
+ DLL_DECLARE(WINAPI, LONG, HidP_GetCaps, (PHIDP_PREPARSED_DATA, PHIDP_CAPS));
964
+ DLL_DECLARE(WINAPI, BOOL, HidD_SetNumInputBuffers, (HANDLE, ULONG));
965
+ DLL_DECLARE(WINAPI, BOOL, HidD_SetFeature, (HANDLE, PVOID, ULONG));
966
+ DLL_DECLARE(WINAPI, BOOL, HidD_GetFeature, (HANDLE, PVOID, ULONG));
967
+ DLL_DECLARE(WINAPI, BOOL, HidD_GetPhysicalDescriptor, (HANDLE, PVOID, ULONG));
968
+ DLL_DECLARE(WINAPI, BOOL, HidD_GetInputReport, (HANDLE, PVOID, ULONG));
969
+ DLL_DECLARE(WINAPI, BOOL, HidD_SetOutputReport, (HANDLE, PVOID, ULONG));
970
+ DLL_DECLARE(WINAPI, BOOL, HidD_FlushQueue, (HANDLE));
971
+ DLL_DECLARE(WINAPI, BOOL, HidP_GetValueCaps, (HIDP_REPORT_TYPE, PHIDP_VALUE_CAPS, PULONG, PHIDP_PREPARSED_DATA));