165 lines
5.8 KiB
C
165 lines
5.8 KiB
C
/*++ 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 <ntddpar.h> in precompiled header
|
|
// #include <initguid.h> in a single source file
|
|
// #include <ntddpar.h> 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_
|