📄 bvd_ser16550.h
字号:
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.
Copyright (c) 1995-2000 Microsoft Corporation. All rights reserved.
Module Name:
bvd_ser16550.h
Abstract:
Definitions for Bulverde's serial 16550 library
Notes:
--*/
#ifndef __BVD_SER16550_H__
#define __BVD_SER16550_H__
#ifdef __cplusplus
extern "C" {
#endif
// We use a callback for serial events
typedef VOID (*EVENT_FUNC)(PVOID Arg1, ULONG Arg2);
// The library has a default baud table, but this can be replaced
typedef struct __XSC1_PAIRS {
ULONG Key;
ULONG AssociatedValue;
} XSC1_PAIRS, *PXSC1_PAIRS;
typedef struct __LOOKUP_TBL {
ULONG Size;
PXSC1_PAIRS Table;
} LOOKUP_TBL, *PLOOKUP_TBL;
//
// @doc HWINTERNAL
// @struct LS_SERIAL_INFO | Passed to serial lib routines.
//
typedef struct __LS_SERIAL_INFO
{
//Even though Cotulla UART registers are 32 bit, only the least significant byte is used
//The other three bytes are reserved. But still, we do 32 bit reads/writes.
volatile PULONG pTHR_RBR_DLL; // @field DLAB = 0 WO 32bit - Transmit Holding Register (THR)
// @field DLAB = 0 RO 32bit - Recieve Buffer Register (RBR)
// @field DLAB = 1 RW 32bit - Divisor Latch Low Register (DLL)
volatile PULONG pIER_DLH; // @field DLAB = 0 RW 32bit - Interrupt Enable Register
// @field DLAB = 1 RW 32bit - Divisor Latch High Register (DLH)
volatile PULONG pIIR_FCR; // @field DLAB = X RO 32bit - Interrupt Identification Register
// @field DLAB = X WO 32bit - FIFO Control Register
volatile PULONG pLCR; // @field DLAB = X RW 32bit - Line Control Register
volatile PULONG pMCR; // @field DLAB = X RW 32bit - Modem Control Regiser
volatile PULONG pLSR; // @field DLAB = X RO 32bit - Line Status Register
volatile PULONG pMSR; // @field DLAB = X RO 32bit - Modem Status Register
volatile PULONG pSCR; // @field DLAB = X RW 32bit - Scratchpad Register
volatile PULONG pIRDASEL; // @field DLAB = X RW 32bit - IrDA Select Register
volatile PULONG pFOR; // @field DLAB = X RO 32bit - FIFO Occupancy Register
volatile PULONG pABR; // @field DLAB = X RW 32bit - Autobaud Control Register
volatile PULONG pACR; // @field DLAB = X 32bit - Autobaud Count Register
BOOL bIr; // @field device running in normal serial mode or IR mode
BOOL PowerDownFlag; // @field whether device is powered down or not
// And we keep shadows of many of the Cotulla UART registers
ULONG FCR; // @field FIFO control state.
ULONG IIR; // @field State of Interrupt Identification Register.
ULONG LSR; // @field Line Status Register.
ULONG MSR; // @field Modem Status Register.
// We wouldn't normally shadow these, except for power on/off
ULONG IER; // @field Interrupt Enable Register.
ULONG LCR; // @field Line Control Register.
ULONG MCR; // @field Modem Control Register.
ULONG SCR; // @field Scratch Register.
ULONG IRDASEL; // @field Infrared Selection Register.
ULONG FOR; // @field FIFO Occupancy Register
ULONG ABR; // @field Autobaud Control Register
ULONG ACR; // @field Autobaud Count Register
// We have an event callback into the MDD
EVENT_FUNC EventCallback; // This callback exists in MDD
PVOID pMddHead; // This is the first parm to callback
// Keep a copy of DCB since we rely on may of its parms
DCB dcb; // @field Device Control Block (copy of DCB in MDD)
// And the same thing applies for CommTimeouts
COMMTIMEOUTS CommTimeouts; // @field Copy of CommTimeouts structure
// Misc fields used by ser16550 library
ULONG OpenCount; // @field Count of simultaneous opens.
PLOOKUP_TBL pBaudTable; // @field Pointer to Baud Table
ULONG DroppedBytes; // @field Number of dropped bytes
HANDLE FlushDone; // @field Handle to flush done event.
BOOL CTSFlowOff; // @field Flag - CTS flow control state.
BOOL DSRFlowOff; // @field Flag - DSR flow control state.
BOOL AddTXIntr; // @field Flag - Fake a TX intr.
COMSTAT Status; // @field Bitfield representing Win32 comm status.
ULONG CommErrors; // @field Bitfield representing Win32 comm error status.
ULONG ModemStatus; // @field Bitfield representing Win32 modem status.
CRITICAL_SECTION TransmitCritSec; // @field Protects UART Registers for non-atomic accesses
CRITICAL_SECTION RegCritSec; // @field Protects UART
ULONG ChipID; // @field Chip identifier (CHIP_ID_COTULLA or CHIP_ID_16550 or CHIP_ID_16450)
DWORD IOBase; // @field IO Base Address - unmapped (to find out which UART is it)
UINT BLR; // @field Board level register
volatile XLLP_GPIO_T *pGPIOReg; // @field for configuring GPIO pins
//volatile GPIO_REGS *pGPIOReg; // @field for configuring GPIO pins
volatile XLLP_CLKMGR_T *pClkMgrReg; // @field for configuring clk mgr
//volatile BLR_REGS *pBLRReg; // @field for board specific stuff
volatile XLLP_BCR_T *pBCRReg; // @field for board specific stuff
} SER16550_INFO, *PSER16550_INFO;
// Values for SER16550_INFO.ChipID
#define CHIP_ID_16550 1
#define CHIP_ID_16450 2
#define CHIP_ID_COTULLA 4
#define CHIP_ID_BULVERDE 8
// Here is the callback for serial events
typedef VOID (*PFN_SER_EVENT) (
PVOID pHandle, // PHW_INDEP_INFO, but pdd doesn't know it
UINT32 events // What events where encountered?
);
// And now, all the function prototypes
VOID HW_XSC1_Init(
PVOID pHead, // points to device head
PULONG pRegBase, // Pointer to 16550 register base
UINT32 RegStride, // Stride amongst the 16550 registers
DWORD IoBase, // IO Base Address
volatile XLLP_GPIO_T *pGPIOReg, // @field for configuring GPIO pins
volatile XLLP_CLKMGR_T *pClkMgrReg, // @field for configuring clk mgr
volatile XLLP_BCR_T *pBCRReg, // @field for board specific stuff
EVENT_FUNC EventCallback, // This callback exists in MDD
PVOID pMddHead, // This is the first parm to callback
PLOOKUP_TBL pBaudTable // Pointer to baud rate table
);
BOOL HW_XSC1_PostInit(
PVOID pHead
);
VOID HW_XSC1_Deinit(
PVOID pHead // points to device head
);
VOID HW_XSC1_Open(
PVOID pHead
);
VOID HW_XSC1_Close(
PVOID pHead
);
VOID HW_XSC1_ClearDTR(
PVOID pHead
);
VOID HW_XSC1_SetDTR(
PVOID pHead
);
VOID HW_XSC1_ClearRTS(
PVOID pHead
);
VOID HW_XSC1_SetRTS(
PVOID pHead
);
VOID HW_XSC1_ClearBreak(
PVOID pHead
);
VOID HW_XSC1_SetBreak(
PVOID pHead
);
VOID HW_XSC1_ClearBreak(
PVOID pHead
);
VOID HW_XSC1_SetBreak(
PVOID pHead
);
ULONG HW_XSC1_GetByteNumber(
PVOID pHead
);
VOID HW_XSC1_DisableXmit(
PVOID pHead
);
VOID HW_XSC1_EnableXmit(
PVOID pHead
);
BOOL HW_XSC1_SetBaudRate(
PVOID pHead,
ULONG BaudRate // ULONG representing decimal baud rate.
);
BOOL HW_XSC1_SetDCB(
PVOID pHead,
LPDCB lpDCB // Pointer to DCB structure
);
ULONG HW_XSC1_SetCommTimeouts(
PVOID pHead,
LPCOMMTIMEOUTS lpCommTimeouts // Pointer to CommTimeout structure
);
ULONG HW_XSC1_GetRxBufferSize(
PVOID pHead
);
PVOID HW_XSC1_GetRxStart(
PVOID pHead
);
INTERRUPT_TYPE HW_XSC1_GetInterruptType(
PVOID pHead
);
ULONG HW_XSC1_RxIntr(
PVOID pHead,
PUCHAR pRxBuffer, // Pointer to receive buffer
ULONG *pBufflen // In = max bytes to read, out = bytes read
);
ULONG HW_XSC1_PutBytes(
PVOID pHead,
PUCHAR pSrc, // Pointer to bytes to be sent.
ULONG NumberOfBytes, // Number of bytes to be sent.
PULONG pBytesSent // Pointer to actual number of bytes put.
);
VOID HW_XSC1_TxIntr(
PVOID pHead
);
VOID HW_XSC1_LineIntr(
PVOID pHead
);
VOID HW_XSC1_OtherIntr(
PVOID pHead
);
VOID HW_XSC1_ModemIntr(
PVOID pHead
);
ULONG HW_XSC1_GetStatus(
PVOID pHead,
LPCOMSTAT lpStat // Pointer to LPCOMMSTAT to hold status.
);
VOID HW_XSC1_Reset(
PVOID pHead
);
VOID HW_XSC1_GetModemStatus(
PVOID pHead,
PULONG pModemStatus // PULONG passed in by user.
);
VOID HW_XSC1_PurgeComm(
PVOID pHead,
DWORD fdwAction // Action to take.
);
BOOL HW_XSC1_XmitComChar(
PVOID pHead,
UCHAR ComChar // Character to transmit.
);
VOID HW_XSC1_PowerOn(
PVOID pHead
);
VOID HW_XSC1_PowerOff(
PVOID pHead
);
BOOL HW_XSC1_Ioctl(
PVOID pHead,
DWORD dwCode,
PBYTE pBufIn,
DWORD dwLenIn,
PBYTE pBufOut,
DWORD dwLenOut,
PDWORD pdwActualOut);
VOID HW_XSC1_TxIntrEx(
PVOID pHead,
PUCHAR pTxBuffer, // @parm Pointer to receive buffer
ULONG *pBufflen // @parm In = max bytes to transmit, out = bytes transmitted
);
VOID HW_XSC1_Enable_Uart_IR(
PVOID pHead,
BOOL EnableUart
); // Hardware Head
BOOL HW_XSC1_TransmitterBusy(
PVOID pHead
);
void HW_XSC1_Enable_IR_Rx_Tx(
PVOID pHead,
BOOL Rxenable,
BOOL Txenable
);
void HW_XSC1_Enable_IR_Tx(
PVOID pHead,
BOOL enable
);
void HW_XSC1_Enable_IR_Rx(
PVOID pHead,
BOOL enable
);
#ifdef __cplusplus
}
#endif
#endif __BVD_SER16550_H__
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -