179 lines
4.1 KiB
C
Raw Normal View History

2001-01-01 00:00:00 +01:00
/*++ 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_