60#include "Cdd_Uart_Priv.h"
61#include "SchM_Cdd_Uart.h"
73#define UART_FIFO_SIZE (64U)
80#define UART_TRANSMITEMPTY_TRIALCOUNT (3000U)
94#define CDD_UART_MODULE_ID 255U
96#define CDD_UART_VENDOR_ID 44U
98#define CDD_UART_INSTANCE_ID 0U
108#define CDD_UART_SW_MAJOR_VERSION CDD_UART_MAJOR_VERSION
110#define CDD_UART_SW_MINOR_VERSION CDD_UART_MINOR_VERSION
112#define CDD_UART_SW_PATCH_VERSION CDD_UART_CFG_PATCH_VERSION
121#define CDD_UART_AR_RELEASE_MAJOR_VERSION 4U
123#define CDD_UART_AR_RELEASE_MINOR_VERSION 3U
125#define CDD_UART_AR_RELEASE_REVISION_VERSION 1U
136#define CDD_UART_INIT_SERVICE_ID 0x01U
138#define CDD_UART_GETVERSIONINFO_SERVICE_ID 0x02U
140#define CDD_UART_REGISTERREADBACK_SERVICE_ID 0x0DU
142#define CDD_UART_READDATA_SERVICE_ID 0x03U
144#define CDD_UART_WRITEDATA_SERVICE_ID 0x04U
146#define CDD_UART_ERROR_SERVICE_ID 0x05U
148#define CDD_UART_CANCEL_SERVICE_ID 0x06U
150#define CDD_UART_GETREMAININGWORDS_SERVICE_ID 0x07U
152#define CDD_UART_READNOTIF_SERVICE_ID 0x08U
154#define CDD_UART_WRITENOTIF_SERVICE_ID 0x09U
156#define CDD_UART_ERRORNOTIF_SERVICE_ID 0x0AU
158#define CDD_UART_DEINIT_SERVICE_ID 0x0BU
160#define CDD_UART_INTERNAL_ISR_ID 0x0CU
171#define CDD_UART_E_UNINIT 0x01U
174#define CDD_UART_E_INVALID_EVENT 0x02U
177#define CDD_UART_E_READ_LOCKED 0x03U
180#define CDD_UART_E_WRITE_LOCKED 0x04U
183#define CDD_UART_E_PARAM_POINTER 0x05U
186#define CDD_UART_E_ALREADY_INITIALIZED 0x06U
189#define CDD_UART_E_PARAM_VALUE 0x07U
192#define CDD_UART_E_PARAM_LENGTH 0x08U
195#define CDD_UART_E_INVALID_CHANNEL 0x09U
198#define CDD_UART_E_INVALID_CONFIG 0x0AU
209#define UART_TX_FIFO_NOT_FULL ( \
210 UART_SSR_TX_FIFO_FULL_TX_FIFO_FULL_VALUE_0)
211#define UART_TX_FIFO_FULL ( \
212 UART_SSR_TX_FIFO_FULL_TX_FIFO_FULL_VALUE_1)
223#define UART_INTID_MODEM_STAT (UART_IIR_IT_TYPE_IT_TYPE_VALUE_0 \
225 UART_IIR_IT_TYPE_SHIFT)
226#define UART_INTID_TX_THRES_REACH (UART_IIR_IT_TYPE_IT_TYPE_VALUE_1 \
228 UART_IIR_IT_TYPE_SHIFT)
229#define UART_INTID_RX_THRES_REACH (UART_IIR_IT_TYPE_IT_TYPE_VALUE_2 \
231 UART_IIR_IT_TYPE_SHIFT)
232#define UART_INTID_RX_LINE_STAT_ERROR (UART_IIR_IT_TYPE_IT_TYPE_VALUE_3 \
234 UART_IIR_IT_TYPE_SHIFT)
235#define UART_INTID_CHAR_TIMEOUT (UART_IIR_IT_TYPE_IT_TYPE_VALUE_6 \
237 UART_IIR_IT_TYPE_SHIFT)
238#define UART_INTID_XOFF_SPEC_CHAR_DETECT (UART_IIR_IT_TYPE_IT_TYPE_VALUE_8 \
240 UART_IIR_IT_TYPE_SHIFT)
241#define UART_INTID_MODEM_SIG_STATE_CHANGE (UART_IIR_IT_TYPE_IT_TYPE_VALUE_10 \
243 UART_IIR_IT_TYPE_SHIFT)
246#define UART_INTR_PENDING (0U)
247#define UART_NO_INTR_PENDING (1U)
257#define UART_INTR_CTS (UART_IER_CTS_IT_MASK)
258#define UART_INTR_RTS (UART_IER_RTS_IT_MASK)
259#define UART_INTR_XOFF (UART_IER_XOFF_IT_MASK)
260#define UART_INTR_SLEEPMODE (UART_IER_SLEEP_MODE_MASK)
261#define UART_INTR_MODEM_STAT (UART_IER_MODEM_STS_IT_MASK)
262#define UART_INTR_LINE_STAT (UART_IER_LINE_STS_IT_MASK)
263#define UART_INTR_THR (UART_IER_THR_IT_MASK)
264#define UART_INTR_RHR_CTI (UART_IER_RHR_IT_MASK)
266#define UART_INTR2_RX_EMPTY (UART_IER2_EN_RXFIFO_EMPTY_MASK)
267#define UART_INTR2_TX_EMPTY (UART_IER2_EN_TXFIFO_EMPTY_MASK)
277#define UART_FIFO_PE_FE_BI_DETECTED (UART_LSR_RX_FIFO_STS_MASK)
278#define UART_BREAK_DETECTED_ERROR (UART_LSR_RX_BI_MASK)
279#define UART_FRAMING_ERROR (UART_LSR_RX_FE_MASK)
280#define UART_PARITY_ERROR (UART_LSR_RX_PE_MASK)
281#define UART_OVERRUN_ERROR (UART_LSR_RX_OE_MASK)
284#define UART_STATE_RX_DISABLED (0x0U)
285#define UART_STATE_RX_ENABLED (0x1U)
288#define IS_DATA_LENGTH_VALID(dataLength) ((dataLength == CDD_UART_WORD_LENGTH_5) || \
289 (dataLength == CDD_UART_WORD_LENGTH_6) || \
290 (dataLength == CDD_UART_WORD_LENGTH_7) || \
291 (dataLength == CDD_UART_WORD_LENGTH_8))
294#define IS_STOP_BITS_VALID(stopBits) ((stopBits == CDD_UART_STOP_BIT_1) || \
295 (stopBits == CDD_UART_STOP_BITS_2))
298#define IS_PARITY_TYPE_VALID(parityType) ((parityType == CDD_UART_PARITY_NONE) || \
299 (parityType == CDD_UART_PARITY_ODD) || \
300 (parityType == CDD_UART_PARITY_EVEN))
303#define IS_OPER_MODE_VALID(operMode) ((operMode == CDD_UART_16x_OPER) || \
304 (operMode == CDD_UART_16x_AUTO_OPER) || \
305 (operMode == CDD_UART_13x_OPER))
308#define IS_RXTRIG_LVL_VALID(rxTrigLvl) ((rxTrigLvl == CDD_UART_TRIGGER_LEVEL_1) || \
309 (rxTrigLvl == CDD_UART_TRIGGER_LEVEL_8) || \
310 (rxTrigLvl == CDD_UART_TRIGGER_LEVEL_16) || \
311 (rxTrigLvl == CDD_UART_TRIGGER_LEVEL_56) || \
312 (rxTrigLvl == CDD_UART_TRIGGER_LEVEL_60))
315#define IS_TXTRIG_LVL_VALID(txTrigLvl) ((txTrigLvl == CDD_UART_TRIGGER_LEVEL_1) || \
316 (txTrigLvl == CDD_UART_TRIGGER_LEVEL_8) || \
317 (txTrigLvl == CDD_UART_TRIGGER_LEVEL_16) || \
318 (txTrigLvl == CDD_UART_TRIGGER_LEVEL_32) || \
319 (txTrigLvl == CDD_UART_TRIGGER_LEVEL_56))
324#define MCAL_STATE_RESET (0U)
325#define MCAL_STATE_READY (1U)
326#define MCAL_STATE_BUSY (2U)
327#define MCAL_STATE_ERROR (3U)
364#if (STD_ON == CDD_UART_VERSION_INFO_API)
366 P2VAR(Std_VersionInfoType, AUTOMATIC, CDD_UART_APPL_DATA) VersionInfoPtr);
388#if (STD_ON == CDD_UART_REGISTER_READBACK_API)
389FUNC(Std_ReturnType, CDD_UART_CODE)
Cdd_Uart_RegisterReadback(uint8 ChannelID, P2VAR(CddUart_RegisterReadbackType, AUTOMATIC, CDD_UART_CFG) RegisterSetPtr);
432#if (STD_ON == CDD_UART_DEINIT_API)
462#if (STD_ON == CDD_UART_WRITE_API)
464 P2VAR(
CddUartDataBufferType, AUTOMATIC, CDD_UART_APPL_DATA) SrcBufferPtr, uint32 Count, uint32 Timeout);
492#if (STD_ON == CDD_UART_READ_API)
494 P2VAR(
CddUartDataBufferType, AUTOMATIC, CDD_UART_APPL_DATA) DestBufferPtr, uint32 Count, uint32 Timeout);
519#if (STD_ON == CDD_UART_CANCEL_API)
545#if (STD_ON == CDD_UART_GETREMAININGWORDS_API)
This file contains generated configuration file for UART Complex Device Driver.
boolean Cdd_Uart_Cancel(uint8 ChannelID, CddUartDataDirectionType TransferType)
Service to cancel an ongoing transaction with UART.
void Cdd_Uart_Init(const Cdd_Uart_CfgType *ConfigurationPtr)
Service for CDD UART Initialization.
uint8 CddUartDataBufferType
Typedef for the data buffer elements.
Definition Cdd_Uart.h:330
Std_ReturnType Cdd_Uart_Read(uint8 ChannelID, CddUartDataBufferType *DestBufferPtr, uint32 Count, uint32 Timeout)
Service to read message or command from the UART.
uint8_least CddUartDataDirectionType
Type for defining the direction of data transfer, i.e., sending or receival.
Definition Cdd_Uart.h:333
uint32 Cdd_Uart_GetRemainingWords(uint8 ChannelID, CddUartDataDirectionType TransferType)
Service to get remaining words to be transmitted from the UART for any ongoing transaction.
void Cdd_Uart_GetVersionInfo(Std_VersionInfoType *VersionInfoPtr)
Service for getting CDD UART version.
Std_ReturnType Cdd_Uart_RegisterReadback(uint8 ChannelID, CddUart_RegisterReadbackType *RegisterSetPtr)
Service for reading HW IP registers of a CDD UART instance.
void Cdd_Uart_DeInit(void)
Service for deinitializing CDD UART.
Std_ReturnType Cdd_Uart_Write(uint8 ChannelID, CddUartDataBufferType *SrcBufferPtr, uint32 Count, uint32 Timeout)
Service to transmit message using UART.
Definition Cdd_Uart_Cfg.h:302