1 // Copyright © 2015, Peter Atashian and Alex Daniel Jones
2 // Licensed under the MIT License <LICENSE.md>
3 DEFINE_GUID!{GUID_DEVINTERFACE_HID, 0x4D1E55B2, 0xF16F, 0x11CF,
4     0x88, 0xCB, 0x00, 0x11, 0x11, 0x00, 0x00, 0x30}
5 pub const GUID_CLASS_INPUT: ::GUID = GUID_DEVINTERFACE_HID;
6 DEFINE_GUID!{GUID_HID_INTERFACE_NOTIFY, 0x2c4e2e88, 0x25e6, 0x4c33, 0x88, 0x2f, 0x3d, 0x82, 0xe6, 0x07, 0x36, 0x81}
7 DEFINE_GUID!{GUID_HID_INTERFACE_HIDPARSE, 0xf5c315a5, 0x69ac, 0x4bc2, 0x92, 0x79, 0xd0, 0xb6, 0x45, 0x76, 0xf4, 0x4b}
8 // FIXME devpropkey stuff
9 pub const HID_REVISION: ::DWORD = 0x00000001;
10 pub const IOCTL_HID_GET_DRIVER_CONFIG: ::DWORD = HID_BUFFER_CTL_CODE!(100);
11 pub const IOCTL_HID_SET_DRIVER_CONFIG: ::DWORD = HID_BUFFER_CTL_CODE!(101);
12 pub const IOCTL_HID_GET_POLL_FREQUENCY_MSEC: ::DWORD = HID_BUFFER_CTL_CODE!(102);
13 pub const IOCTL_HID_SET_POLL_FREQUENCY_MSEC: ::DWORD = HID_BUFFER_CTL_CODE!(103);
14 pub const IOCTL_GET_NUM_DEVICE_INPUT_BUFFERS: ::DWORD = HID_BUFFER_CTL_CODE!(104);
15 pub const IOCTL_SET_NUM_DEVICE_INPUT_BUFFERS: ::DWORD = HID_BUFFER_CTL_CODE!(105);
16 pub const IOCTL_HID_GET_COLLECTION_INFORMATION: ::DWORD = HID_BUFFER_CTL_CODE!(106);
17 pub const IOCTL_HID_ENABLE_WAKE_ON_SX: ::DWORD = HID_BUFFER_CTL_CODE!(107);
18 pub const IOCTL_HID_SET_S0_IDLE_TIMEOUT: ::DWORD = HID_BUFFER_CTL_CODE!(108);
19 pub const IOCTL_HID_GET_COLLECTION_DESCRIPTOR: ::DWORD = HID_CTL_CODE!(100);
20 pub const IOCTL_HID_FLUSH_QUEUE: ::DWORD = HID_CTL_CODE!(101);
21 pub const IOCTL_HID_SET_FEATURE: ::DWORD = HID_IN_CTL_CODE!(100);
22 pub const IOCTL_HID_SET_OUTPUT_REPORT: ::DWORD = HID_IN_CTL_CODE!(101);
23 pub const IOCTL_HID_GET_FEATURE: ::DWORD = HID_OUT_CTL_CODE!(100);
24 pub const IOCTL_GET_PHYSICAL_DESCRIPTOR: ::DWORD = HID_OUT_CTL_CODE!(102);
25 pub const IOCTL_HID_GET_HARDWARE_ID: ::DWORD = HID_OUT_CTL_CODE!(103);
26 pub const IOCTL_HID_GET_INPUT_REPORT: ::DWORD = HID_OUT_CTL_CODE!(104);
27 pub const IOCTL_HID_GET_OUTPUT_REPORT: ::DWORD = HID_OUT_CTL_CODE!(105);
28 pub const IOCTL_HID_GET_MANUFACTURER_STRING: ::DWORD = HID_OUT_CTL_CODE!(110);
29 pub const IOCTL_HID_GET_PRODUCT_STRING: ::DWORD = HID_OUT_CTL_CODE!(111);
30 pub const IOCTL_HID_GET_SERIALNUMBER_STRING: ::DWORD = HID_OUT_CTL_CODE!(112);
31 pub const IOCTL_HID_GET_INDEXED_STRING: ::DWORD = HID_OUT_CTL_CODE!(120);
32 pub const IOCTL_HID_GET_MS_GENRE_DESCRIPTOR: ::DWORD = HID_OUT_CTL_CODE!(121);
33 pub const IOCTL_HID_ENABLE_SECURE_READ: ::DWORD = HID_CTL_CODE!(130);
34 pub const IOCTL_HID_DISABLE_SECURE_READ: ::DWORD = HID_CTL_CODE!(131);
35 pub const IOCTL_HID_DEVICERESET_NOTIFICATION: ::DWORD = HID_CTL_CODE!(140);
36 STRUCT!{struct HID_XFER_PACKET {
37     reportBuffer: ::PUCHAR,
38     reportBufferLen: ::ULONG,
39     reportId: ::UCHAR,
40 }}
41 pub type PHID_XFER_PACKET = *mut HID_XFER_PACKET;
42 //FIXME Stuff for NT_INCLUDED
43 STRUCT!{struct HID_COLLECTION_INFORMATION {
44     DescriptorSize: ::ULONG,
45     Polled: ::BOOLEAN,
46     Reserved1: [::UCHAR; 1],
47     VendorID: ::USHORT,
48     ProductID: ::USHORT,
49     VersionNumber: ::USHORT,
50 }}
51 pub type PHID_COLLECTION_INFORMATION = *mut HID_COLLECTION_INFORMATION;
52 STRUCT!{struct HID_DRIVER_CONFIG {
53     Size: ::ULONG,
54     RingBufferSize: ::ULONG,
55 }}
56 pub type PHID_DRIVER_CONFIG = *mut HID_DRIVER_CONFIG;
57