/* * Routines to access hardware * * Copyright (c) 2013 Realtek Semiconductor Corp. * * This module is a confidential and proprietary property of RealTek and * possession or use of this module requires written permission of RealTek. */ #ifndef _HAL_UART_H_ #define _HAL_UART_H_ #include "rtl8195a_uart.h" /** * RUART Configurations */ #define UART_WAIT_FOREVER 0xffffffff #define UART_DMA_MBLK_NUM 16 // maximum block number for each DMA transfer, it must <= 16 #define UART_DMA_BLOCK_SIZE 4092 // the block size of multiple block DMA, it cann0t over 4095 typedef struct _HAL_UART_DMA_MULTIBLK_ { volatile GDMA_CH_LLI_ELE GdmaChLli[UART_DMA_MBLK_NUM]; struct GDMA_CH_LLI Lli[UART_DMA_MBLK_NUM]; struct BLOCK_SIZE_LIST BlockSizeList[UART_DMA_MBLK_NUM]; }UART_DMA_MULTIBLK, *PUART_DMA_MULTIBLK; typedef struct _UART_DMA_CONFIG_ { u8 TxDmaEnable; u8 RxDmaEnable; u8 TxDmaBurstSize; u8 RxDmaBurstSize; VOID *pHalGdmaOp; VOID *pTxHalGdmaAdapter; VOID *pRxHalGdmaAdapter; IRQ_HANDLE TxGdmaIrqHandle; IRQ_HANDLE RxGdmaIrqHandle; #if defined(E_CUT_ROM_DOMAIN) || (!defined(CONFIG_RELEASE_BUILD_LIBRARIES)) UART_DMA_MULTIBLK *pTxDmaBlkList; // point to multi-block list UART_DMA_MULTIBLK *pRxDmaBlkList; // point to multi-block list u8 TxDmaMBChnl; // is using DMA multiple block channel u8 RxDmaMBChnl; // is using DMA multiple block channel #endif }UART_DMA_CONFIG, *PUART_DMA_CONFIG; typedef struct _HAL_RUART_ADAPTER_ { u32 BaudRate; //+0 u32 FlowControl; //+4 u32 FifoControl; //+8 u32 Interrupts; //+12 u32 TxCount; //+16 how many byte to TX u32 RxCount; //+20 how many bytes to RX u8 *pTxBuf; //+24 u8 *pRxBuf; //+28 HAL_UART_State State; //+32 UART state u8 Status; //+36 Transfer Status u8 Locked; //+37 is UART locked for operation u8 UartIndex; //+38 u8 WordLen; //+39 word length select: 0 -> 7 bits, 1 -> 8 bits u8 StopBit; //+40 word length select: 0 -> 1 stop bit, 1 -> 2 stop bit u8 Parity; //+41 parity check enable u8 ParityType; //+42 parity check type u8 StickParity; //+43 u8 ModemStatus; //+44 the modem status u8 DmaEnable; u8 TestCaseNumber; u8 PinmuxSelect; BOOL PullMode; IRQ_HANDLE IrqHandle; PUART_DMA_CONFIG DmaConfig; VOID (*ModemStatusInd)(VOID *pAdapter); //+72 modem status indication interrupt handler VOID (*TxTDCallback)(VOID *pAdapter); //+76 User Tx Done callback function VOID (*RxDRCallback)(VOID *pAdapter); //+80 User Rx Data ready callback function VOID (*TxCompCallback)(VOID *para); //+84 User Tx complete callback function VOID (*RxCompCallback)(VOID *para); //+88 User Rx complete callback function VOID *TxTDCbPara; // the pointer agrument for TxTDCallback VOID *RxDRCbPara; // the pointer agrument for RxDRCallback VOID *TxCompCbPara; // the pointer argument for TxCompCbPara VOID *RxCompCbPara; // the pointer argument for RxCompCallback VOID (*EnterCritical)(void); VOID (*ExitCritical)(void); #if defined(E_CUT_ROM_DOMAIN) || (!defined(CONFIG_RELEASE_BUILD_LIBRARIES)) //1 New member only can be added below: members above must be fixed for ROM code u32 *pDefaultBaudRateTbl; // point to the table of pre-defined baud rate u8 *pDefaultOvsrRTbl; // point to the table of OVSR for pre-defined baud rate u16 *pDefaultDivTbl; // point to the table of DIV for pre-defined baud rate u8 *pDefOvsrAdjBitTbl_10; // point to the table of OVSR-Adj bits for 10 bits u8 *pDefOvsrAdjBitTbl_9; // point to the table of OVSR-Adj bits for 9 bits u8 *pDefOvsrAdjBitTbl_8; // point to the table of OVSR-Adj bits for 8 bits u16 *pDefOvsrAdjTbl_10; // point to the table of OVSR-Adj for pre-defined baud rate u16 *pDefOvsrAdjTbl_9; // point to the table of OVSR-Adj for pre-defined baud rate u16 *pDefOvsrAdjTbl_8; // point to the table of OVSR-Adj for pre-defined baud rate PUART_DMA_MULTIBLK pTxDMAMBlk; // point to the Link List Table of the DMA Multiple Block PUART_DMA_MULTIBLK pRxDMAMBlk; // point to the Link List Table of the DMA Multiple Block u32 BaudRateUsing; // Current using Baud-Rate u8 WordLenUsing; // Current using Word Length u8 ParityUsing; // Current using Parity check u8 RTSCtrl; // Software RTS Control #if 0//CONFIG_CHIP_E_CUT u8 TxState; u8 RxState; u32 TxInitSize; // how many byte to TX at atart u32 RxInitSize; // how many bytes to RX at start VOID (*RuartEnterCritical)(VOID *para); // enter critical: disable UART interrupt VOID (*RuartExitCritical)(VOID *para); // exit critical: re-enable UART interrupt VOID (*TaskYield)(VOID *para); // User Task Yield: do a context switch while waitting VOID *TaskYieldPara; // the agrument (pointer) for TaskYield #endif // #if CONFIG_CHIP_E_CUT #endif }HAL_RUART_ADAPTER, *PHAL_RUART_ADAPTER; typedef struct _HAL_RUART_OP_ { VOID (*HalRuartAdapterLoadDef)(VOID *pAdp, u8 UartIdx); // Load UART adapter default setting VOID (*HalRuartTxGdmaLoadDef)(VOID *pAdp, VOID *pCfg); // Load TX GDMA default setting VOID (*HalRuartRxGdmaLoadDef)(VOID *pAdp, VOID *pCfg); // Load RX GDMA default setting HAL_Status (*HalRuartResetRxFifo)(VOID *Data); HAL_Status (*HalRuartInit)(VOID *Data); VOID (*HalRuartDeInit)(VOID *Data); HAL_Status (*HalRuartPutC)(VOID *Data, u8 TxData); u32 (*HalRuartSend)(VOID *Data, u8 *pTxData, u32 Length, u32 Timeout); HAL_Status (*HalRuartIntSend)(VOID *Data, u8 *pTxData, u32 Length); HAL_Status (*HalRuartDmaSend)(VOID *Data, u8 *pTxData, u32 Length); HAL_Status (*HalRuartStopSend)(VOID *Data); HAL_Status (*HalRuartGetC)(VOID *Data, u8 *pRxByte); u32 (*HalRuartRecv)(VOID *Data, u8 *pRxData, u32 Length, u32 Timeout); HAL_Status (*HalRuartIntRecv)(VOID *Data, u8 *pRxData, u32 Length); HAL_Status (*HalRuartDmaRecv)(VOID *Data, u8 *pRxData, u32 Length); HAL_Status (*HalRuartStopRecv)(VOID *Data); u8 (*HalRuartGetIMR)(VOID *Data); VOID (*HalRuartSetIMR)(VOID *Data); u32 (*HalRuartGetDebugValue)(VOID *Data, u32 DbgSel); VOID (*HalRuartDmaInit)(VOID *Data); VOID (*HalRuartRTSCtrl)(VOID *Data, BOOLEAN RtsCtrl); VOID (*HalRuartRegIrq)(VOID *Data); VOID (*HalRuartIntEnable)(VOID *Data); VOID (*HalRuartIntDisable)(VOID *Data); }HAL_RUART_OP, *PHAL_RUART_OP; typedef struct _RUART_DATA_ { PHAL_RUART_ADAPTER pHalRuartAdapter; BOOL PullMode; u8 BinaryData; u8 SendBuffer; u8 RecvBuffer; }RUART_DATA, *PRUART_DATA; typedef struct _RUART_ADAPTER_ { PHAL_RUART_OP pHalRuartOp; PHAL_RUART_ADAPTER pHalRuartAdapter; PUART_DMA_CONFIG pHalRuartDmaCfg; }RUART_ADAPTER, *PRUART_ADAPTER; extern VOID HalRuartOpInit( IN VOID *Data ); extern HAL_Status HalRuartTxGdmaInit( PHAL_RUART_ADAPTER pHalRuartAdapter, PUART_DMA_CONFIG pUartGdmaConfig, u8 IsMultiBlk ); extern VOID HalRuartTxGdmaDeInit( PUART_DMA_CONFIG pUartGdmaConfig ); extern HAL_Status HalRuartRxGdmaInit( PHAL_RUART_ADAPTER pHalRuartAdapter, PUART_DMA_CONFIG pUartGdmaConfig, u8 IsMultiBlk ); extern VOID HalRuartRxGdmaDeInit( PUART_DMA_CONFIG pUartGdmaConfig ); extern HAL_Status HalRuartResetTxFifo( VOID *Data ); extern HAL_Status HalRuartResetTRxFifo(IN VOID *Data); extern HAL_Status HalRuartResetRxFifo( IN VOID *Data ); extern HAL_Status HalRuartSetBaudRate( IN VOID *Data ); extern HAL_Status HalRuartInit( IN VOID *Data ); extern VOID HalRuartDeInit( IN VOID *Data ); extern HAL_Status HalRuartDisable( IN VOID *Data ); extern HAL_Status HalRuartEnable( IN VOID *Data ); HAL_Status HalRuartFlowCtrl( IN VOID *Data ); VOID HalRuartEnterCritical( IN VOID *Data ); VOID HalRuartExitCritical( IN VOID *Data ); HAL_Status HalRuartDmaSend( IN VOID *Data, IN u8 *pTxBuf, IN u32 Length ); HAL_Status HalRuartDmaRecv( IN VOID *Data, IN u8 *pRxBuf, IN u32 Length ); extern const HAL_RUART_OP _HalRuartOp; extern HAL_Status RuartLock (PHAL_RUART_ADAPTER pHalRuartAdapter); extern VOID RuartUnLock (PHAL_RUART_ADAPTER pHalRuartAdapter); #endif