/*++ BUILD Version: 0001 // Increment this if a change has global effects Copyright (c) Microsoft Corporation. All rights reserved. Module Name: ntddpar.h Abstract: This is the include file that defines all constants and types for accessing the Parallel device. Author: Steve Wood (stevewo) 27-May-1990 Revision History: --*/ // // Interface GUID // // // need these GUIDs outside conditional includes so that user can // #include in precompiled header // #include in a single source file // #include in that source file a second time to instantiate the GUIDs // // #ifdef WANT_WDM #ifndef FAR #define FAR #endif #ifdef DEFINE_GUID DEFINE_GUID(GUID_DEVINTERFACE_PARALLEL, 0x97F76EF0, 0xF883, 0x11D0, 0xAF, 0x1F, 0x00, 0x00, 0xF8, 0x00, 0x84, 0x5C); DEFINE_GUID(GUID_DEVINTERFACE_PARCLASS, 0x811FC6A5, 0xF728, 0x11D0, 0xA5, 0x37, 0x00, 0x00, 0xF8, 0x75, 0x3E, 0xD1); // // Obsolete device interface class GUID names. // (use of above GUID_DEVINTERFACE_* names is recommended). // #define GUID_PARALLEL_DEVICE GUID_DEVINTERFACE_PARALLEL #define GUID_PARCLASS_DEVICE GUID_DEVINTERFACE_PARCLASS #endif // #endif #ifndef _NTDDPAR_ #define _NTDDPAR_ #ifdef __cplusplus extern "C" { #endif // // NtDeviceIoControlFile IoControlCode values for this device. // // Warning: Remember that the low two bits of the code specify how the // buffers are passed to the driver! // #define IOCTL_PAR_BASE FILE_DEVICE_PARALLEL_PORT #define IOCTL_PAR_QUERY_INFORMATION CTL_CODE(FILE_DEVICE_PARALLEL_PORT,1,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_PAR_SET_INFORMATION CTL_CODE(FILE_DEVICE_PARALLEL_PORT,2,METHOD_BUFFERED,FILE_ANY_ACCESS) // // Returns NULL terminated device ID string // #define IOCTL_PAR_QUERY_DEVICE_ID CTL_CODE(FILE_DEVICE_PARALLEL_PORT,3,METHOD_BUFFERED,FILE_ANY_ACCESS) // // Returns buffer size required for a call to IOCTL_PAR_QUERY_DEVICE_ID // to succeed. This includes device ID size plus space for terminating NULL. // #define IOCTL_PAR_QUERY_DEVICE_ID_SIZE CTL_CODE(FILE_DEVICE_PARALLEL_PORT,4,METHOD_BUFFERED,FILE_ANY_ACCESS) #define IOCTL_IEEE1284_GET_MODE CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 5, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_IEEE1284_NEGOTIATE CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 6, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_SET_WRITE_ADDRESS CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 7, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_SET_READ_ADDRESS CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 8, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_GET_DEVICE_CAPS CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 9, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_GET_DEFAULT_MODES CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 10, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_PING CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 11, METHOD_BUFFERED, FILE_ANY_ACCESS) // // Similar to IOCTL_PAR_QUERY_DEVICE_ID above, but includes (i.e., does // not discard) the two byte size prefix returned by the device. // #define IOCTL_PAR_QUERY_RAW_DEVICE_ID CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 12, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_ECP_HOST_RECOVERY CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 13, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_GET_READ_ADDRESS CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 14, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_GET_WRITE_ADDRESS CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 15, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_TEST CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 20, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_PAR_IS_PORT_FREE CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 21, METHOD_BUFFERED, FILE_ANY_ACCESS) // returns Location of the port - generally of the form: LPTx or LPTx.y or LPTx.y-z #define IOCTL_PAR_QUERY_LOCATION CTL_CODE(FILE_DEVICE_PARALLEL_PORT, 22, METHOD_BUFFERED, FILE_ANY_ACCESS) // // NtDeviceIoControlFile InputBuffer/OutputBuffer record structures for // this device. // typedef struct _PAR_QUERY_INFORMATION{ UCHAR Status; } PAR_QUERY_INFORMATION, *PPAR_QUERY_INFORMATION; typedef struct _PAR_SET_INFORMATION{ UCHAR Init; } PAR_SET_INFORMATION, *PPAR_SET_INFORMATION; #define PARALLEL_INIT 0x1 #define PARALLEL_AUTOFEED 0x2 #define PARALLEL_PAPER_EMPTY 0x4 #define PARALLEL_OFF_LINE 0x8 #define PARALLEL_POWER_OFF 0x10 #define PARALLEL_NOT_CONNECTED 0x20 #define PARALLEL_BUSY 0x40 #define PARALLEL_SELECTED 0x80 // // This is the structure returned by IOCTL_PAR_QUERY_DEVICE_ID_SIZE. // typedef struct _PAR_DEVICE_ID_SIZE_INFORMATION { ULONG DeviceIdSize; } PAR_DEVICE_ID_SIZE_INFORMATION, *PPAR_DEVICE_ID_SIZE_INFORMATION; // // These constants are used to construct the mask for the negotiation IOCTL. // These need to be moved to ntddpar.h so that they are available to User Mode... // IOCTL_INTERNAL_IEEE1284_NEGOTIATE. // typedef struct _PARCLASS_NEGOTIATION_MASK { USHORT usReadMask; USHORT usWriteMask; } PARCLASS_NEGOTIATION_MASK, *PPARCLASS_NEGOTIATION_MASK; #define NONE 0x0000 #define CENTRONICS 0x0001 /* Write Only */ #define IEEE_COMPATIBILITY 0x0002 /* Write Only */ #define NIBBLE 0x0004 /* Read Only */ #define CHANNEL_NIBBLE 0x0008 /* Read Only */ #define BYTE_BIDIR 0x0010 /* Read Only */ #define EPP_HW 0x0020 #define EPP_SW 0x0040 #define EPP_ANY 0x0060 #define BOUNDED_ECP 0x0080 #define ECP_HW_NOIRQ 0x0100 /* HWECP PIO */ #define ECP_HW_IRQ 0x0200 /* HWECP with IRQ */ #define ECP_SW 0x0400 #define ECP_ANY 0x0780 #ifdef __cplusplus } #endif #endif // _NTDDPAR_