/*++ BUILD Version: 0002 // Increment this if a change has global effects Copyright (c) 1991 Microsoft Corporation Module Name: jazzserp.h ppcserp.h Abstract: This header file defines the Jazz serial port registers. Author: David N. Cutler (davec) 28-Apr-1991 Chuck Bauman 03-Jun-1993 Revision History: Modified SP_VIRTUAL_BASE and SERIAL2_PHYSICAL_BASE to use COM2 17-Aug-1993 */ //IBMJW #ifndef _PPCSERP_ #define _PPCSERP_ // BUGBUG Temporarily until next drop when registry support will be included. extern PVOID HalpEisaControlBase; #define COM1_PORT 0x3f8 #define COM2_PORT 0x2f8 // IBMCDB #define SP_VIRTUAL_BASE ((PSZ) HalpEisaControlBase+COM2_PORT)// IBMCDB #define SERIAL2_PHYSICAL_BASE EISA_CONTROL_PHYSICAL_BASE+COM2_PORT // IBMCDB // Define serial port read registers structure. typedef struct _SP_READ_REGISTERS { UCHAR ReceiveBuffer; UCHAR InterruptEnable; UCHAR InterruptId; UCHAR LineControl; UCHAR ModemControl; UCHAR LineStatus; UCHAR ModemStatus; UCHAR ScratchPad; } SP_READ_REGISTERS, *PSP_READ_REGISTERS; // Define define serial port write registers structure. typedef struct _SP_WRITE_REGISTERS { UCHAR TransmitBuffer; UCHAR InterruptEnable; UCHAR FifoControl; UCHAR LineControl; UCHAR ModemControl; UCHAR Reserved1; UCHAR ModemStatus; UCHAR ScratchPad; } SP_WRITE_REGISTERS, *PSP_WRITE_REGISTERS; // Define serial port interrupt enable register structure. typedef struct _SP_INTERRUPT_ENABLE { UCHAR ReceiveEnable : 1; UCHAR TransmitEnable : 1; UCHAR LineStatusEnable : 1; UCHAR ModemStatusEnable : 1; UCHAR Reserved1 : 4; } SP_INTERRUPT_ENABLE, *PSP_INTERRUPT_ENABLE; // Define serial port interrupt id register structure. typedef struct _SP_INTERRUPT_ID { UCHAR InterruptPending : 1; UCHAR Identification : 3; UCHAR Reserved1 : 2; UCHAR FifoEnabled : 2; } SP_INTERRUPT_ID, *PSP_INTERRUPT_ID; // Define serial port fifo control register structure. typedef struct _SP_FIFO_CONTROL { UCHAR FifoEnable : 1; UCHAR ReceiveFifoReset : 1; UCHAR TransmitFifoReset : 1; UCHAR DmaModeSelect : 1; UCHAR Reserved1 : 2; UCHAR ReceiveFifoLevel : 2; } SP_FIFO_CONTROL, *PSP_FIFO_CONTROL; // Define serial port line control register structure. typedef struct _SP_LINE_CONTROL { UCHAR CharacterSize : 2; UCHAR StopBits : 1; UCHAR ParityEnable : 1; UCHAR EvenParity : 1; UCHAR StickParity : 1; UCHAR SetBreak : 1; UCHAR DivisorLatch : 1; } SP_LINE_CONTROL, *PSP_LINE_CONTROL; // Line status register character size definitions. #define FIVE_BITS 0x0 // five bits per character #define SIX_BITS 0x1 // six bits per character #define SEVEN_BITS 0x2 // seven bits per character #define EIGHT_BITS 0x3 // eight bits per character // Line speed divisor definition. #define BAUD_RATE_9600 28 // divisor for 9600 baud #define BAUD_RATE_19200 14 // divisor for 19200 baud // Define serial port modem control register structure. typedef struct _SP_MODEM_CONTROL { UCHAR DataTerminalReady : 1; UCHAR RequestToSend : 1; UCHAR Reserved1 : 1; UCHAR Interrupt : 1; UCHAR loopBack : 1; UCHAR Reserved2 : 3; } SP_MODEM_CONTROL, *PSP_MODEM_CONTROL; // Define serial port line status register structure. typedef struct _SP_LINE_STATUS { UCHAR DataReady : 1; UCHAR OverrunError : 1; UCHAR ParityError : 1; UCHAR FramingError : 1; UCHAR BreakIndicator : 1; UCHAR TransmitHoldingEmpty : 1; UCHAR TransmitEmpty : 1; UCHAR ReceiveFifoError : 1; } SP_LINE_STATUS, *PSP_LINE_STATUS; // Define serial port modem status register structure. typedef struct _SP_MODEM_STATUS { UCHAR DeltaClearToSend : 1; UCHAR DeltaDataSetReady : 1; UCHAR TrailingRingIndicator : 1; UCHAR DeltaReceiveDetect : 1; UCHAR ClearToSend : 1; UCHAR DataSetReady : 1; UCHAR RingIndicator : 1; UCHAR ReceiveDetect : 1; } SP_MODEM_STATUS, *PSP_MODEM_STATUS; #endif // _JAZZSERP_