⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bvd_ser16550.h

📁 Xcale270Bsp包,wince平台
💻 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 + -