hidclass.h 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. /*
  2. * hidclass.h
  3. *
  4. * HID class driver interface
  5. *
  6. * This file is part of the w32api package.
  7. *
  8. * Contributors:
  9. * Created by Casper S. Hornstrup <chorns@users.sourceforge.net>
  10. *
  11. * THIS SOFTWARE IS NOT COPYRIGHTED
  12. *
  13. * This source code is offered for use in the public domain. You may
  14. * use, modify or distribute it freely.
  15. *
  16. * This code is distributed in the hope that it will be useful but
  17. * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
  18. * DISCLAIMED. This includes but is not limited to warranties of
  19. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  20. *
  21. */
  22. #ifndef __HIDCLASS_H
  23. #define __HIDCLASS_H
  24. #include "hidpi.h"
  25. #ifdef __cplusplus
  26. extern "C" {
  27. #endif
  28. #define HID_REVISION 0x00000001
  29. DEFINE_GUID (GUID_DEVINTERFACE_HID, \
  30. 0x4D1E55B2L, 0xF16F, 0x11CF, 0x88, 0xCB, 0x00, 0x11, 0x11, 0x00, 0x00, 0x30);
  31. DEFINE_GUID (GUID_HID_INTERFACE_NOTIFY, \
  32. 0x2c4e2e88L, 0x25e6, 0x4c33, 0x88, 0x2f, 0x3d, 0x82, 0xe6, 0x07, 0x36, 0x81);
  33. DEFINE_GUID (GUID_HID_INTERFACE_HIDPARSE, \
  34. 0xf5c315a5, 0x69ac, 0x4bc2, 0x92, 0x79, 0xd0, 0xb6, 0x45, 0x76, 0xf4, 0x4b);
  35. #define GUID_CLASS_INPUT GUID_DEVINTERFACE_HID
  36. #define GUID_CLASS_INPUT_STR "4D1E55B2-F16F-11CF-88CB-001111000030"
  37. #define HID_CTL_CODE(id) \
  38. CTL_CODE (FILE_DEVICE_KEYBOARD, (id), METHOD_NEITHER, FILE_ANY_ACCESS)
  39. #define HID_BUFFER_CTL_CODE(id) \
  40. CTL_CODE (FILE_DEVICE_KEYBOARD, (id), METHOD_BUFFERED, FILE_ANY_ACCESS)
  41. #define HID_IN_CTL_CODE(id) \
  42. CTL_CODE (FILE_DEVICE_KEYBOARD, (id), METHOD_IN_DIRECT, FILE_ANY_ACCESS)
  43. #define HID_OUT_CTL_CODE(id) \
  44. CTL_CODE (FILE_DEVICE_KEYBOARD, (id), METHOD_OUT_DIRECT, FILE_ANY_ACCESS)
  45. #define IOCTL_GET_PHYSICAL_DESCRIPTOR HID_OUT_CTL_CODE(102)
  46. #define IOCTL_HID_FLUSH_QUEUE HID_CTL_CODE(101)
  47. #define IOCTL_HID_GET_COLLECTION_DESCRIPTOR HID_CTL_CODE(100)
  48. #define IOCTL_HID_GET_COLLECTION_INFORMATION HID_BUFFER_CTL_CODE(106)
  49. #define IOCTL_HID_GET_FEATURE HID_OUT_CTL_CODE(100)
  50. #define IOCTL_HID_GET_HARDWARE_ID HID_OUT_CTL_CODE(103)
  51. #define IOCTL_HID_GET_INDEXED_STRING HID_OUT_CTL_CODE(120)
  52. #define IOCTL_HID_GET_INPUT_REPORT HID_OUT_CTL_CODE(104)
  53. #define IOCTL_HID_GET_MANUFACTURER_STRING HID_OUT_CTL_CODE(110)
  54. #define IOCTL_GET_NUM_DEVICE_INPUT_BUFFERS HID_BUFFER_CTL_CODE(104)
  55. #define IOCTL_HID_GET_POLL_FREQUENCY_MSEC HID_BUFFER_CTL_CODE(102)
  56. #define IOCTL_HID_GET_PRODUCT_STRING HID_OUT_CTL_CODE(111)
  57. #define IOCTL_HID_GET_SERIALNUMBER_STRING HID_OUT_CTL_CODE(112)
  58. #define IOCTL_HID_SET_FEATURE HID_IN_CTL_CODE(100)
  59. #define IOCTL_SET_NUM_DEVICE_INPUT_BUFFERS HID_BUFFER_CTL_CODE(105)
  60. #define IOCTL_HID_SET_OUTPUT_REPORT HID_IN_CTL_CODE(101)
  61. #define IOCTL_HID_SET_POLL_FREQUENCY_MSEC HID_BUFFER_CTL_CODE(103)
  62. #define IOCTL_HID_GET_DRIVER_CONFIG HID_BUFFER_CTL_CODE(100)
  63. #define IOCTL_HID_SET_DRIVER_CONFIG HID_BUFFER_CTL_CODE(101)
  64. #define IOCTL_HID_GET_MS_GENRE_DESCRIPTOR HID_OUT_CTL_CODE(121)
  65. /* FIXME: these values are wrong! */
  66. #define IOCTL_HID_GET_STRING 0
  67. #define IOCTL_HID_GET_DEVICE_ATTRIBUTES 1
  68. #define IOCTL_HID_GET_DEVICE_DESCRIPTOR 2
  69. #define IOCTL_HID_READ_REPORT 3
  70. #define IOCTL_HID_WRITE_REPORT 4
  71. #define IOCTL_HID_GET_REPORT_DESCRIPTOR 5
  72. typedef enum _HID_STRING_TYPE
  73. {
  74. HID_STRING_INDEXED = 0,
  75. HID_STRING_ID_IMANUFACTURER,
  76. HID_STRING_ID_IPRODUCT,
  77. HID_STRING_ID_ISERIALNUMBER,
  78. HID_STRING_MAX
  79. } HID_STRING_TYPE;
  80. enum DeviceObjectState {
  81. DeviceObjectStarted = 0,
  82. DeviceObjectStopped,
  83. DeviceObjectRemoved
  84. };
  85. typedef VOID (NTAPI *PHID_STATUS_CHANGE)(
  86. PVOID Context,
  87. enum DeviceObjectState State);
  88. typedef NTSTATUS (NTAPI *PHIDP_GETCAPS)(
  89. IN PHIDP_PREPARSED_DATA PreparsedData,
  90. OUT PHIDP_CAPS Capabilities);
  91. typedef struct _HID_COLLECTION_INFORMATION {
  92. ULONG DescriptorSize;
  93. BOOLEAN Polled;
  94. UCHAR Reserved1[1];
  95. USHORT VendorID;
  96. USHORT ProductID;
  97. USHORT VersionNumber;
  98. } HID_COLLECTION_INFORMATION, *PHID_COLLECTION_INFORMATION;
  99. typedef struct _HID_DRIVER_CONFIG {
  100. ULONG Size;
  101. ULONG RingBufferSize;
  102. } HID_DRIVER_CONFIG, *PHID_DRIVER_CONFIG;
  103. typedef struct _HID_INTERFACE_HIDPARSE {
  104. #ifdef __cplusplus
  105. INTERFACE i;
  106. #else
  107. /* GCC doesn't support including unnamed structs, so INTERFACE is
  108. expanded here */
  109. USHORT Size;
  110. USHORT Version;
  111. PVOID Context;
  112. PINTERFACE_REFERENCE InterfaceReference;
  113. PINTERFACE_DEREFERENCE InterfaceDereference;
  114. #endif
  115. PHIDP_GETCAPS HidpGetCaps;
  116. } HID_INTERFACE_HIDPARSE, *PHID_INTERFACE_HIDPARSE;
  117. typedef struct _HID_INTERFACE_NOTIFY_PNP {
  118. #ifdef __cplusplus
  119. INTERFACE i;
  120. #else
  121. /* GCC doesn't support including unnamed structs, so INTERFACE is
  122. expanded here */
  123. USHORT Size;
  124. USHORT Version;
  125. PVOID Context;
  126. PINTERFACE_REFERENCE InterfaceReference;
  127. PINTERFACE_DEREFERENCE InterfaceDereference;
  128. #endif
  129. PHID_STATUS_CHANGE StatusChangeFn;
  130. PVOID CallbackContext;
  131. } HID_INTERFACE_NOTIFY_PNP, *PHID_INTERFACE_NOTIFY_PNP;
  132. typedef struct _HID_XFER_PACKET {
  133. PUCHAR reportBuffer;
  134. ULONG reportBufferLen;
  135. UCHAR reportId;
  136. } HID_XFER_PACKET, *PHID_XFER_PACKET;
  137. #ifdef __cplusplus
  138. }
  139. #endif
  140. #endif /* __HIDCLASS_H */