usbscan.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. /*
  2. * usbscan.h
  3. *
  4. * USB scanner definitions
  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. #pragma once
  23. #ifdef __cplusplus
  24. extern "C" {
  25. #endif
  26. #if (NTDDI_VERSION >= NTDDI_WIN2K)
  27. #pragma pack(push,8)
  28. #ifndef MAX_NUM_PIPES
  29. #define MAX_NUM_PIPES 8
  30. #endif
  31. #define BULKIN_FLAG 0x80
  32. typedef struct _DRV_VERSION {
  33. OUT ULONG major;
  34. OUT ULONG minor;
  35. OUT ULONG internal;
  36. } DRV_VERSION, *PDRV_VERSION;
  37. typedef struct _IO_BLOCK {
  38. IN ULONG uOffset;
  39. IN ULONG uLength;
  40. IN OUT PUCHAR pbyData;
  41. IN ULONG uIndex;
  42. } IO_BLOCK, *PIO_BLOCK;
  43. typedef struct _IO_BLOCK_EX {
  44. IN ULONG uOffset;
  45. IN ULONG uLength;
  46. IN OUT PUCHAR pbyData;
  47. IN ULONG uIndex;
  48. IN UCHAR bRequest;
  49. IN UCHAR bmRequestType;
  50. IN UCHAR fTransferDirectionIn;
  51. } IO_BLOCK_EX, *PIO_BLOCK_EX;
  52. typedef struct _CHANNEL_INFO {
  53. OUT ULONG EventChannelSize;
  54. OUT ULONG uReadDataAlignment;
  55. OUT ULONG uWriteDataAlignment;
  56. }CHANNEL_INFO, *PCHANNEL_INFO;
  57. typedef enum _PIPE_TYPE {
  58. EVENT_PIPE,
  59. READ_DATA_PIPE,
  60. WRITE_DATA_PIPE,
  61. ALL_PIPE
  62. } PIPE_TYPE;
  63. typedef struct _USBSCAN_GET_DESCRIPTOR {
  64. IN UCHAR DescriptorType;
  65. IN UCHAR Index;
  66. IN USHORT LanguageId;
  67. } USBSCAN_GET_DESCRIPTOR, *PUSBSCAN_GET_DESCRIPTOR;
  68. typedef struct _DEVICE_DESCRIPTOR {
  69. OUT USHORT usVendorId;
  70. OUT USHORT usProductId;
  71. OUT USHORT usBcdDevice;
  72. OUT USHORT usLanguageId;
  73. } DEVICE_DESCRIPTOR, *PDEVICE_DESCRIPTOR;
  74. typedef enum _RAW_PIPE_TYPE {
  75. USBSCAN_PIPE_CONTROL,
  76. USBSCAN_PIPE_ISOCHRONOUS,
  77. USBSCAN_PIPE_BULK,
  78. USBSCAN_PIPE_INTERRUPT
  79. } RAW_PIPE_TYPE;
  80. typedef struct _USBSCAN_PIPE_INFORMATION {
  81. USHORT MaximumPacketSize;
  82. UCHAR EndpointAddress;
  83. UCHAR Interval;
  84. RAW_PIPE_TYPE PipeType;
  85. } USBSCAN_PIPE_INFORMATION, *PUSBSCAN_PIPE_INFORMATION;
  86. typedef struct _USBSCAN_PIPE_CONFIGURATION {
  87. OUT ULONG NumberOfPipes;
  88. OUT USBSCAN_PIPE_INFORMATION PipeInfo[MAX_NUM_PIPES];
  89. } USBSCAN_PIPE_CONFIGURATION, *PUSBSCAN_PIPE_CONFIGURATION;
  90. #if (NTDDI_VERSION >= NTDDI_WINXP)
  91. typedef struct _USBSCAN_TIMEOUT {
  92. IN ULONG TimeoutRead;
  93. IN ULONG TimeoutWrite;
  94. IN ULONG TimeoutEvent;
  95. } USBSCAN_TIMEOUT, *PUSBSCAN_TIMEOUT;
  96. #endif
  97. #define FILE_DEVICE_USB_SCAN 0x8000
  98. #define IOCTL_INDEX 0x0800
  99. #define IOCTL_GET_VERSION \
  100. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 0, METHOD_BUFFERED,FILE_ANY_ACCESS)
  101. #define IOCTL_CANCEL_IO \
  102. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 1, METHOD_BUFFERED,FILE_ANY_ACCESS)
  103. #define IOCTL_WAIT_ON_DEVICE_EVENT \
  104. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 2, METHOD_BUFFERED,FILE_ANY_ACCESS)
  105. #define IOCTL_READ_REGISTERS \
  106. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 3, METHOD_BUFFERED,FILE_ANY_ACCESS)
  107. #define IOCTL_WRITE_REGISTERS \
  108. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 4, METHOD_BUFFERED, FILE_ANY_ACCESS)
  109. #define IOCTL_GET_CHANNEL_ALIGN_RQST \
  110. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 5, METHOD_BUFFERED,FILE_ANY_ACCESS)
  111. #define IOCTL_GET_DEVICE_DESCRIPTOR \
  112. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 6, METHOD_BUFFERED,FILE_ANY_ACCESS)
  113. #define IOCTL_RESET_PIPE \
  114. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 7, METHOD_BUFFERED,FILE_ANY_ACCESS)
  115. #define IOCTL_GET_USB_DESCRIPTOR \
  116. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 8, METHOD_BUFFERED,FILE_ANY_ACCESS)
  117. #define IOCTL_SEND_USB_REQUEST \
  118. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 9, METHOD_BUFFERED,FILE_ANY_ACCESS)
  119. #define IOCTL_GET_PIPE_CONFIGURATION \
  120. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 10,METHOD_BUFFERED,FILE_ANY_ACCESS)
  121. #if (NTDDI_VERSION >= NTDDI_WINXP)
  122. #define IOCTL_SET_TIMEOUT \
  123. CTL_CODE(FILE_DEVICE_USB_SCAN, IOCTL_INDEX + 11,METHOD_BUFFERED,FILE_ANY_ACCESS)
  124. #endif
  125. #pragma pack(pop)
  126. #endif // (NTDDI_VERSION >= NTDDI_WIN2K)
  127. #ifdef __cplusplus
  128. }
  129. #endif