Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

189 lines
4.9 KiB

  1. /*++
  2. Copyright (c) Microsoft 1998, All Rights Reserved
  3. Module Name:
  4. hid.h
  5. Abstract:
  6. This module contains the declarations and definitions for use with the
  7. hid user mode client sample driver.
  8. Environment:
  9. Kernel & user mode
  10. @@BEGIN_DDKSPLIT
  11. Revision History:
  12. Nov-96 : Created by Kenneth D. Ray
  13. @@END_DDKSPLIT
  14. --*/
  15. #ifndef HID_H
  16. #define HID_H
  17. #include "hidsdi.h"
  18. #include "setupapi.h"
  19. typedef struct _SP_FNCLASS_DEVICE_DATA {
  20. DWORD cbSize;
  21. GUID FunctionClassGuid;
  22. TCHAR DevicePath [ANYSIZE_ARRAY];
  23. } SP_FNCLASS_DEVICE_DATA, *PSP_FNCLASS_DEVICE_DATA;
  24. BOOLEAN
  25. SetupDiGetFunctionClassDeviceInfo (
  26. IN HDEVINFO DeviceInfoSet,
  27. IN PSP_DEVINFO_DATA DeviceInfoData,
  28. OUT PSP_FNCLASS_DEVICE_DATA FunctionClassDeviceData,
  29. IN DWORD FunctionClassDeviceDataSize,
  30. OUT PDWORD RequiredSize
  31. );
  32. #define ASSERT(x)
  33. //
  34. // A structure to hold the steady state data received from the hid device.
  35. // Each time a read packet is received we fill in this structure.
  36. // Each time we wish to write to a hid device we fill in this structure.
  37. // This structure is here only for convenience. Most real applications will
  38. // have a more efficient way of moving the hid data to the read, write, and
  39. // feature routines.
  40. //
  41. typedef struct _HID_DATA {
  42. BOOLEAN IsButtonData;
  43. UCHAR Reserved;
  44. USAGE UsagePage; // The usage page for which we are looking.
  45. ULONG Status; // The last status returned from the accessor function
  46. // when updating this field.
  47. ULONG ReportID; // ReportID for this given data structure
  48. BOOLEAN IsDataSet; // Variable to track whether a given data structure
  49. // has already been added to a report structure
  50. union {
  51. struct {
  52. ULONG UsageMin; // Variables to track the usage minimum and max
  53. ULONG UsageMax; // If equal, then only a single usage
  54. ULONG MaxUsageLength; // Usages buffer length.
  55. PUSAGE Usages; // list of usages (buttons ``down'' on the device.
  56. } ButtonData;
  57. struct {
  58. USAGE Usage; // The usage describing this value;
  59. USHORT Reserved;
  60. ULONG Value;
  61. LONG ScaledValue;
  62. } ValueData;
  63. };
  64. } HID_DATA, *PHID_DATA;
  65. typedef struct _HID_DEVICE {
  66. PCHAR DevicePath;
  67. HANDLE HidDevice; // A file handle to the hid device.
  68. BOOL OpenedForRead;
  69. BOOL OpenedForWrite;
  70. BOOL OpenedOverlapped;
  71. BOOL OpenedExclusive;
  72. PHIDP_PREPARSED_DATA Ppd; // The opaque parser info describing this device
  73. HIDP_CAPS Caps; // The Capabilities of this hid device.
  74. HIDD_ATTRIBUTES Attributes;
  75. PCHAR InputReportBuffer;
  76. PHID_DATA InputData; // array of hid data structures
  77. ULONG InputDataLength; // Num elements in this array.
  78. PHIDP_BUTTON_CAPS InputButtonCaps;
  79. PHIDP_VALUE_CAPS InputValueCaps;
  80. PCHAR OutputReportBuffer;
  81. PHID_DATA OutputData;
  82. ULONG OutputDataLength;
  83. PHIDP_BUTTON_CAPS OutputButtonCaps;
  84. PHIDP_VALUE_CAPS OutputValueCaps;
  85. PCHAR FeatureReportBuffer;
  86. PHID_DATA FeatureData;
  87. ULONG FeatureDataLength;
  88. PHIDP_BUTTON_CAPS FeatureButtonCaps;
  89. PHIDP_VALUE_CAPS FeatureValueCaps;
  90. } HID_DEVICE, *PHID_DEVICE;
  91. BOOLEAN
  92. OpenHidDevice (
  93. IN PCHAR DevicePath,
  94. IN BOOL HasReadAccess,
  95. IN BOOL HasWriteAccess,
  96. IN BOOL IsOverlapped,
  97. IN BOOL IsExclusive,
  98. IN BOOL GetDeviceInfo,
  99. IN OUT PHID_DEVICE HidDevice
  100. );
  101. BOOLEAN
  102. FindKnownHidDevices (
  103. OUT PHID_DEVICE * HidDevices, // A array of struct _HID_DEVICE
  104. OUT PULONG NumberDevices // the length of this array.
  105. );
  106. BOOLEAN
  107. FillDeviceInfo(
  108. IN PHID_DEVICE HidDevice
  109. );
  110. VOID
  111. CloseHidDevices (
  112. OUT PHID_DEVICE HidDevices, // A array of struct _HID_DEVICE
  113. OUT ULONG NumberDevices // the length of this array.
  114. );
  115. VOID
  116. CloseHidDevice (
  117. IN PHID_DEVICE HidDevice,
  118. IN BOOL FreeDeviceInfo
  119. );
  120. BOOLEAN
  121. Read (
  122. PHID_DEVICE HidDevice
  123. );
  124. BOOLEAN
  125. ReadOverlapped (
  126. PHID_DEVICE HidDevice,
  127. HANDLE CompletionEvent
  128. );
  129. BOOLEAN
  130. Write (
  131. PHID_DEVICE HidDevice
  132. );
  133. BOOLEAN
  134. UnpackReport (
  135. IN PCHAR ReportBuffer,
  136. IN USHORT ReportBufferLength,
  137. IN HIDP_REPORT_TYPE ReportType,
  138. IN OUT PHID_DATA Data,
  139. IN ULONG DataLength,
  140. IN PHIDP_PREPARSED_DATA Ppd
  141. );
  142. BOOLEAN
  143. SetFeature (
  144. PHID_DEVICE HidDevice
  145. );
  146. BOOLEAN
  147. GetFeature (
  148. PHID_DEVICE HidDevice
  149. );
  150. #endif