home *** CD-ROM | disk | FTP | other *** search
/ H4CK3R 14 / hacker14.iso / programacao / cwin / c.exe / $INSTDIR / include / ddk / usbscan.h < prev    next >
Encoding:
C/C++ Source or Header  |  2003-12-15  |  4.1 KB  |  164 lines

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