parallel.h 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. /*
  2. * parallel.h
  3. *
  4. * ParPort 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 __PARALLEL_H
  23. #define __PARALLEL_H
  24. #include "ntddpar.h"
  25. #ifdef __cplusplus
  26. extern "C" {
  27. #endif
  28. #define DD_PARALLEL_PORT_BASE_NAME "ParallelPort"
  29. #define DD_PARALLEL_PORT_BASE_NAME_U L"ParallelPort"
  30. #define IOCTL_INTERNAL_DESELECT_DEVICE \
  31. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 24, METHOD_BUFFERED, FILE_ANY_ACCESS)
  32. #define IOCTL_INTERNAL_GET_MORE_PARALLEL_PORT_INFO \
  33. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 17, METHOD_BUFFERED, FILE_ANY_ACCESS)
  34. #define IOCTL_INTERNAL_GET_PARALLEL_PNP_INFO \
  35. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 21, METHOD_BUFFERED, FILE_ANY_ACCESS)
  36. #define IOCTL_INTERNAL_GET_PARALLEL_PORT_INFO \
  37. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 12, METHOD_BUFFERED, FILE_ANY_ACCESS)
  38. #define IOCTL_INTERNAL_INIT_1284_3_BUS \
  39. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 22, METHOD_BUFFERED, FILE_ANY_ACCESS)
  40. #define IOCTL_INTERNAL_PARALLEL_CLEAR_CHIP_MODE \
  41. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 20, METHOD_BUFFERED, FILE_ANY_ACCESS)
  42. #define IOCTL_INTERNAL_PARALLEL_CONNECT_INTERRUPT \
  43. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 13, METHOD_BUFFERED, FILE_ANY_ACCESS)
  44. #define IOCTL_INTERNAL_PARALLEL_DISCONNECT_INTERRUPT \
  45. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 14, METHOD_BUFFERED, FILE_ANY_ACCESS)
  46. #define IOCTL_INTERNAL_PARALLEL_PORT_ALLOCATE \
  47. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 11, METHOD_BUFFERED, FILE_ANY_ACCESS)
  48. #define IOCTL_INTERNAL_PARALLEL_PORT_FREE \
  49. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 40, METHOD_BUFFERED, FILE_ANY_ACCESS)
  50. #define IOCTL_INTERNAL_PARALLEL_SET_CHIP_MODE \
  51. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 19, METHOD_BUFFERED, FILE_ANY_ACCESS)
  52. #define IOCTL_INTERNAL_RELEASE_PARALLEL_PORT_INFO \
  53. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 15, METHOD_BUFFERED, FILE_ANY_ACCESS)
  54. #define IOCTL_INTERNAL_SELECT_DEVICE \
  55. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 23, METHOD_BUFFERED, FILE_ANY_ACCESS)
  56. typedef struct _PARALLEL_1284_COMMAND {
  57. UCHAR ID;
  58. UCHAR Port;
  59. ULONG CommandFlags;
  60. } PARALLEL_1284_COMMAND, *PPARALLEL_1284_COMMAND;
  61. /* PARALLEL_1284_COMMAND.CommandFlags */
  62. #define PAR_END_OF_CHAIN_DEVICE 0x00000001
  63. #define PAR_HAVE_PORT_KEEP_PORT 0x00000002
  64. typedef struct _MORE_PARALLEL_PORT_INFORMATION {
  65. INTERFACE_TYPE InterfaceType;
  66. ULONG BusNumber;
  67. ULONG InterruptLevel;
  68. ULONG InterruptVector;
  69. KAFFINITY InterruptAffinity;
  70. KINTERRUPT_MODE InterruptMode;
  71. } MORE_PARALLEL_PORT_INFORMATION, *PMORE_PARALLEL_PORT_INFORMATION;
  72. typedef NTSTATUS
  73. (NTAPI *PPARALLEL_SET_CHIP_MODE)(
  74. IN PVOID SetChipContext,
  75. IN UCHAR ChipMode);
  76. typedef NTSTATUS
  77. (NTAPI *PPARALLEL_CLEAR_CHIP_MODE)(
  78. IN PVOID ClearChipContext,
  79. IN UCHAR ChipMode);
  80. typedef NTSTATUS
  81. (NTAPI *PPARCHIP_CLEAR_CHIP_MODE)(
  82. IN PVOID ClearChipContext,
  83. IN UCHAR ChipMode);
  84. typedef NTSTATUS
  85. (NTAPI *PPARALLEL_TRY_SELECT_ROUTINE)(
  86. IN PVOID TrySelectContext,
  87. IN PVOID TrySelectCommand);
  88. typedef NTSTATUS
  89. (NTAPI *PPARALLEL_DESELECT_ROUTINE)(
  90. IN PVOID DeselectContext,
  91. IN PVOID DeselectCommand);
  92. /* PARALLEL_PNP_INFORMATION.HardwareCapabilities */
  93. #define PPT_NO_HARDWARE_PRESENT 0x00000000
  94. #define PPT_ECP_PRESENT 0x00000001
  95. #define PPT_EPP_PRESENT 0x00000002
  96. #define PPT_EPP_32_PRESENT 0x00000004
  97. #define PPT_BYTE_PRESENT 0x00000008
  98. #define PPT_BIDI_PRESENT 0x00000008
  99. #define PPT_1284_3_PRESENT 0x00000010
  100. typedef struct _PARALLEL_PNP_INFORMATION {
  101. PHYSICAL_ADDRESS OriginalEcpController;
  102. PUCHAR EcpController;
  103. ULONG SpanOfEcpController;
  104. ULONG PortNumber;
  105. ULONG HardwareCapabilities;
  106. PPARALLEL_SET_CHIP_MODE TrySetChipMode;
  107. PPARALLEL_CLEAR_CHIP_MODE ClearChipMode;
  108. ULONG FifoDepth;
  109. ULONG FifoWidth;
  110. PHYSICAL_ADDRESS EppControllerPhysicalAddress;
  111. ULONG SpanOfEppController;
  112. ULONG Ieee1284_3DeviceCount;
  113. PPARALLEL_TRY_SELECT_ROUTINE TrySelectDevice;
  114. PPARALLEL_DESELECT_ROUTINE DeselectDevice;
  115. PVOID Context;
  116. ULONG CurrentMode;
  117. PWSTR PortName;
  118. } PARALLEL_PNP_INFORMATION, *PPARALLEL_PNP_INFORMATION;
  119. typedef BOOLEAN
  120. (NTAPI *PPARALLEL_TRY_ALLOCATE_ROUTINE)(
  121. IN PVOID TryAllocateContext);
  122. typedef VOID
  123. (NTAPI *PPARALLEL_FREE_ROUTINE)(
  124. IN PVOID FreeContext);
  125. typedef ULONG
  126. (NTAPI *PPARALLEL_QUERY_WAITERS_ROUTINE)(
  127. IN PVOID QueryAllocsContext);
  128. typedef struct _PARALLEL_PORT_INFORMATION {
  129. PHYSICAL_ADDRESS OriginalController;
  130. PUCHAR Controller;
  131. ULONG SpanOfController;
  132. PPARALLEL_TRY_ALLOCATE_ROUTINE TryAllocatePort;
  133. PPARALLEL_FREE_ROUTINE FreePort;
  134. PPARALLEL_QUERY_WAITERS_ROUTINE QueryNumWaiters;
  135. PVOID Context;
  136. } PARALLEL_PORT_INFORMATION, *PPARALLEL_PORT_INFORMATION;
  137. /* PARALLEL_CHIP_MODE.ModeFlags */
  138. #define INITIAL_MODE 0x00
  139. #define PARCHIP_ECR_ARBITRATOR 0x01
  140. typedef struct _PARALLEL_CHIP_MODE {
  141. UCHAR ModeFlags;
  142. BOOLEAN success;
  143. } PARALLEL_CHIP_MODE, *PPARALLEL_CHIP_MODE;
  144. typedef VOID
  145. (NTAPI *PPARALLEL_DEFERRED_ROUTINE)(
  146. IN PVOID DeferredContext);
  147. typedef struct _PARALLEL_INTERRUPT_SERVICE_ROUTINE {
  148. PKSERVICE_ROUTINE InterruptServiceRoutine;
  149. PVOID InterruptServiceContext;
  150. PPARALLEL_DEFERRED_ROUTINE DeferredPortCheckRoutine;
  151. PVOID DeferredPortCheckContext;
  152. } PARALLEL_INTERRUPT_SERVICE_ROUTINE, *PPARALLEL_INTERRUPT_SERVICE_ROUTINE;
  153. #define IOCTL_INTERNAL_DISCONNECT_IDLE \
  154. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 32, METHOD_BUFFERED, FILE_ANY_ACCESS)
  155. #define IOCTL_INTERNAL_LOCK_PORT \
  156. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 37, METHOD_BUFFERED, FILE_ANY_ACCESS)
  157. #define IOCTL_INTERNAL_LOCK_PORT_NO_SELECT \
  158. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 52, METHOD_BUFFERED, FILE_ANY_ACCESS)
  159. #define IOCTL_INTERNAL_PARCLASS_CONNECT \
  160. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 30, METHOD_BUFFERED, FILE_ANY_ACCESS)
  161. #define IOCTL_INTERNAL_PARCLASS_DISCONNECT \
  162. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 31, METHOD_BUFFERED, FILE_ANY_ACCESS)
  163. #define IOCTL_INTERNAL_UNLOCK_PORT \
  164. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 38, METHOD_BUFFERED, FILE_ANY_ACCESS)
  165. #define IOCTL_INTERNAL_UNLOCK_PORT_NO_DESELECT \
  166. CTL_CODE (FILE_DEVICE_PARALLEL_PORT, 53, METHOD_BUFFERED, FILE_ANY_ACCESS)
  167. typedef USHORT
  168. (NTAPI *PDETERMINE_IEEE_MODES)(
  169. IN PVOID Context);
  170. typedef enum _PARALLEL_SAFETY {
  171. SAFE_MODE,
  172. UNSAFE_MODE
  173. } PARALLEL_SAFETY;
  174. typedef NTSTATUS
  175. (NTAPI *PNEGOTIATE_IEEE_MODE)(
  176. IN PVOID Context,
  177. IN USHORT ModeMaskFwd,
  178. IN USHORT ModeMaskRev,
  179. IN PARALLEL_SAFETY ModeSafety,
  180. IN BOOLEAN IsForward);
  181. typedef NTSTATUS
  182. (NTAPI *PTERMINATE_IEEE_MODE)(
  183. IN PVOID Context);
  184. typedef NTSTATUS
  185. (NTAPI *PPARALLEL_IEEE_FWD_TO_REV)(
  186. IN PVOID Context);
  187. typedef NTSTATUS
  188. (NTAPI *PPARALLEL_IEEE_REV_TO_FWD)(
  189. IN PVOID Context);
  190. typedef NTSTATUS
  191. (NTAPI *PPARALLEL_READ)(
  192. IN PVOID Context,
  193. OUT PVOID Buffer,
  194. IN ULONG NumBytesToRead,
  195. OUT PULONG NumBytesRead,
  196. IN UCHAR Channel);
  197. typedef NTSTATUS
  198. (NTAPI *PPARALLEL_WRITE)(
  199. IN PVOID Context,
  200. OUT PVOID Buffer,
  201. IN ULONG NumBytesToWrite,
  202. OUT PULONG NumBytesWritten,
  203. IN UCHAR Channel);
  204. typedef NTSTATUS
  205. (NTAPI *PPARALLEL_TRYSELECT_DEVICE)(
  206. IN PVOID Context,
  207. IN PARALLEL_1284_COMMAND Command);
  208. typedef NTSTATUS
  209. (NTAPI *PPARALLEL_DESELECT_DEVICE)(
  210. IN PVOID Context,
  211. IN PARALLEL_1284_COMMAND Command);
  212. typedef struct _PARCLASS_INFORMATION {
  213. PUCHAR Controller;
  214. PUCHAR EcrController;
  215. ULONG SpanOfController;
  216. PDETERMINE_IEEE_MODES DetermineIeeeModes;
  217. PNEGOTIATE_IEEE_MODE NegotiateIeeeMode;
  218. PTERMINATE_IEEE_MODE TerminateIeeeMode;
  219. PPARALLEL_IEEE_FWD_TO_REV IeeeFwdToRevMode;
  220. PPARALLEL_IEEE_REV_TO_FWD IeeeRevToFwdMode;
  221. PPARALLEL_READ ParallelRead;
  222. PPARALLEL_WRITE ParallelWrite;
  223. PVOID ParclassContext;
  224. ULONG HardwareCapabilities;
  225. ULONG FifoDepth;
  226. ULONG FifoWidth;
  227. PPARALLEL_TRYSELECT_DEVICE ParallelTryselect;
  228. PPARALLEL_DESELECT_DEVICE ParallelDeSelect;
  229. } PARCLASS_INFORMATION, *PPARCLASS_INFORMATION;
  230. #ifdef __cplusplus
  231. }
  232. #endif
  233. #endif /* __PARALLEL_H */