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.
- package/.github/workflows/prebuild.yml +62 -0
- package/.gitmodules +3 -0
- package/LICENSE +7 -0
- package/Readme.md +339 -0
- package/binding.gyp +90 -0
- package/libusb/.gitattributes +11 -0
- package/libusb/.private/README.txt +5 -0
- package/libusb/.private/bd.cmd +89 -0
- package/libusb/.private/bm.sh +54 -0
- package/libusb/.private/bwince.cmd +57 -0
- package/libusb/.private/post-rewrite.sh +28 -0
- package/libusb/.private/pre-commit.sh +42 -0
- package/libusb/.private/wbs.txt +61 -0
- package/libusb/.private/wbs_wince.txt +42 -0
- package/libusb/AUTHORS +78 -0
- package/libusb/COPYING +504 -0
- package/libusb/ChangeLog +211 -0
- package/libusb/INSTALL +234 -0
- package/libusb/INSTALL_WIN.txt +73 -0
- package/libusb/Makefile.am +28 -0
- package/libusb/NEWS +2 -0
- package/libusb/PORTING +94 -0
- package/libusb/README +28 -0
- package/libusb/README.git +41 -0
- package/libusb/TODO +2 -0
- package/libusb/Xcode/common.xcconfig +49 -0
- package/libusb/Xcode/debug.xcconfig +29 -0
- package/libusb/Xcode/libusb.xcconfig +21 -0
- package/libusb/Xcode/libusb.xcodeproj/project.pbxproj +1 -0
- package/libusb/Xcode/libusb_debug.xcconfig +21 -0
- package/libusb/Xcode/libusb_release.xcconfig +21 -0
- package/libusb/Xcode/release.xcconfig +30 -0
- package/libusb/android/README +114 -0
- package/libusb/android/jni/Android.mk +23 -0
- package/libusb/android/jni/Application.mk +24 -0
- package/libusb/android/jni/examples.mk +134 -0
- package/libusb/android/jni/libusb.mk +54 -0
- package/libusb/android/jni/tests.mk +56 -0
- package/libusb/autogen.sh +8 -0
- package/libusb/bootstrap.sh +19 -0
- package/libusb/configure.ac +304 -0
- package/libusb/doc/Makefile.am +9 -0
- package/libusb/doc/doxygen.cfg.in +1288 -0
- package/libusb/doc/libusb.png +0 -0
- package/libusb/examples/Makefile.am +19 -0
- package/libusb/examples/dpfp.c +506 -0
- package/libusb/examples/dpfp_threaded.c +544 -0
- package/libusb/examples/ezusb.c +831 -0
- package/libusb/examples/ezusb.h +120 -0
- package/libusb/examples/fxload.c +287 -0
- package/libusb/examples/getopt/getopt.c +1060 -0
- package/libusb/examples/getopt/getopt.h +180 -0
- package/libusb/examples/getopt/getopt1.c +188 -0
- package/libusb/examples/hotplugtest.c +104 -0
- package/libusb/examples/listdevs.c +71 -0
- package/libusb/examples/sam3u_benchmark.c +193 -0
- package/libusb/examples/xusb.c +1129 -0
- package/libusb/libusb/Makefile.am +75 -0
- package/libusb/libusb/core.c +2342 -0
- package/libusb/libusb/descriptor.c +1199 -0
- package/libusb/libusb/hotplug.c +327 -0
- package/libusb/libusb/hotplug.h +82 -0
- package/libusb/libusb/io.c +2631 -0
- package/libusb/libusb/libusb-1.0.def +166 -0
- package/libusb/libusb/libusb-1.0.rc +61 -0
- package/libusb/libusb/libusb.h +1998 -0
- package/libusb/libusb/libusbi.h +1040 -0
- package/libusb/libusb/os/darwin_usb.c +2009 -0
- package/libusb/libusb/os/darwin_usb.h +162 -0
- package/libusb/libusb/os/linux_netlink.c +369 -0
- package/libusb/libusb/os/linux_udev.c +307 -0
- package/libusb/libusb/os/linux_usbfs.c +2695 -0
- package/libusb/libusb/os/linux_usbfs.h +192 -0
- package/libusb/libusb/os/netbsd_usb.c +738 -0
- package/libusb/libusb/os/openbsd_usb.c +832 -0
- package/libusb/libusb/os/poll_posix.c +51 -0
- package/libusb/libusb/os/poll_posix.h +11 -0
- package/libusb/libusb/os/poll_windows.c +796 -0
- package/libusb/libusb/os/poll_windows.h +131 -0
- package/libusb/libusb/os/threads_posix.c +82 -0
- package/libusb/libusb/os/threads_posix.h +50 -0
- package/libusb/libusb/os/threads_windows.c +212 -0
- package/libusb/libusb/os/threads_windows.h +87 -0
- package/libusb/libusb/os/wince_usb.c +1032 -0
- package/libusb/libusb/os/wince_usb.h +131 -0
- package/libusb/libusb/os/windows_common.h +108 -0
- package/libusb/libusb/os/windows_usb.c +5347 -0
- package/libusb/libusb/os/windows_usb.h +971 -0
- package/libusb/libusb/strerror.c +199 -0
- package/libusb/libusb/sync.c +307 -0
- package/libusb/libusb/version.h +18 -0
- package/libusb/libusb/version_nano.h +1 -0
- package/libusb/libusb-1.0.pc.in +11 -0
- package/libusb/msvc/config.h +50 -0
- package/libusb/msvc/ddk_build.cmd +175 -0
- package/libusb/msvc/errno.h +102 -0
- package/libusb/msvc/fxload_2010.vcxproj +170 -0
- package/libusb/msvc/fxload_2010.vcxproj.filters +25 -0
- package/libusb/msvc/fxload_2012.vcxproj +174 -0
- package/libusb/msvc/fxload_2012.vcxproj.filters +25 -0
- package/libusb/msvc/fxload_2013.vcxproj +174 -0
- package/libusb/msvc/fxload_sources +23 -0
- package/libusb/msvc/getopt_2005.vcproj +288 -0
- package/libusb/msvc/getopt_2010.vcxproj +131 -0
- package/libusb/msvc/getopt_2010.vcxproj.filters +26 -0
- package/libusb/msvc/getopt_2012.vcxproj +136 -0
- package/libusb/msvc/getopt_2012.vcxproj.filters +26 -0
- package/libusb/msvc/getopt_2013.vcxproj +136 -0
- package/libusb/msvc/getopt_sources +20 -0
- package/libusb/msvc/hotplugtest_2010.vcxproj +163 -0
- package/libusb/msvc/hotplugtest_2010.vcxproj.filters +14 -0
- package/libusb/msvc/hotplugtest_2012.vcxproj +167 -0
- package/libusb/msvc/hotplugtest_2012.vcxproj.filters +14 -0
- package/libusb/msvc/hotplugtest_2013.vcxproj +167 -0
- package/libusb/msvc/hotplugtest_sources +20 -0
- package/libusb/msvc/inttypes.h +295 -0
- package/libusb/msvc/libusb.dsw +71 -0
- package/libusb/msvc/libusb_2005.sln +95 -0
- package/libusb/msvc/libusb_2010.sln +94 -0
- package/libusb/msvc/libusb_2012.sln +94 -0
- package/libusb/msvc/libusb_2013.sln +100 -0
- package/libusb/msvc/libusb_2015.sln +100 -0
- package/libusb/msvc/libusb_dll.dsp +194 -0
- package/libusb/msvc/libusb_dll_2005.vcproj +436 -0
- package/libusb/msvc/libusb_dll_2010.vcxproj +170 -0
- package/libusb/msvc/libusb_dll_2010.vcxproj.filters +81 -0
- package/libusb/msvc/libusb_dll_2012.vcxproj +175 -0
- package/libusb/msvc/libusb_dll_2012.vcxproj.filters +84 -0
- package/libusb/msvc/libusb_dll_2013.vcxproj +175 -0
- package/libusb/msvc/libusb_dll_wince.vcproj +1243 -0
- package/libusb/msvc/libusb_sources +38 -0
- package/libusb/msvc/libusb_static.dsp +174 -0
- package/libusb/msvc/libusb_static_2005.vcproj +362 -0
- package/libusb/msvc/libusb_static_2010.vcxproj +156 -0
- package/libusb/msvc/libusb_static_2010.vcxproj.filters +74 -0
- package/libusb/msvc/libusb_static_2012.vcxproj +160 -0
- package/libusb/msvc/libusb_static_2012.vcxproj.filters +74 -0
- package/libusb/msvc/libusb_static_2013.vcxproj +160 -0
- package/libusb/msvc/libusb_static_wince.vcproj +1185 -0
- package/libusb/msvc/libusb_wince.sln +246 -0
- package/libusb/msvc/listdevs.dsp +103 -0
- package/libusb/msvc/listdevs_2005.vcproj +360 -0
- package/libusb/msvc/listdevs_2010.vcxproj +165 -0
- package/libusb/msvc/listdevs_2010.vcxproj.filters +14 -0
- package/libusb/msvc/listdevs_2012.vcxproj +169 -0
- package/libusb/msvc/listdevs_2012.vcxproj.filters +14 -0
- package/libusb/msvc/listdevs_2013.vcxproj +169 -0
- package/libusb/msvc/listdevs_sources +19 -0
- package/libusb/msvc/listdevs_wince.vcproj +1120 -0
- package/libusb/msvc/missing.c +80 -0
- package/libusb/msvc/missing.h +32 -0
- package/libusb/msvc/stdint.h +256 -0
- package/libusb/msvc/stress_2005.vcproj +390 -0
- package/libusb/msvc/stress_2010.vcxproj +167 -0
- package/libusb/msvc/stress_2010.vcxproj.filters +25 -0
- package/libusb/msvc/stress_2012.vcxproj +171 -0
- package/libusb/msvc/stress_2012.vcxproj.filters +25 -0
- package/libusb/msvc/stress_2013.vcxproj +171 -0
- package/libusb/msvc/stress_wince.vcproj +1128 -0
- package/libusb/msvc/xusb.dsp +102 -0
- package/libusb/msvc/xusb_2005.vcproj +344 -0
- package/libusb/msvc/xusb_2010.vcxproj +163 -0
- package/libusb/msvc/xusb_2010.vcxproj.filters +14 -0
- package/libusb/msvc/xusb_2012.vcxproj +167 -0
- package/libusb/msvc/xusb_2012.vcxproj.filters +14 -0
- package/libusb/msvc/xusb_2013.vcxproj +167 -0
- package/libusb/msvc/xusb_sources +20 -0
- package/libusb/msvc/xusb_wince.vcproj +1120 -0
- package/libusb/tests/Makefile.am +6 -0
- package/libusb/tests/libusb_testlib.h +107 -0
- package/libusb/tests/stress.c +160 -0
- package/libusb/tests/testlib.c +281 -0
- package/libusb.gypi +136 -0
- package/libusb_config/config.h +1 -0
- package/package.json +69 -0
- package/src/device.cc +412 -0
- package/src/helpers.h +64 -0
- package/src/node_usb.cc +319 -0
- package/src/node_usb.h +120 -0
- package/src/transfer.cc +148 -0
- package/src/uv_async_queue.h +33 -0
- package/test/usb.coffee +191 -0
- 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));
|