 |
AM263x MCU+ SDK
11.00.00
|
|
Go to the documentation of this file.
56 #include <drivers/hw_include/cslr.h>
57 #include <drivers/hw_include/cslr_uart.h>
58 #include <drivers/hw_include/hw_types.h>
59 #include <drivers/uart/v0/lld/dma/uart_dma.h>
70 #define UART_FIFO_SIZE (64U)
77 #define UART_TRANSMITEMPTY_TRIALCOUNT (3000U)
80 #define UART_ERROR_COUNT (0x00FFFFFFU)
91 #define UART_STATUS_SUCCESS ((int32_t)0)
93 #define UART_STATUS_FAILURE ((int32_t)-1)
95 #define UART_TRANSFER_STATUS_SUCCESS ((int32_t)0)
97 #define UART_TRANSFER_STATUS_FAILURE ((int32_t)-1)
103 #define UART_WAIT_FOREVER ((int32_t)-1)
107 #define UART_INVALID_PARAM ((int32_t)-3)
112 #define UART_TRANSFER_BUSY ((int32_t)-4)
118 #define UART_TRANSFER_TIMEOUT ((int32_t)-2)
124 #define UART_TRANSFER_INVALID_STATE ((int32_t)-5)
126 #define UART_TRANSFER_STATUS_TIMEOUT (1U)
128 #define UART_TRANSFER_STATUS_ERROR_BI (2U)
130 #define UART_TRANSFER_STATUS_ERROR_FE (3U)
132 #define UART_TRANSFER_STATUS_ERROR_PE (4U)
134 #define UART_TRANSFER_STATUS_ERROR_OE (5U)
136 #define UART_TRANSFER_STATUS_CANCELLED (6U)
138 #define UART_TRANSFER_STATUS_STARTED (7U)
140 #define UART_TRANSFER_STATUS_READ_TIMEOUT (8U)
142 #define UART_TRANSFER_STATUS_ERROR_INUSE (9U)
144 #define UART_TRANSFER_STATUS_ERROR_OTH (10U)
167 #define UART_READ_RETURN_MODE_FULL (0U)
171 #define UART_READ_RETURN_MODE_PARTIAL (1U)
182 #define UART_LEN_5 (0U)
183 #define UART_LEN_6 (1U)
184 #define UART_LEN_7 (2U)
185 #define UART_LEN_8 (3U)
196 #define UART_STATE_RESET (0U)
197 #define UART_STATE_READY (1U)
198 #define UART_STATE_BUSY (2U)
199 #define UART_STATE_ERROR (3U)
205 #define UART_NOT_IN_USE(x) (void) 0
214 #define UART_STOPBITS_1 (0U)
215 #define UART_STOPBITS_2 (1U)
216 #define UART_STOPBITS_1P5 (UART_STOPBITS_1)
227 #define UART_PARITY_NONE (0x00U)
228 #define UART_PARITY_ODD (0x01U)
229 #define UART_PARITY_EVEN (0x03U)
230 #define UART_PARITY_FORCED0 (0x07U)
231 #define UART_PARITY_FORCED1 (0x05U)
242 #define UART_FCTYPE_NONE (0x00U)
243 #define UART_FCTYPE_HW (0x02U)
254 #define UART_FCPARAM_RXNONE (0x00U)
255 #define UART_FCPARAM_RXXONXOFF_2 (0x01U)
256 #define UART_FCPARAM_RXXONXOFF_1 (0x02U)
257 #define UART_FCPARAM_RXXONXOFF_12 (0x03U)
258 #define UART_FCPARAM_AUTO_RTS (0x40U)
269 #define UART_FCPARAM_TXNONE (0x00U)
270 #define UART_FCPARAM_TXXONXOFF_2 (0x04U)
271 #define UART_FCPARAM_TXXONXOFF_1 (0x08U)
272 #define UART_FCPARAM_TXXONXOFF_12 (0x0CU)
273 #define UART_FCPARAM_AUTO_CTS (0x80U)
284 #define UART_RXTRIGLVL_1 (1U)
285 #define UART_RXTRIGLVL_8 (8U)
286 #define UART_RXTRIGLVL_16 (16U)
287 #define UART_RXTRIGLVL_56 (56U)
288 #define UART_RXTRIGLVL_60 (60U)
299 #define UART_TXTRIGLVL_1 (1U)
300 #define UART_TXTRIGLVL_8 (8U)
301 #define UART_TXTRIGLVL_16 (16U)
302 #define UART_TXTRIGLVL_32 (32U)
303 #define UART_TXTRIGLVL_56 (56U)
314 #define UART_OPER_MODE_16X (0U)
315 #define UART_OPER_MODE_SIR (1U)
316 #define UART_OPER_MODE_16X_AUTO_BAUD (2U)
317 #define UART_OPER_MODE_13X (3U)
318 #define UART_OPER_MODE_MIR (4U)
319 #define UART_OPER_MODE_FIR (5U)
320 #define UART_OPER_MODE_CIR (6U)
321 #define UART_OPER_MODE_DISABLED (7U)
333 #define UART_TX_FIFO_NOT_FULL ( \
334 UART_SSR_TX_FIFO_FULL_TX_FIFO_FULL_VALUE_0)
335 #define UART_TX_FIFO_FULL ( \
336 UART_SSR_TX_FIFO_FULL_TX_FIFO_FULL_VALUE_1)
347 #define UART_INTID_MODEM_STAT (UART_IIR_IT_TYPE_IT_TYPE_VALUE_0 \
349 UART_IIR_IT_TYPE_SHIFT)
350 #define UART_INTID_TX_THRES_REACH (UART_IIR_IT_TYPE_IT_TYPE_VALUE_1 \
352 UART_IIR_IT_TYPE_SHIFT)
353 #define UART_INTID_RX_THRES_REACH (UART_IIR_IT_TYPE_IT_TYPE_VALUE_2 \
355 UART_IIR_IT_TYPE_SHIFT)
356 #define UART_INTID_RX_LINE_STAT_ERROR (UART_IIR_IT_TYPE_IT_TYPE_VALUE_3 \
358 UART_IIR_IT_TYPE_SHIFT)
359 #define UART_INTID_CHAR_TIMEOUT (UART_IIR_IT_TYPE_IT_TYPE_VALUE_6 \
361 UART_IIR_IT_TYPE_SHIFT)
362 #define UART_INTID_XOFF_SPEC_CHAR_DETECT (UART_IIR_IT_TYPE_IT_TYPE_VALUE_8 \
364 UART_IIR_IT_TYPE_SHIFT)
365 #define UART_INTID_MODEM_SIG_STATE_CHANGE (UART_IIR_IT_TYPE_IT_TYPE_VALUE_10 \
367 UART_IIR_IT_TYPE_SHIFT)
370 #define UART_INTR_PENDING (0U)
371 #define UART_N0_INTR_PENDING (1U)
381 #define UART_INTR_CTS (UART_IER_CTS_IT_MASK)
382 #define UART_INTR_RTS (UART_IER_RTS_IT_MASK)
383 #define UART_INTR_XOFF (UART_IER_XOFF_IT_MASK)
384 #define UART_INTR_SLEEPMODE (UART_IER_SLEEP_MODE_MASK)
385 #define UART_INTR_MODEM_STAT (UART_IER_MODEM_STS_IT_MASK)
386 #define UART_INTR_LINE_STAT (UART_IER_LINE_STS_IT_MASK)
387 #define UART_INTR_THR (UART_IER_THR_IT_MASK)
388 #define UART_INTR_RHR_CTI (UART_IER_RHR_IT_MASK)
390 #define UART_INTR2_RX_EMPTY (UART_IER2_EN_RXFIFO_EMPTY_MASK)
391 #define UART_INTR2_TX_EMPTY (UART_IER2_EN_TXFIFO_EMPTY_MASK)
401 #define UART_FIFO_PE_FE_BI_DETECTED (UART_LSR_RX_FIFO_STS_MASK)
402 #define UART_BREAK_DETECTED_ERROR (UART_LSR_RX_BI_MASK)
403 #define UART_FRAMING_ERROR (UART_LSR_RX_FE_MASK)
404 #define UART_PARITY_ERROR (UART_LSR_RX_PE_MASK)
405 #define UART_OVERRUN_ERROR (UART_LSR_RX_OE_MASK)
415 #define UART_REG_CONFIG_MODE_A ((uint32_t) 0x0080)
416 #define UART_REG_CONFIG_MODE_B ((uint32_t) 0x00BF)
417 #define UART_REG_OPERATIONAL_MODE ((uint32_t) 0x007F)
429 #define UART_CONFIG_MODE_POLLED (0x00U)
430 #define UART_CONFIG_MODE_INTERRUPT (0x01U)
431 #define UART_CONFIG_MODE_USER_INTR (0x02U)
432 #define UART_CONFIG_MODE_DMA (0x03U)
433 #define UART_CONFIG_MODE_POLLED_WITH_COUNTER (0x04U)
436 #define UART_STATE_RX_DISABLED (0x0U)
437 #define UART_STATE_RX_ENABLED (0x1U)
443 struct UARTLLD_Object_s;
444 struct UART_Config_s;
446 typedef struct UART_ExtendedParams_s
567 typedef struct UARTLLD_Object_s
729 int32_t
UART_lld_write(UARTLLD_Handle hUart,
void * txBuf, uint32_t size, uint32_t timeout,
772 int32_t
UART_lld_read(UARTLLD_Handle hUart,
void * rxBuf, uint32_t size, uint32_t timeout,
1165 uint32_t isChannelTx);
int32_t UART_lld_readIntr(UARTLLD_Handle hUart, void *rxBuf, uint32_t size, const UART_ExtendedParams *extendedParams)
This API reads data from the UART instance in Interrupt mode.
int32_t UART_writeCancelNoCB(UARTLLD_Handle hUart)
EDMA Instance Configuration. Pointer to this object is returned as handle by driver open.
Definition: edma/v0/edma.h:675
int32_t UART_lld_read(UARTLLD_Handle hUart, void *rxBuf, uint32_t size, uint32_t timeout, const UART_ExtendedParams *extendedParams)
This API reads data from the UART instance in Polling mode.
uint32_t operMode
Definition: uart_lld.h:534
void * args
Definition: hsmclient_msg.h:4
Definition: uart_lld.h:447
int32_t UART_lld_deInit(UARTLLD_Handle hUart)
This API De-Initializes the UART instance.
void UART_lld_Transaction_init(UART_Transaction *trans)
Function to initialize the UART_Transaction struct to its defaults.
int32_t UART_readCancelNoCB(UARTLLD_Handle hUart)
int32_t UART_lld_readCancel(UARTLLD_Handle hUart, UART_Transaction *trans)
This API cancels current UART Read.
uint32_t txEvtNum
Definition: uart_lld.h:546
UARTLLD_InitHandle hUartInit
Definition: uart_lld.h:571
uint32_t transferMode
Definition: uart_lld.h:524
uint32_t UART_readLineStatus(uint32_t baseAddr)
This API reads the line status register value.
int32_t UART_lld_dmaDisableChannel(UARTLLD_Handle hUart, uint32_t isChannelTx)
API to disable DMA channel.
int32_t UART_lld_writeIntr(UARTLLD_Handle hUart, void *txBuf, uint32_t size, const UART_ExtendedParams *extendedParams)
This API writes data to the UART instance in Interrupt mode.
UART_writeCompCallbackFxn writeCompleteCallbackFxn
Definition: uart_lld.h:560
uint32_t timeout
Definition: uart_lld.h:465
int32_t UART_lld_flushTxFifo(UARTLLD_Handle hUart)
Function to flush a TX FIFO of peripheral specified by the UART handle.
uint32_t dataLength
Definition: uart_lld.h:508
const uint8_t * writeBuf
Definition: uart_lld.h:577
uint32_t rxEvtNum
Definition: uart_lld.h:544
int32_t UART_lld_writeDma(UARTLLD_Handle hUart, void *txBuf, uint32_t size, const UART_ExtendedParams *extendedParams)
This API writes data to the UART instance in DMA mode.
uint32_t baudRate
Definition: uart_lld.h:506
UART_DmaHandle uartDmaHandle
Definition: uart_lld.h:548
UART_readCompCallbackFxn readCompleteCallbackFxn
Definition: uart_lld.h:558
uint32_t hwFlowControl
Definition: uart_lld.h:516
int32_t UART_lld_dmaWrite(UARTLLD_Handle hUart, const UART_Transaction *transaction)
API to write data using an UART DMA channel.
int32_t UART_lld_deInitDma(UARTLLD_Handle hUart)
This API De-Initializes the UART instance in DMA mode.
uint32_t UART_operatingModeSelect(uint32_t baseAddr, uint32_t modeFlag)
int32_t UART_lld_initDma(UARTLLD_Handle hUart)
This API Initializes the UART instance in DMA mode.
UART_clockGet clockP_get
Definition: uart_lld.h:554
UART_clockUsecToTick clockP_usecToTick
Definition: uart_lld.h:556
uint32_t writeSizeRemaining
Definition: uart_lld.h:581
UART driver initialization object.
Definition: uart_lld.h:500
uint32_t readSizeRemaining
Definition: uart_lld.h:591
struct UART_EdmaChConfig_s * UART_DmaChConfig
Definition: uart_dma_edma.h:90
void UART_intrEnable(uint32_t baseAddr, uint32_t intrFlag)
This API enables the specified interrupts in the UART mode of operation.
uint64_t lineStatusTimeout
Definition: uart_lld.h:619
uint32_t UART_getIntrIdentityStatus(uint32_t baseAddr)
This API determines the UART Interrupt Status.
void UART_lld_Transaction_deInit(UART_Transaction *trans)
Function to de-initialize the UART_Transaction struct to its defaults.
uint32_t state
Definition: uart_lld.h:610
uint32_t parityType
Definition: uart_lld.h:512
uint32_t currIntMask
Definition: uart_lld.h:605
void UART_lld_controllerIsr(void *args)
This is the UART ISR and can be used as IRQ handler.
UART driver object.
Definition: uart_lld.h:568
uint32_t readMode
Definition: uart_lld.h:536
void UART_enableLoopbackMode(uint32_t baseAddr)
Function to enable loopback mode. This function is for internal use. Not recommended for customers to...
void UART_putChar(uint32_t baseAddr, uint8_t byteTx)
This API writes a byte to the Transmitter FIFO without checking for the emptiness of the Transmitter ...
uint32_t hwFlowControlThr
Definition: uart_lld.h:518
uint32_t stopBits
Definition: uart_lld.h:510
void UART_disableLoopbackMode(uint32_t baseAddr)
Function to disable loopback mode. This function is for internal use. Not recommended for customers t...
int32_t UART_lld_dmaDeInit(UARTLLD_Handle hUart)
API to close an UART DMA channel.
uint32_t timeGuardVal
Definition: uart_lld.h:552
uint8_t intrPriority
Definition: uart_lld.h:528
uint32_t UART_getBaseAddr_lld(UARTLLD_Handle handle)
Function to get base address of UART instance of a particular handle.
int32_t UART_lld_setRxState(UARTLLD_Handle hUart, uint32_t state)
Function to enable/disable UART RX State.
uint8_t * readBuf
Definition: uart_lld.h:587
int32_t UART_lld_init(UARTLLD_Handle hUart)
This API Initializes the UART instance.
uint32_t writeMode
Definition: uart_lld.h:538
UART_DmaChConfig dmaChCfg
Definition: uart_lld.h:550
uint32_t status
Definition: uart_lld.h:467
Data structure used with UART_read() and UART_write()
Definition: uart_lld.h:457
uint32_t writeCount
Definition: uart_lld.h:579
uint32_t readCount
Definition: uart_lld.h:589
int32_t UART_lld_write(UARTLLD_Handle hUart, void *txBuf, uint32_t size, uint32_t timeout, const UART_ExtendedParams *extendedParams)
This API writes data to the UART instance in Polling mode.
uint32_t UART_getIntr2Status(uint32_t baseAddr)
This API determines the UART Interrupt Status 2.
UART_Transaction writeTrans
Definition: uart_lld.h:603
uint32_t rxTimeoutCnt
Definition: uart_lld.h:593
void UART_intr2Disable(uint32_t baseAddr, uint32_t intrFlag)
This API disables the specified interrupts in the UART mode of operation for IER2.
uint32_t UART_IsTxRxFifoEmpty(uint32_t baseAddr)
uint32_t UART_getChar(uint32_t baseAddr, uint8_t *pChar)
This API reads a byte from the Receiver Buffer Register (RBR). It checks once if any character is rea...
uint32_t * args
Definition: uart_lld.h:448
uint32_t baseAddr
Definition: uart_lld.h:569
uint32_t inputClkFreq
Definition: uart_lld.h:504
void UART_intr2Enable(uint32_t baseAddr, uint32_t intrFlag)
This API enables the specified interrupts in the UART mode of operation for IER2.
uint32_t UART_checkCharsAvailInFifo(uint32_t baseAddr)
This API checks if the RX FIFO (or RHR in non-FIFO mode) has atleast one byte of data to be read.
uint32_t intrNum
Definition: uart_lld.h:526
void * writeTransferMutex
Definition: uart_lld.h:614
struct UART_Config_s * args
Definition: uart_lld.h:617
int32_t UART_lld_readDma(UARTLLD_Handle hUart, void *rxBuf, uint32_t size, const UART_ExtendedParams *extendedParams)
This API reads data from the UART instance in DMA mode.
uint32_t UART_spaceAvail(uint32_t baseAddr)
uint8_t UART_getCharFifo(uint32_t baseAddr, uint8_t *readBuf)
This API reads the data present at the top of the RX FIFO, that is, the data in the Receive Holding R...
uint32_t txTrigLvl
Definition: uart_lld.h:542
struct UARTLLD_InitObject * UARTLLD_InitHandle
int32_t UART_lld_writeCancel(UARTLLD_Handle hUart, UART_Transaction *trans)
This API cancels current UART Write.
uint32_t readErrorCnt
Definition: uart_lld.h:595
void * readTransferMutex
Definition: uart_lld.h:612
uint32_t * args
Definition: uart_lld.h:469
void(* UART_readCompCallbackFxn)(struct UARTLLD_Object_s *args)
The definition of a read complete callback function used by the UART driver when used in UART_TRANSFE...
Definition: uart_lld.h:482
int32_t UART_lld_readWithCounter(UARTLLD_Handle hUart, void *rxBuf, uint32_t size, uint32_t timeout, const UART_ExtendedParams *extendedParams)
This API reads data with counter.
UART_Transaction readTrans
Definition: uart_lld.h:601
void UART_intrDisable(uint32_t baseAddr, uint32_t intrFlag)
This API disables the specified interrupts in the UART mode of operation.
uint32_t readReturnMode
Definition: uart_lld.h:514
void * buf
Definition: uart_lld.h:458
uint32_t(* UART_clockGet)(void)
Definition: uart_lld.h:473
int32_t UART_lld_dmaInit(UARTLLD_Handle hUart, UART_DmaChConfig dmaChCfg)
API to open an UART DMA channel.
uint32_t(* UART_clockUsecToTick)(uint64_t usecs)
Definition: uart_lld.h:474
void(* UART_writeCompCallbackFxn)(struct UARTLLD_Object_s *args)
The definition of a write complete callback function used by the UART driver when used in UART_TRANSF...
Definition: uart_lld.h:490
uint32_t rxTrigLvl
Definition: uart_lld.h:540
uint32_t count
Definition: uart_lld.h:461
int32_t UART_lld_dmaRead(UARTLLD_Handle hUart, const UART_Transaction *transaction)
API to read data using an UART DMA channel.
int32_t UART_procLineStatusErr(UARTLLD_Handle hUart)
Function to check various error conditions in uart.