📄 ser16950.h
字号:
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
/*++
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) 1999 Socket Communications, Inc.
Module Name:
ser16950.h
Abstract:
Definitions for serial 16950 library
Notes:
--*/
#ifndef __SER16550_H__
#define __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 __PAIRS {
ULONG Key;
ULONG AssociatedValue;
} PAIRS, *PPAIRS;
typedef struct __LOOKUP_TBL {
ULONG Size;
PPAIRS Table;
} LOOKUP_TBL, *PLOOKUP_TBL;
typedef struct __QUADS {
ULONG Key;
ULONG AssociatedValue;
ULONG AssociatedValue2;
ULONG AssociatedValue3;
} QUAD, *PQUAD;
typedef struct __LOOKUP_TBL_4 {
ULONG Size;
PQUAD Table;
} LOOKUP_TBL_4, *PLOOKUP_TBL_4;
//
// @doc HWINTERNAL
// @struct LS_SERIAL_INFO | Passed to serial lib routines.
//
typedef struct __LS_SERIAL_INFO
{
// Store volatile pointers to each 16550 register
volatile PUCHAR pData; // @field RX data / Transmit Holding Reg
volatile PUCHAR pIER; // @field Interrupt Enable
volatile PUCHAR pIIR_FCR; // @field read IIR (Int ID) / Write FCR (FIFO Ctrl)
volatile PUCHAR pLCR; // @field Line Control
volatile PUCHAR pMCR; // @field Modem Control
volatile PUCHAR pLSR; // @field Line Status
volatile PUCHAR pMSR; // @field Modem Status
volatile PUCHAR pScratch; // @field Scratch Register
volatile PUCHAR pSPR; // @field SPR Register
volatile PUCHAR pICR; // @field ICR Register
volatile PUCHAR pEFR; // @field EFR Register
// And we keep shadows of many of the 16550 registers
UCHAR FCR; // @field FIFO control state.
UCHAR IIR; // @field State of Interrupt Identification Register.
UCHAR LSR; // @field Line Status Register.
UCHAR MSR; // @field Modem Status Register.
UCHAR IER; // @field Interrupt Enable Register.
UCHAR LCR; // @field Line Control Register.
UCHAR MCR; // @field Modem Control Register.
UCHAR Scratch; // @field Scratch Register.
UCHAR mimicACR; // Shadow of the 950 ACR register
BOOL ASRChanged; //
//
BOOL bSleepDisable; // Set sleep bits if false
ULONG RxFifoTrigger; // Default is 32
ULONG TxFifoTrigger; // Default is 1
// 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
// Fields added to support flow control on RING indicate modem stats line
BOOL RINGFlowOff; // Flag - RI flow control state
ULONG RIToggleCount; // Count of times RI changed
ULONG RIToggleTimeout;// Count of times has polled for RI
// Fields added to support SLIP packitizer from user application
BOOL SLIPStartOfPacket;
BOOL SLIPEndOfPacket;
BOOL SLIPEscapeFound;
// 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 TX FIFO from simultaneous access
ULONG ChipID; // @field Chip identifier (CHIP_ID_16550 or CHIP_ID_16450)
BYTE BaudClock; // Currently, 'normal' (0) and 20Mhz (20)supported
} SER16950_INFO, *PSER16950_INFO;
#define CHIP_ID_WENDY1 0xa5
// Wendy FIFO triggers, these correlate to the 16550 values
#define WENDY_HIGH_WATER_00 01 // 1 in 16550
#define WENDY_HIGH_WATER_01 128 // 4 in 16550
#define WENDY_HIGH_WATER_10 256 // 8 in 16550
#define WENDY_HIGH_WATER_11 384 // 14 in 16550
// Driver currently uses the 10 value (8 for 16550, 256 for Wendy)
// how full RX Fifo should be when RX interrupt should occurs
#define SERIAL_BYTE_RX_HIGH_WATER WENDY_HIGH_WATER_10
// how empty TX fifo shoudl be before TX interrupt occurs
#define SERIAL_BYTE_TX_LOW_WATER WENDY_HIGH_WATER_10
#define WENDY_FIFO_DEPTH 512
#define MCR_BAUD_PRESCALE 0x80
// 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 SL_Init(
PVOID pHead, // points to device head
PUCHAR pRegBase, // Pointer to 16550 register base
UINT8 RegStride, // Stride amongst the 16550 registers
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
);
VOID SL_Deinit(
PVOID pHead // points to device head
);
VOID SL_Open(
PVOID pHead
);
VOID SL_Close(
PVOID pHead
);
VOID SL_ClearDTR(
PVOID pHead
);
VOID SL_SetDTR(
PVOID pHead
);
VOID SL_ClearRTS(
PVOID pHead
);
VOID SL_SetRTS(
PVOID pHead
);
VOID SL_ClearBreak(
PVOID pHead
);
VOID SL_SetBreak(
PVOID pHead
);
VOID SL_ClearBreak(
PVOID pHead
);
VOID SL_SetBreak(
PVOID pHead
);
ULONG SL_GetByteNumber(
PVOID pHead
);
VOID SL_DisableXmit(
PVOID pHead
);
VOID SL_EnableXmit(
PVOID pHead
);
BOOL SL_SetBaudRate(
PVOID pHead,
ULONG BaudRate // ULONG representing decimal baud rate.
);
ULONG SL_SetDCB(
PVOID pHead,
LPDCB lpDCB // Pointer to DCB structure
);
ULONG SL_SetCommTimeouts(
PVOID pHead,
LPCOMMTIMEOUTS lpCommTimeouts // Pointer to CommTimeout structure
);
ULONG SL_GetRxBufferSize(
PVOID pHead
);
PVOID SL_GetRxStart(
PVOID pHead
);
INTERRUPT_TYPE SL_GetInterruptType(
PVOID pHead
);
ULONG SL_RxIntr(
PVOID pHead,
PUCHAR pRxBuffer, // Pointer to receive buffer
ULONG *pBufflen // In = max bytes to read, out = bytes read
);
ULONG SL_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 SL_TxIntr(
PVOID pHead
);
VOID SL_LineIntr(
PVOID pHead
);
VOID SL_OtherIntr(
PVOID pHead
);
ULONG SL_GetStatus(
PVOID pHead,
LPCOMSTAT lpStat // Pointer to LPCOMMSTAT to hold status.
);
VOID SL_Reset(
PVOID pHead
);
VOID SL_GetModemStatus(
PVOID pHead,
PULONG pModemStatus // PULONG passed in by user.
);
VOID SL_PurgeComm(
PVOID pHead,
DWORD fdwAction // Action to take.
);
BOOL SL_XmitComChar(
PVOID pHead,
UCHAR ComChar // Character to transmit.
);
VOID SL_PowerOn(
PVOID pHead
);
VOID SL_PowerOff(
PVOID pHead
);
BOOL SL_Ioctl(
PVOID pHead,
DWORD dwCode,
PBYTE pBufIn,
DWORD dwLenIn,
PBYTE pBufOut,
DWORD dwLenOut,
PDWORD pdwActualOut);
#ifdef __cplusplus
}
#endif
#endif __SER16550_H__
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -