mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-24 03:23:18 +08:00
2286 lines
84 KiB
C
2286 lines
84 KiB
C
/*
|
|
* Copyright 2018, 2020, 2022 NXP
|
|
* All rights reserved.
|
|
*
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#include "fsl_lpuart.h"
|
|
|
|
#include "fsl_adapter_uart.h"
|
|
|
|
#if (defined(FSL_FEATURE_LPUART_IS_LPFLEXCOMM) && (FSL_FEATURE_LPUART_IS_LPFLEXCOMM > 0U))
|
|
#include "fsl_lpflexcomm.h"
|
|
#endif /* FSL_FEATURE_LPUART_IS_LPFLEXCOMM */
|
|
|
|
/*! @brief MACROs for whether a software idleline detection should be used. */
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
#if (defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
#define HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION (1)
|
|
#else /* HAL_UART_TRANSFER_MODE */
|
|
#define HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION (0)
|
|
#endif /* HAL_UART_TRANSFER_MODE */
|
|
#else /* UART_ADAPTER_NON_BLOCKING_MODE */
|
|
#define HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION (1)
|
|
#endif /* UART_ADAPTER_NON_BLOCKING_MODE */
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#include "fsl_component_timer_manager.h"
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
#include "fsl_lpuart_edma.h"
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#include "fsl_lpuart_dma.h"
|
|
#endif
|
|
#if defined(FSL_FEATURE_SOC_DMAMUX_COUNT) && FSL_FEATURE_SOC_DMAMUX_COUNT
|
|
#include "fsl_dmamux.h"
|
|
#endif
|
|
#ifdef DMA_IRQS
|
|
#define DMA_CHN_IRQS DMA_IRQS
|
|
#endif
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
|
|
/*******************************************************************************
|
|
* Definitions
|
|
******************************************************************************/
|
|
#ifndef NDEBUG
|
|
#if (defined(DEBUG_CONSOLE_ASSERT_DISABLE) && (DEBUG_CONSOLE_ASSERT_DISABLE > 0U))
|
|
#undef assert
|
|
#define assert(n)
|
|
#endif
|
|
#endif
|
|
|
|
#ifndef HAL_UART_ADAPTER_LOWPOWER_RESTORE
|
|
#define HAL_UART_ADAPTER_LOWPOWER_RESTORE (1)
|
|
#endif
|
|
|
|
#ifndef HAL_UART_DMA_RING_BUFFER_ENABLE
|
|
#define HAL_UART_DMA_RING_BUFFER_ENABLE (0U)
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
#ifndef LPUART_RING_BUFFER_SIZE
|
|
#define LPUART_RING_BUFFER_SIZE (128U)
|
|
#endif
|
|
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
/*! @brief uart RX state structure. */
|
|
typedef struct _hal_uart_dma_receive_state
|
|
{
|
|
uint8_t *volatile buffer;
|
|
volatile uint32_t bufferLength;
|
|
volatile uint32_t bufferSofar;
|
|
volatile uint32_t timeout;
|
|
volatile bool receiveAll;
|
|
} hal_uart_dma_receive_state_t;
|
|
|
|
/*! @brief uart TX state structure. */
|
|
typedef struct _hal_uart_dma_send_state
|
|
{
|
|
uint8_t *volatile buffer;
|
|
volatile uint32_t bufferLength;
|
|
volatile uint32_t bufferSofar;
|
|
volatile uint32_t timeout;
|
|
} hal_uart_dma_send_state_t;
|
|
|
|
typedef struct _hal_uart_dma_state
|
|
{
|
|
struct _hal_uart_dma_state *next;
|
|
uint8_t instance; /* LPUART instance */
|
|
hal_uart_dma_transfer_callback_t dma_callback;
|
|
void *dma_callback_param;
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
lpuart_edma_handle_t edmaHandle;
|
|
edma_handle_t txEdmaHandle;
|
|
edma_handle_t rxEdmaHandle;
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
lpuart_dma_handle_t dmaHandle;
|
|
dma_handle_t txDmaHandle;
|
|
dma_handle_t rxDmaHandle;
|
|
#endif
|
|
hal_uart_dma_receive_state_t dma_rx;
|
|
hal_uart_dma_send_state_t dma_tx;
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER) && (HAL_UART_ADAPTER_LOWPOWER > 0U))
|
|
dma_channel_mux_configure_t dma_channel_mux_configure;
|
|
dma_mux_configure_t dma_mux_configure;
|
|
hal_uart_dma_config_t hal_uart_dma_config;
|
|
#endif
|
|
} hal_uart_dma_state_t;
|
|
|
|
typedef struct _lpuart_dma_list
|
|
{
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
TIMER_MANAGER_HANDLE_DEFINE(timerManagerHandle);
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
hal_uart_dma_state_t *dma_list;
|
|
volatile int8_t activeCount;
|
|
} hal_lpuart_dma_list_t;
|
|
|
|
static hal_lpuart_dma_list_t s_dmaHandleList;
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
/*! @brief uart RX state structure. */
|
|
typedef struct _hal_uart_receive_state
|
|
{
|
|
uint8_t *volatile buffer;
|
|
volatile uint32_t bufferLength;
|
|
volatile uint32_t bufferSofar;
|
|
} hal_uart_receive_state_t;
|
|
|
|
/*! @brief uart TX state structure. */
|
|
typedef struct _hal_uart_send_state
|
|
{
|
|
uint8_t *volatile buffer;
|
|
volatile uint32_t bufferLength;
|
|
volatile uint32_t bufferSofar;
|
|
} hal_uart_send_state_t;
|
|
#endif
|
|
/*! @brief uart state structure. */
|
|
typedef struct _hal_uart_state
|
|
{
|
|
uint8_t instance;
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
hal_uart_transfer_callback_t callback;
|
|
void *callbackParam;
|
|
#if (defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
lpuart_handle_t hardwareHandle;
|
|
#endif
|
|
hal_uart_receive_state_t rx;
|
|
hal_uart_send_state_t tx;
|
|
#endif
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER) && (HAL_UART_ADAPTER_LOWPOWER > 0U))
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER_RESTORE) && (HAL_UART_ADAPTER_LOWPOWER_RESTORE > 0U))
|
|
uint32_t reg_BAUD;
|
|
uint32_t reg_CTRL;
|
|
uint32_t reg_WATER;
|
|
uint32_t reg_MODIR;
|
|
#else
|
|
hal_uart_config_t config;
|
|
#endif
|
|
#endif
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
hal_uart_dma_state_t *dmaHandle;
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
} hal_uart_state_t;
|
|
|
|
/*******************************************************************************
|
|
* Prototypes
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Variables
|
|
******************************************************************************/
|
|
static LPUART_Type *const s_LpuartAdapterBase[] = LPUART_BASE_PTRS;
|
|
#if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER) && (HAL_UART_ADAPTER_LOWPOWER > 0U))
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER_RESTORE) && (HAL_UART_ADAPTER_LOWPOWER_RESTORE > 0U))
|
|
static const clock_ip_name_t s_LpuartAdapterClock[] = LPUART_CLOCKS;
|
|
#endif /* HAL_UART_ADAPTER_LOWPOWER_RESTORE */
|
|
#endif /* HAL_UART_ADAPTER_LOWPOWER */
|
|
#endif /* FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL */
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
|
|
#if !(defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
/* Array of LPUART IRQ number. */
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
static const IRQn_Type s_LpuartRxIRQ[] = LPUART_RX_IRQS;
|
|
static const IRQn_Type s_LpuartTxIRQ[] = LPUART_TX_IRQS;
|
|
#else
|
|
static const IRQn_Type s_LpuartIRQ[] = LPUART_RX_TX_IRQS;
|
|
#endif
|
|
#endif
|
|
|
|
#if !(defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
static hal_uart_state_t *s_UartState[sizeof(s_LpuartAdapterBase) / sizeof(LPUART_Type *)];
|
|
#endif
|
|
#endif
|
|
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
static hal_uart_dma_state_t *s_UartDmaState[sizeof(s_LpuartAdapterBase) / sizeof(LPUART_Type *)] = {0};
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
/* allocate ring buffer section. */
|
|
AT_NONCACHEABLE_SECTION_INIT(
|
|
static uint8_t s_ringBuffer[sizeof(s_LpuartAdapterBase) / sizeof(LPUART_Type *)][LPUART_RING_BUFFER_SIZE]) = {0};
|
|
/* Allocate TCD memory poll with ring buffer used. */
|
|
AT_NONCACHEABLE_SECTION_ALIGN(
|
|
static edma_tcd_t tcdMemoryPoolPtr[sizeof(s_LpuartAdapterBase) / sizeof(LPUART_Type *)][1], sizeof(edma_tcd_t));
|
|
|
|
static volatile uint32_t ringBufferIndex[sizeof(s_LpuartAdapterBase) / sizeof(LPUART_Type *)] = {0U};
|
|
static void LPUART_StartRingBufferEDMA(hal_uart_handle_t handle);
|
|
static void LPUART_DMACallbacks(LPUART_Type *base, lpuart_edma_handle_t *handle, status_t status, void *userData);
|
|
#endif
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
|
|
/*******************************************************************************
|
|
* Code
|
|
******************************************************************************/
|
|
|
|
#if ((defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U)) || \
|
|
(defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U)))
|
|
static hal_uart_status_t HAL_UartGetStatus(status_t status)
|
|
{
|
|
hal_uart_status_t uartStatus = kStatus_HAL_UartError;
|
|
switch (status)
|
|
{
|
|
case (int32_t)kStatus_Success:
|
|
uartStatus = kStatus_HAL_UartSuccess;
|
|
break;
|
|
case (int32_t)kStatus_LPUART_TxBusy:
|
|
uartStatus = kStatus_HAL_UartTxBusy;
|
|
break;
|
|
case (int32_t)kStatus_LPUART_RxBusy:
|
|
uartStatus = kStatus_HAL_UartRxBusy;
|
|
break;
|
|
case (int32_t)kStatus_LPUART_TxIdle:
|
|
uartStatus = kStatus_HAL_UartTxIdle;
|
|
break;
|
|
case (int32_t)kStatus_LPUART_RxIdle:
|
|
uartStatus = kStatus_HAL_UartRxIdle;
|
|
break;
|
|
case (int32_t)kStatus_LPUART_BaudrateNotSupport:
|
|
uartStatus = kStatus_HAL_UartBaudrateNotSupport;
|
|
break;
|
|
case (int32_t)kStatus_LPUART_NoiseError:
|
|
case (int32_t)kStatus_LPUART_FramingError:
|
|
case (int32_t)kStatus_LPUART_ParityError:
|
|
uartStatus = kStatus_HAL_UartProtocolError;
|
|
break;
|
|
default:
|
|
/*MISRA rule 16.4*/
|
|
break;
|
|
}
|
|
return uartStatus;
|
|
}
|
|
#else
|
|
static hal_uart_status_t HAL_UartGetStatus(status_t status)
|
|
{
|
|
hal_uart_status_t uartStatus;
|
|
if ((int32_t)kStatus_Success == status)
|
|
{
|
|
uartStatus = kStatus_HAL_UartSuccess; /* Successfully */
|
|
}
|
|
else
|
|
{
|
|
uartStatus = kStatus_HAL_UartError; /* Error occurs on HAL uart */
|
|
}
|
|
return uartStatus;
|
|
}
|
|
#endif
|
|
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
static uint32_t HAL_UartGetDmaReceivedBytes(uint8_t instance)
|
|
{
|
|
volatile uint32_t receivedBytes = 0U;
|
|
uint32_t remainingBytes = 0U;
|
|
uint32_t newIndex = 0U;
|
|
|
|
hal_uart_dma_state_t *uartDmaHandle = s_UartDmaState[instance];
|
|
|
|
remainingBytes =
|
|
EDMA_GetRemainingMajorLoopCount(uartDmaHandle->rxEdmaHandle.base, uartDmaHandle->rxEdmaHandle.channel);
|
|
if (remainingBytes == LPUART_RING_BUFFER_SIZE)
|
|
{
|
|
remainingBytes = 0;
|
|
}
|
|
else
|
|
{
|
|
newIndex = LPUART_RING_BUFFER_SIZE - remainingBytes;
|
|
}
|
|
|
|
if (newIndex < ringBufferIndex[instance])
|
|
{
|
|
newIndex = newIndex + LPUART_RING_BUFFER_SIZE;
|
|
}
|
|
receivedBytes = newIndex - ringBufferIndex[instance];
|
|
|
|
return receivedBytes;
|
|
}
|
|
#endif
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
static void HAL_UartDMAIdlelineInterruptHandle(uint8_t instance)
|
|
{
|
|
hal_uart_dma_state_t *uartDmaHandle = s_UartDmaState[instance];
|
|
hal_dma_callback_msg_t msg;
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
uint32_t receiveLength = 0;
|
|
uint32_t callbackLength = 0;
|
|
uint32_t remianLength = 0;
|
|
uint32_t key;
|
|
#endif /* HAL_UART_DMA_RING_BUFFER_ENABLE */
|
|
assert(uartDmaHandle);
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
if ((NULL != uartDmaHandle->dma_callback) && (NULL != uartDmaHandle->dma_rx.buffer))
|
|
{
|
|
key = DisableGlobalIRQ();
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
receiveLength = HAL_UartGetDmaReceivedBytes(instance);
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
if (uartDmaHandle->dma_rx.receiveAll == true)
|
|
{
|
|
if (receiveLength < uartDmaHandle->dma_rx.bufferLength)
|
|
{
|
|
LPUART_EnableInterrupts(s_LpuartAdapterBase[instance], (uint32_t)kLPUART_IdleLineInterruptEnable);
|
|
EnableGlobalIRQ(key);
|
|
return;
|
|
}
|
|
}
|
|
callbackLength =
|
|
(receiveLength < uartDmaHandle->dma_rx.bufferLength) ? receiveLength : uartDmaHandle->dma_rx.bufferLength;
|
|
if (callbackLength != 0U)
|
|
{
|
|
msg.status = kStatus_HAL_UartDmaIdleline;
|
|
msg.dataSize = callbackLength;
|
|
|
|
if (ringBufferIndex[instance] + callbackLength < LPUART_RING_BUFFER_SIZE)
|
|
{
|
|
(void)memcpy(uartDmaHandle->dma_rx.buffer, &s_ringBuffer[instance][ringBufferIndex[instance]],
|
|
callbackLength);
|
|
ringBufferIndex[instance] += callbackLength;
|
|
}
|
|
else
|
|
{
|
|
remianLength = callbackLength + ringBufferIndex[instance] - LPUART_RING_BUFFER_SIZE;
|
|
(void)memcpy(uartDmaHandle->dma_rx.buffer, &s_ringBuffer[instance][ringBufferIndex[instance]],
|
|
(callbackLength - remianLength));
|
|
(void)memcpy(uartDmaHandle->dma_rx.buffer + (callbackLength - remianLength), &s_ringBuffer[instance][0],
|
|
remianLength);
|
|
ringBufferIndex[instance] = remianLength;
|
|
}
|
|
msg.data = uartDmaHandle->dma_rx.buffer;
|
|
uartDmaHandle->dma_rx.buffer = NULL;
|
|
|
|
uartDmaHandle->dma_callback(uartDmaHandle, &msg, uartDmaHandle->dma_callback_param);
|
|
}
|
|
EnableGlobalIRQ(key);
|
|
}
|
|
#else
|
|
if ((NULL != uartDmaHandle->dma_callback) && (NULL != uartDmaHandle->dma_rx.buffer))
|
|
{
|
|
/* HAL_UartDMAGetReceiveCount(uartDmaHandle, &msg.dataSize); */
|
|
/* HAL_UartDMAAbortReceive(uartDmaHandle); */
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
(void)LPUART_TransferGetReceiveCountEDMA(s_LpuartAdapterBase[uartDmaHandle->instance],
|
|
&uartDmaHandle->edmaHandle, &msg.dataSize);
|
|
LPUART_TransferAbortReceiveEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle);
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
msg.status = kStatus_HAL_UartDmaIdleline;
|
|
msg.data = uartDmaHandle->dma_rx.buffer;
|
|
uartDmaHandle->dma_rx.buffer = NULL;
|
|
|
|
uartDmaHandle->dma_callback(uartDmaHandle, &msg, uartDmaHandle->dma_callback_param);
|
|
}
|
|
|
|
#endif
|
|
}
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
|
|
#if (defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
static void HAL_UartCallback(LPUART_Type *base, lpuart_handle_t *handle, status_t status, void *callbackParam)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_status_t uartStatus = HAL_UartGetStatus(status);
|
|
assert(callbackParam);
|
|
|
|
uartHandle = (hal_uart_state_t *)callbackParam;
|
|
|
|
if (kStatus_HAL_UartProtocolError == uartStatus)
|
|
{
|
|
if (0U != uartHandle->hardwareHandle.rxDataSize)
|
|
{
|
|
uartStatus = kStatus_HAL_UartError;
|
|
}
|
|
}
|
|
|
|
if (NULL != uartHandle->callback)
|
|
{
|
|
uartHandle->callback(uartHandle, uartStatus, uartHandle->callbackParam);
|
|
}
|
|
}
|
|
|
|
#else /* HAL_UART_TRANSFER_MODE */
|
|
|
|
static void HAL_UartInterruptHandle(uint8_t instance)
|
|
{
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
hal_dma_callback_msg_t msg;
|
|
hal_uart_dma_state_t *uartDmaHandle = s_UartDmaState[instance];
|
|
uint32_t sentCount = 0U;
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
hal_uart_state_t *uartHandle = s_UartState[instance];
|
|
uint32_t status;
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
uint8_t count;
|
|
#endif
|
|
|
|
assert(NULL != uartHandle);
|
|
|
|
status = LPUART_GetStatusFlags(s_LpuartAdapterBase[instance]);
|
|
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
/* DMA send complete interrupt. */
|
|
if ((NULL != uartDmaHandle) && (instance == uartDmaHandle->instance))
|
|
{
|
|
if (NULL != uartDmaHandle->dma_tx.buffer)
|
|
{
|
|
if ((0U != ((uint32_t)kLPUART_TransmissionCompleteFlag & status)) &&
|
|
(0U != (LPUART_GetEnabledInterrupts(s_LpuartAdapterBase[instance]) &
|
|
(uint32_t)kLPUART_TransmissionCompleteFlag)))
|
|
|
|
{
|
|
#if (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#elif (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
(void)LPUART_TransferGetSendCountEDMA(s_LpuartAdapterBase[uartDmaHandle->instance],
|
|
&uartDmaHandle->edmaHandle, &sentCount);
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
|
|
/* Disable tx complete interrupt */
|
|
(void)LPUART_DisableInterrupts(s_LpuartAdapterBase[instance],
|
|
(uint32_t)kLPUART_TransmissionCompleteFlag);
|
|
uartDmaHandle->edmaHandle.txState = 0;
|
|
msg.status = kStatus_HAL_UartDmaTxIdle;
|
|
msg.data = uartDmaHandle->dma_tx.buffer;
|
|
msg.dataSize = uartDmaHandle->dma_tx.bufferLength;
|
|
uartDmaHandle->dma_tx.buffer = NULL;
|
|
uartDmaHandle->dma_callback(uartDmaHandle, &msg, uartDmaHandle->dma_callback_param);
|
|
}
|
|
}
|
|
/* DMA receive Idleline interrupt. */
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
if (NULL != uartDmaHandle->dma_rx.buffer)
|
|
#else
|
|
if ((NULL != uartDmaHandle->dma_rx.buffer) && (false == uartDmaHandle->dma_rx.receiveAll))
|
|
#endif
|
|
{
|
|
if ((0U != ((uint32_t)kLPUART_IdleLineFlag & status)) &&
|
|
(0U != (LPUART_GetEnabledInterrupts(s_LpuartAdapterBase[instance]) &
|
|
(uint32_t)kLPUART_IdleLineInterruptEnable)))
|
|
{
|
|
HAL_UartDMAIdlelineInterruptHandle(instance);
|
|
(void)LPUART_ClearStatusFlags(s_LpuartAdapterBase[instance], (uint32_t)kLPUART_IdleLineFlag);
|
|
}
|
|
}
|
|
}
|
|
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
/* If RX overrun. */
|
|
if ((uint32_t)kLPUART_RxOverrunFlag == ((uint32_t)kLPUART_RxOverrunFlag & status))
|
|
{
|
|
/* Clear overrun flag, otherwise the RX does not work. */
|
|
s_LpuartAdapterBase[instance]->STAT =
|
|
((s_LpuartAdapterBase[instance]->STAT & 0x3FE00000U) | LPUART_STAT_OR_MASK);
|
|
}
|
|
#endif
|
|
if ((0u != ((uint32_t)kLPUART_NoiseErrorFlag & status)) || (0u != ((uint32_t)kLPUART_FramingErrorFlag & status)) ||
|
|
(0u != ((uint32_t)kLPUART_ParityErrorFlag & status)))
|
|
{
|
|
if (0u != ((uint32_t)kLPUART_NoiseErrorFlag & status))
|
|
{
|
|
(void)LPUART_ClearStatusFlags(s_LpuartAdapterBase[instance], (uint32_t)kLPUART_NoiseErrorFlag);
|
|
}
|
|
if (0u != ((uint32_t)kLPUART_FramingErrorFlag & status))
|
|
{
|
|
(void)LPUART_ClearStatusFlags(s_LpuartAdapterBase[instance], (uint32_t)kLPUART_FramingErrorFlag);
|
|
}
|
|
if (0u != ((uint32_t)kLPUART_ParityErrorFlag & status))
|
|
{
|
|
(void)LPUART_ClearStatusFlags(s_LpuartAdapterBase[instance], (uint32_t)kLPUART_ParityErrorFlag);
|
|
}
|
|
|
|
/*clean RDRF flag and drop the data with status error*/
|
|
if (0u != ((uint32_t)(kLPUART_RxDataRegFullFlag)&status))
|
|
{
|
|
(void)LPUART_ReadByte(s_LpuartAdapterBase[instance]);
|
|
}
|
|
status = LPUART_GetStatusFlags(s_LpuartAdapterBase[instance]);
|
|
}
|
|
#if (defined(FSL_FEATURE_LPUART_IS_LPFLEXCOMM) && (FSL_FEATURE_LPUART_IS_LPFLEXCOMM > 0U))
|
|
if (((0U != ((uint32_t)kLPUART_RxDataRegFullFlag & status)) &&
|
|
#else
|
|
/* Receive data register full */
|
|
if (((0U != ((uint32_t)kLPUART_RxDataRegFullFlag & status)) &&
|
|
#endif /* FSL_FEATURE_LPUART_IS_LPFLEXCOMM */
|
|
(0U != (LPUART_GetEnabledInterrupts(s_LpuartAdapterBase[instance]) &
|
|
(uint32_t)kLPUART_RxDataRegFullInterruptEnable)))
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
|| ((0U != ((uint32_t)kLPUART_IdleLineFlag & status)) &&
|
|
(0U !=
|
|
(LPUART_GetEnabledInterrupts(s_LpuartAdapterBase[instance]) & (uint32_t)kLPUART_IdleLineInterruptEnable)))
|
|
#endif
|
|
)
|
|
{
|
|
if (NULL != uartHandle->rx.buffer)
|
|
{
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
/* Get the size that can be stored into buffer for this interrupt. */
|
|
#if defined(FSL_FEATURE_LPUART_HAS_FIFO) && FSL_FEATURE_LPUART_HAS_FIFO
|
|
count = ((uint8_t)((s_LpuartAdapterBase[instance]->WATER & LPUART_WATER_RXCOUNT_MASK) >>
|
|
LPUART_WATER_RXCOUNT_SHIFT));
|
|
#else
|
|
if (0U != (status & (uint32_t)kLPUART_RxDataRegFullInterruptEnable))
|
|
{
|
|
count = 1U;
|
|
}
|
|
else
|
|
{
|
|
count = 0U;
|
|
}
|
|
#endif
|
|
while (0u != count)
|
|
{
|
|
count--;
|
|
#endif
|
|
uartHandle->rx.buffer[uartHandle->rx.bufferSofar++] = LPUART_ReadByte(s_LpuartAdapterBase[instance]);
|
|
if (uartHandle->rx.bufferSofar >= uartHandle->rx.bufferLength)
|
|
{
|
|
LPUART_DisableInterrupts(
|
|
s_LpuartAdapterBase[instance], (uint32_t)kLPUART_RxDataRegFullInterruptEnable |
|
|
(uint32_t)kLPUART_RxOverrunInterruptEnable
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
| (uint32_t)kLPUART_IdleLineInterruptEnable
|
|
#endif
|
|
);
|
|
uartHandle->rx.buffer = NULL;
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
count = 0u;
|
|
#endif
|
|
if (NULL != uartHandle->callback)
|
|
{
|
|
uartHandle->callback(uartHandle, kStatus_HAL_UartRxIdle, uartHandle->callbackParam);
|
|
}
|
|
}
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
}
|
|
#endif
|
|
}
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
if ((0U != ((uint32_t)kLPUART_IdleLineFlag & status)) &&
|
|
(0U !=
|
|
(LPUART_GetEnabledInterrupts(s_LpuartAdapterBase[instance]) & (uint32_t)kLPUART_IdleLineInterruptEnable)))
|
|
{
|
|
s_LpuartAdapterBase[instance]->STAT |= ((uint32_t)kLPUART_IdleLineFlag);
|
|
}
|
|
#endif
|
|
}
|
|
|
|
/* Send data register empty and the interrupt is enabled. */
|
|
if ((0U != (LPUART_STAT_TDRE_MASK & status)) && (0U != (LPUART_GetEnabledInterrupts(s_LpuartAdapterBase[instance]) &
|
|
(uint32_t)kLPUART_TxDataRegEmptyInterruptEnable)))
|
|
{
|
|
if (NULL != uartHandle->tx.buffer)
|
|
{
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
/* Get the size that transmit buffer for this interrupt. */
|
|
#if defined(FSL_FEATURE_LPUART_HAS_FIFO) && FSL_FEATURE_LPUART_HAS_FIFO
|
|
count = (uint8_t)FSL_FEATURE_LPUART_FIFO_SIZEn(s_LpuartAdapterBase[instance]) -
|
|
(uint8_t)((s_LpuartAdapterBase[instance]->WATER & LPUART_WATER_TXCOUNT_MASK) >>
|
|
LPUART_WATER_TXCOUNT_SHIFT);
|
|
#else
|
|
count = 1u;
|
|
#endif
|
|
while (0u != count)
|
|
{
|
|
count--;
|
|
#endif
|
|
LPUART_WriteByte(s_LpuartAdapterBase[instance], uartHandle->tx.buffer[uartHandle->tx.bufferSofar++]);
|
|
if (uartHandle->tx.bufferSofar >= uartHandle->tx.bufferLength)
|
|
{
|
|
LPUART_DisableInterrupts(s_LpuartAdapterBase[instance],
|
|
(uint32_t)kLPUART_TxDataRegEmptyInterruptEnable);
|
|
uartHandle->tx.buffer = NULL;
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
count = 0u;
|
|
#endif
|
|
if (NULL != uartHandle->callback)
|
|
{
|
|
uartHandle->callback(uartHandle, kStatus_HAL_UartTxIdle, uartHandle->callbackParam);
|
|
}
|
|
}
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
}
|
|
#endif
|
|
}
|
|
}
|
|
|
|
#if !(defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
(void)LPUART_ClearStatusFlags(s_LpuartAdapterBase[instance], status);
|
|
#endif
|
|
}
|
|
#endif /* HAL_UART_TRANSFER_MODE */
|
|
#if (defined(FSL_FEATURE_LPUART_IS_LPFLEXCOMM) && (FSL_FEATURE_LPUART_IS_LPFLEXCOMM > 0U))
|
|
static void HAL_LpUartInterruptHandle_Wapper(uint32_t instance, void *handle)
|
|
{
|
|
hal_uart_state_t *uartHandle = (hal_uart_state_t *)handle;
|
|
HAL_UartInterruptHandle(uartHandle->instance);
|
|
}
|
|
#endif /* FSL_FEATURE_LPUART_IS_LPFLEXCOMM */
|
|
|
|
#endif /* UART_ADAPTER_NON_BLOCKING_MODE */
|
|
|
|
static hal_uart_status_t HAL_UartInitCommon(hal_uart_handle_t handle, const hal_uart_config_t *uart_config)
|
|
{
|
|
lpuart_config_t lpuartConfig;
|
|
status_t status;
|
|
hal_uart_status_t uartStatus = kStatus_HAL_UartSuccess;
|
|
|
|
LPUART_GetDefaultConfig(&lpuartConfig);
|
|
lpuartConfig.baudRate_Bps = uart_config->baudRate_Bps;
|
|
lpuartConfig.parityMode = (lpuart_parity_mode_t)uart_config->parityMode;
|
|
lpuartConfig.stopBitCount = (lpuart_stop_bit_count_t)uart_config->stopBitCount;
|
|
lpuartConfig.enableRx = (bool)uart_config->enableRx;
|
|
lpuartConfig.enableTx = (bool)uart_config->enableTx;
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
#if defined(FSL_FEATURE_LPUART_HAS_FIFO) && FSL_FEATURE_LPUART_HAS_FIFO
|
|
if (uart_config->txFifoWatermark > 0U)
|
|
{
|
|
lpuartConfig.txFifoWatermark =
|
|
MIN(uart_config->txFifoWatermark,
|
|
(uint8_t)FSL_FEATURE_LPUART_FIFO_SIZEn(s_LpuartAdapterBase[uart_config->instance])) -
|
|
1U;
|
|
}
|
|
if (uart_config->rxFifoWatermark > 0U)
|
|
{
|
|
lpuartConfig.rxFifoWatermark =
|
|
MIN(uart_config->rxFifoWatermark,
|
|
(uint8_t)FSL_FEATURE_LPUART_FIFO_SIZEn(s_LpuartAdapterBase[uart_config->instance])) -
|
|
1U;
|
|
}
|
|
#endif
|
|
#endif
|
|
#if defined(FSL_FEATURE_LPUART_HAS_MODEM_SUPPORT) && FSL_FEATURE_LPUART_HAS_MODEM_SUPPORT
|
|
lpuartConfig.enableRxRTS = (bool)uart_config->enableRxRTS;
|
|
lpuartConfig.enableTxCTS = (bool)uart_config->enableTxCTS;
|
|
#endif /* FSL_FEATURE_LPUART_HAS_MODEM_SUPPORT */
|
|
|
|
/* Idleline config */
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
lpuartConfig.rxIdleType = kLPUART_IdleTypeStopBit;
|
|
lpuartConfig.rxIdleConfig = kLPUART_IdleCharacter2;
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
|
|
status = LPUART_Init(s_LpuartAdapterBase[uart_config->instance], (const void *)&lpuartConfig, uart_config->srcClock_Hz);
|
|
|
|
if ((int32_t)kStatus_Success != status)
|
|
{
|
|
uartStatus = HAL_UartGetStatus(status); /*Get current uart status*/
|
|
}
|
|
|
|
return uartStatus;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartInit(hal_uart_handle_t handle, const hal_uart_config_t *uart_config)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_status_t uartStatus;
|
|
assert(NULL != handle);
|
|
assert(NULL != uart_config);
|
|
assert(uart_config->instance < (sizeof(s_LpuartAdapterBase) / sizeof(LPUART_Type *)));
|
|
assert(NULL != s_LpuartAdapterBase[uart_config->instance]);
|
|
assert(HAL_UART_HANDLE_SIZE >= sizeof(hal_uart_state_t));
|
|
|
|
uartStatus = HAL_UartInitCommon(handle, uart_config);
|
|
|
|
if (kStatus_HAL_UartSuccess == uartStatus)
|
|
{
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartHandle->instance = uart_config->instance;
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
uartHandle->dmaHandle = NULL;
|
|
#endif /* HAL_UART_DMA_ENABLE */
|
|
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
#if (defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
LPUART_TransferCreateHandle(s_LpuartAdapterBase[uart_config->instance], &uartHandle->hardwareHandle,
|
|
(lpuart_transfer_callback_t)HAL_UartCallback, handle);
|
|
#else
|
|
s_UartState[uartHandle->instance] = uartHandle;
|
|
#if (defined(FSL_FEATURE_LPUART_IS_LPFLEXCOMM) && (FSL_FEATURE_LPUART_IS_LPFLEXCOMM > 0U))
|
|
LP_FLEXCOMM_SetIRQHandler(uart_config->instance, HAL_LpUartInterruptHandle_Wapper, handle,
|
|
LP_FLEXCOMM_PERIPH_LPUART);
|
|
#endif /* FSL_FEATURE_LPUART_IS_LPFLEXCOMM */
|
|
|
|
/* Enable interrupt in NVIC. */
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartRxIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartRxIRQ[uartHandle->instance]);
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartTxIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartTxIRQ[uartHandle->instance]);
|
|
#else
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
(void)EnableIRQ(s_LpuartIRQ[uartHandle->instance]);
|
|
#endif
|
|
#endif
|
|
|
|
#endif
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER) && (HAL_UART_ADAPTER_LOWPOWER > 0U))
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER_RESTORE) && (HAL_UART_ADAPTER_LOWPOWER_RESTORE > 0U))
|
|
uartHandle->reg_BAUD = s_LpuartAdapterBase[uartHandle->instance]->BAUD;
|
|
uartHandle->reg_CTRL = s_LpuartAdapterBase[uartHandle->instance]->CTRL;
|
|
uartHandle->reg_WATER = s_LpuartAdapterBase[uartHandle->instance]->WATER;
|
|
uartHandle->reg_MODIR = s_LpuartAdapterBase[uartHandle->instance]->MODIR;
|
|
#else
|
|
(void)memcpy(&uartHandle->config, uart_config, sizeof(hal_uart_config_t));
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
return uartStatus;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartDeinit(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
|
|
assert(NULL != handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
LPUART_Deinit(s_LpuartAdapterBase[uartHandle->instance]); /*LPUART Deinitialization*/
|
|
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
|
|
#if !(defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
s_UartState[uartHandle->instance] = NULL;
|
|
#endif
|
|
|
|
#endif
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartReceiveBlocking(hal_uart_handle_t handle, uint8_t *data, size_t length)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
status_t status;
|
|
assert(NULL != handle);
|
|
assert(NULL != data);
|
|
assert(length > 0U);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
status = LPUART_ReadBlocking(s_LpuartAdapterBase[uartHandle->instance], data, length);
|
|
|
|
return HAL_UartGetStatus(status);
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartSendBlocking(hal_uart_handle_t handle, const uint8_t *data, size_t length)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
|
|
assert(NULL != handle);
|
|
assert(NULL != data);
|
|
assert(length > 0U);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
(void)LPUART_WriteBlocking(s_LpuartAdapterBase[uartHandle->instance], data, length);
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartEnterLowpower(hal_uart_handle_t handle)
|
|
{
|
|
assert(NULL != handle);
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartExitLowpower(hal_uart_handle_t handle)
|
|
{
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER) && (HAL_UART_ADAPTER_LOWPOWER > 0U))
|
|
hal_uart_state_t *uartHandle;
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER_RESTORE) && (HAL_UART_ADAPTER_LOWPOWER_RESTORE > 0U))
|
|
#if !(defined(FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL) && FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL)
|
|
/* Enable lpuart clock */
|
|
CLOCK_EnableClock(s_LpuartAdapterClock[uartHandle->instance]);
|
|
#endif /* FSL_SDK_DISABLE_DRIVER_CLOCK_CONTROL */
|
|
s_LpuartAdapterBase[uartHandle->instance]->BAUD = uartHandle->reg_BAUD;
|
|
s_LpuartAdapterBase[uartHandle->instance]->WATER = uartHandle->reg_WATER;
|
|
s_LpuartAdapterBase[uartHandle->instance]->MODIR = uartHandle->reg_MODIR;
|
|
#if defined(FSL_FEATURE_LPUART_HAS_FIFO) && FSL_FEATURE_LPUART_HAS_FIFO
|
|
/* Enable tx/rx FIFO */
|
|
s_LpuartAdapterBase[uartHandle->instance]->FIFO |= (LPUART_FIFO_TXFE_MASK | LPUART_FIFO_RXFE_MASK);
|
|
/* Flush FIFO */
|
|
s_LpuartAdapterBase[uartHandle->instance]->FIFO |= (LPUART_FIFO_TXFLUSH_MASK | LPUART_FIFO_RXFLUSH_MASK);
|
|
#endif /* FSL_FEATURE_LPUART_HAS_FIFO */
|
|
s_LpuartAdapterBase[uartHandle->instance]->CTRL = uartHandle->reg_CTRL;
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
s_UartState[uartHandle->instance] = handle;
|
|
/* Enable interrupt in NVIC. */
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartRxIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartRxIRQ[uartHandle->instance]);
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartTxIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartTxIRQ[uartHandle->instance]);
|
|
#else
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
(void)EnableIRQ(s_LpuartIRQ[uartHandle->instance]);
|
|
#endif
|
|
s_LpuartAdapterBase[uartHandle->instance]->CTRL |= LPUART_CTRL_RIE_MASK;
|
|
HAL_UartIsrFunction(uartHandle);
|
|
|
|
#endif
|
|
#else
|
|
HAL_UartInit(handle, &uartHandle->config);
|
|
#endif
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else
|
|
/* Enable RX interrupt for detecting the IDLE line interrupt. */
|
|
LPUART_EnableInterrupts(s_LpuartAdapterBase[uartHandle->instance], kLPUART_IdleLineInterruptEnable);
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
HAL_UartDMAInit(uartHandle, uartHandle->dmaHandle, &uartHandle->dmaHandle->hal_uart_dma_config);
|
|
LPUART_StartRingBufferEDMA(handle);
|
|
ringBufferIndex[uartHandle->instance] = 0;
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
#endif
|
|
#endif
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
|
|
#if (defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
|
|
hal_uart_status_t HAL_UartTransferInstallCallback(hal_uart_handle_t handle,
|
|
hal_uart_transfer_callback_t callback,
|
|
void *callbackParam)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
|
|
assert(handle);
|
|
assert(0U != HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
uartHandle->callbackParam = callbackParam;
|
|
uartHandle->callback = callback;
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartTransferReceiveNonBlocking(hal_uart_handle_t handle, hal_uart_transfer_t *transfer)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
status_t status;
|
|
assert(handle);
|
|
assert(transfer);
|
|
assert(0U != HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
status = LPUART_TransferReceiveNonBlocking(s_LpuartAdapterBase[uartHandle->instance], &uartHandle->hardwareHandle,
|
|
(lpuart_transfer_t *)(void *)transfer, NULL);
|
|
|
|
return HAL_UartGetStatus(status);
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartTransferSendNonBlocking(hal_uart_handle_t handle, hal_uart_transfer_t *transfer)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
status_t status;
|
|
assert(handle);
|
|
assert(transfer);
|
|
assert(0U != HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
status = LPUART_TransferSendNonBlocking(s_LpuartAdapterBase[uartHandle->instance], &uartHandle->hardwareHandle,
|
|
(lpuart_transfer_t *)(void *)transfer);
|
|
|
|
return HAL_UartGetStatus(status);
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartTransferGetReceiveCount(hal_uart_handle_t handle, uint32_t *count)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
status_t status;
|
|
assert(handle);
|
|
assert(count);
|
|
assert(0U != HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
status =
|
|
LPUART_TransferGetReceiveCount(s_LpuartAdapterBase[uartHandle->instance], &uartHandle->hardwareHandle, count);
|
|
|
|
return HAL_UartGetStatus(status);
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartTransferGetSendCount(hal_uart_handle_t handle, uint32_t *count)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
status_t status;
|
|
assert(handle);
|
|
assert(count);
|
|
assert(0U != HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
status = LPUART_TransferGetSendCount(s_LpuartAdapterBase[uartHandle->instance], &uartHandle->hardwareHandle, count);
|
|
|
|
return HAL_UartGetStatus(status);
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartTransferAbortReceive(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(handle);
|
|
assert(0U != HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
LPUART_TransferAbortReceive(s_LpuartAdapterBase[uartHandle->instance], &uartHandle->hardwareHandle);
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartTransferAbortSend(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(handle);
|
|
assert(0U != HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
LPUART_TransferAbortSend(s_LpuartAdapterBase[uartHandle->instance], &uartHandle->hardwareHandle);
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
#else /* HAL_UART_TRANSFER_MODE */
|
|
|
|
/* None transactional API with non-blocking mode. */
|
|
hal_uart_status_t HAL_UartInstallCallback(hal_uart_handle_t handle,
|
|
hal_uart_transfer_callback_t callback,
|
|
void *callbackParam)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
|
|
assert(NULL != handle);
|
|
assert(0U == HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartHandle->callbackParam = callbackParam;
|
|
uartHandle->callback = callback;
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartReceiveNonBlocking(hal_uart_handle_t handle, uint8_t *data, size_t length)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(NULL != handle);
|
|
assert(NULL != data);
|
|
assert(length > 0U);
|
|
assert(0U == HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
if (NULL != uartHandle->rx.buffer)
|
|
{
|
|
return kStatus_HAL_UartRxBusy;
|
|
}
|
|
|
|
uartHandle->rx.bufferLength = length;
|
|
uartHandle->rx.bufferSofar = 0;
|
|
uartHandle->rx.buffer = data;
|
|
LPUART_EnableInterrupts(s_LpuartAdapterBase[uartHandle->instance], (uint32_t)kLPUART_RxDataRegFullInterruptEnable |
|
|
(uint32_t)kLPUART_RxOverrunInterruptEnable
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
| (uint32_t)kLPUART_IdleLineInterruptEnable
|
|
#endif
|
|
);
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartSendNonBlocking(hal_uart_handle_t handle, uint8_t *data, size_t length)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(NULL != handle);
|
|
assert(NULL != data);
|
|
assert(length > 0U);
|
|
assert(0U == HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
if (NULL != uartHandle->tx.buffer)
|
|
{
|
|
return kStatus_HAL_UartTxBusy;
|
|
}
|
|
uartHandle->tx.bufferLength = length;
|
|
uartHandle->tx.bufferSofar = 0;
|
|
uartHandle->tx.buffer = data;
|
|
LPUART_EnableInterrupts(s_LpuartAdapterBase[uartHandle->instance], (uint32_t)kLPUART_TxDataRegEmptyInterruptEnable);
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartGetReceiveCount(hal_uart_handle_t handle, uint32_t *reCount)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(NULL != handle);
|
|
assert(NULL != reCount);
|
|
assert(0U == HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
if (NULL != uartHandle->rx.buffer)
|
|
{
|
|
*reCount = uartHandle->rx.bufferSofar;
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
return kStatus_HAL_UartError;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartGetSendCount(hal_uart_handle_t handle, uint32_t *seCount)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(NULL != handle);
|
|
assert(NULL != seCount);
|
|
assert(0U == HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
if (NULL != uartHandle->tx.buffer)
|
|
{
|
|
*seCount = uartHandle->tx.bufferSofar;
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
return kStatus_HAL_UartError;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartAbortReceive(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(NULL != handle);
|
|
assert(0U == HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
if (NULL != uartHandle->rx.buffer)
|
|
{
|
|
LPUART_DisableInterrupts(
|
|
s_LpuartAdapterBase[uartHandle->instance],
|
|
(uint32_t)kLPUART_RxDataRegFullInterruptEnable | (uint32_t)kLPUART_RxOverrunInterruptEnable);
|
|
uartHandle->rx.buffer = NULL;
|
|
}
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
hal_uart_status_t HAL_UartAbortSend(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(NULL != handle);
|
|
assert(0U == HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
if (NULL != uartHandle->tx.buffer)
|
|
{
|
|
LPUART_DisableInterrupts(s_LpuartAdapterBase[uartHandle->instance],
|
|
(uint32_t)kLPUART_TxDataRegEmptyInterruptEnable);
|
|
uartHandle->tx.buffer = NULL;
|
|
}
|
|
|
|
return kStatus_HAL_UartSuccess;
|
|
}
|
|
|
|
#endif /* HAL_UART_TRANSFER_MODE */
|
|
|
|
#if (defined(HAL_UART_TRANSFER_MODE) && (HAL_UART_TRANSFER_MODE > 0U))
|
|
|
|
void HAL_UartIsrFunction(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(NULL != handle);
|
|
assert(0U != HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
|
|
#if 0
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
DisableIRQ(s_LpuartRxIRQ[uartHandle->instance]);
|
|
DisableIRQ(s_LpuartTxIRQ[uartHandle->instance]);
|
|
#else
|
|
DisableIRQ(s_LpuartIRQ[uartHandle->instance]);
|
|
#endif
|
|
#endif
|
|
LPUART_TransferHandleIRQ(s_LpuartAdapterBase[uartHandle->instance], &uartHandle->hardwareHandle);
|
|
#if 0
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartRxIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartRxIRQ[uartHandle->instance]);
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartTxIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartTxIRQ[uartHandle->instance]);
|
|
#else
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartIRQ[uartHandle->instance]);
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
#else /* HAL_UART_TRANSFER_MODE */
|
|
|
|
void HAL_UartIsrFunction(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
assert(NULL != handle);
|
|
assert(0U == HAL_UART_TRANSFER_MODE);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
hal_uart_dma_state_t *uartDmaHandle = s_UartDmaState[uartHandle->instance];
|
|
#endif
|
|
#if 0
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
DisableIRQ(s_LpuartRxIRQ[uartHandle->instance]);
|
|
DisableIRQ(s_LpuartTxIRQ[uartHandle->instance]);
|
|
#else
|
|
DisableIRQ(s_LpuartIRQ[uartHandle->instance]);
|
|
#endif
|
|
#endif
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
if ((NULL != uartDmaHandle) && (uartDmaHandle->dma_tx.buffer != NULL))
|
|
{
|
|
EDMA_HandleIRQ(&uartHandle->dmaHandle->txEdmaHandle);
|
|
}
|
|
#endif
|
|
#endif
|
|
|
|
HAL_UartInterruptHandle(uartHandle->instance);
|
|
|
|
#if 0
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartRxIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartRxIRQ[uartHandle->instance]);
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartTxIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartTxIRQ[uartHandle->instance]);
|
|
#else
|
|
NVIC_SetPriority((IRQn_Type)s_LpuartIRQ[uartHandle->instance], HAL_UART_ISR_PRIORITY);
|
|
EnableIRQ(s_LpuartIRQ[uartHandle->instance]);
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1) && FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART0_LPUART1_RX_IRQHandler(void)
|
|
{
|
|
if ((s_UartState[0]))
|
|
{
|
|
if ((LPUART_STAT_OR_MASK & LPUART0->STAT) ||
|
|
((LPUART_STAT_RDRF_MASK & LPUART0->STAT) && (LPUART_CTRL_RIE_MASK & LPUART0->CTRL)) ||
|
|
((LPUART_STAT_IDLE_MASK & LPUART0->STAT) && (LPUART_STAT_IDLE_MASK & LPUART0->CTRL)))
|
|
{
|
|
HAL_UartInterruptHandle(0);
|
|
}
|
|
}
|
|
if ((s_UartState[1]))
|
|
{
|
|
if ((LPUART_STAT_OR_MASK & LPUART1->STAT) ||
|
|
((LPUART_STAT_RDRF_MASK & LPUART1->STAT) && (LPUART_CTRL_RIE_MASK & LPUART1->CTRL)) ||
|
|
((LPUART_STAT_IDLE_MASK & LPUART1->STAT) && (LPUART_STAT_IDLE_MASK & LPUART1->CTRL)))
|
|
{
|
|
HAL_UartInterruptHandle(1);
|
|
}
|
|
}
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART0_LPUART1_TX_IRQHandler(void)
|
|
{
|
|
if ((s_UartState[0]))
|
|
{
|
|
if ((LPUART_STAT_OR_MASK & LPUART0->STAT) ||
|
|
((LPUART0->STAT & LPUART_STAT_TDRE_MASK) && (LPUART0->CTRL & LPUART_CTRL_TIE_MASK)) ||
|
|
((LPUART_CTRL_TCIE_MASK & LPUART0->STAT) && (LPUART_CTRL_TCIE_MASK & LPUART0->CTRL)))
|
|
{
|
|
HAL_UartInterruptHandle(0);
|
|
}
|
|
}
|
|
if ((s_UartState[1]))
|
|
{
|
|
if ((LPUART_STAT_OR_MASK & LPUART1->STAT) ||
|
|
((LPUART1->STAT & LPUART_STAT_TDRE_MASK) && (LPUART1->CTRL & LPUART_CTRL_TIE_MASK)) ||
|
|
((LPUART_CTRL_TCIE_MASK & LPUART1->STAT) && (LPUART_CTRL_TCIE_MASK & LPUART1->CTRL)))
|
|
{
|
|
HAL_UartInterruptHandle(1);
|
|
}
|
|
}
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else /* FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ */
|
|
void LPUART0_LPUART1_IRQHandler(void);
|
|
void LPUART0_LPUART1_IRQHandler(void)
|
|
{
|
|
uint32_t orMask;
|
|
uint32_t rdrfMask;
|
|
uint32_t rieMask;
|
|
uint32_t tdreMask;
|
|
uint32_t tieMask;
|
|
uint32_t ilieMask;
|
|
uint32_t tcieMask;
|
|
if (NULL != (s_UartState[0]))
|
|
{
|
|
orMask = LPUART_STAT_OR_MASK & LPUART0->STAT;
|
|
rdrfMask = LPUART_STAT_RDRF_MASK & LPUART0->STAT;
|
|
rieMask = LPUART_CTRL_RIE_MASK & LPUART0->CTRL;
|
|
tdreMask = LPUART0->STAT & LPUART_STAT_TDRE_MASK;
|
|
tieMask = LPUART0->CTRL & LPUART_CTRL_TIE_MASK;
|
|
ilieMask = LPUART0->STAT & LPUART_CTRL_ILIE_MASK;
|
|
tcieMask = LPUART0->STAT & LPUART_CTRL_TCIE_MASK;
|
|
if ((bool)orMask || ((bool)rdrfMask && (bool)rieMask) || ((bool)tdreMask && (bool)tieMask) || (bool)ilieMask ||
|
|
(bool)tcieMask)
|
|
{
|
|
HAL_UartInterruptHandle(0);
|
|
}
|
|
}
|
|
if (NULL != (s_UartState[1]))
|
|
{
|
|
orMask = LPUART_STAT_OR_MASK & LPUART1->STAT;
|
|
rdrfMask = LPUART_STAT_RDRF_MASK & LPUART1->STAT;
|
|
rieMask = LPUART_CTRL_RIE_MASK & LPUART1->CTRL;
|
|
tdreMask = LPUART1->STAT & LPUART_STAT_TDRE_MASK;
|
|
tieMask = LPUART1->CTRL & LPUART_CTRL_TIE_MASK;
|
|
ilieMask = LPUART1->STAT & LPUART_CTRL_ILIE_MASK;
|
|
tcieMask = LPUART1->STAT & LPUART_CTRL_TCIE_MASK;
|
|
if ((bool)orMask || ((bool)rdrfMask && (bool)rieMask) || ((bool)tdreMask && (bool)tieMask) || (bool)ilieMask ||
|
|
(bool)tcieMask)
|
|
{
|
|
HAL_UartInterruptHandle(1);
|
|
}
|
|
}
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif /* FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ */
|
|
#endif /* FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1 */
|
|
|
|
#if defined(LPUART0)
|
|
#if !(defined(FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1) && FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART0_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(0);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART0_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(0);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART0_IRQHandler(void);
|
|
void LPUART0_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(0);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif /* FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ */
|
|
#endif /* FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1 */
|
|
#endif /* LPUART0 */
|
|
|
|
#if defined(LPUART1)
|
|
#if !(defined(FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1) && FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART1_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(1);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART1_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(1);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else /* FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ */
|
|
void LPUART1_IRQHandler(void);
|
|
void LPUART1_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(1);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif /* FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ */
|
|
#endif /* FSL_FEATURE_LPUART_HAS_SHARED_IRQ0_IRQ1 */
|
|
#endif /* LPUART1 */
|
|
|
|
#if defined(LPUART2)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART2_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(2);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART2_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(2);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART2_IRQHandler(void);
|
|
void LPUART2_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(2);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART2 */
|
|
|
|
#if defined(LPUART3)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART3_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(3);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART3_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(3);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART3_IRQHandler(void);
|
|
void LPUART3_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(3);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART3 */
|
|
|
|
#if defined(LPUART4)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART4_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(4);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART4_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(4);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART4_IRQHandler(void);
|
|
void LPUART4_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(4);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART4 */
|
|
|
|
#if defined(LPUART5)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART5_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(5);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART5_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(5);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART5_IRQHandler(void);
|
|
void LPUART5_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(5);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART5 */
|
|
|
|
#if defined(LPUART6)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART6_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(6);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART6_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(6);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART6_IRQHandler(void);
|
|
void LPUART6_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(6);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART6 */
|
|
|
|
#if defined(LPUART7)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART7_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(7);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART7_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(7);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART7_IRQHandler(void);
|
|
void LPUART7_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(7);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART7 */
|
|
|
|
#if defined(LPUART8)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART8_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(8);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART8_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(8);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART8_IRQHandler(void);
|
|
void LPUART8_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(8);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART8 */
|
|
|
|
#if defined(LPUART9)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART9_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(9);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART9_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(9);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART9_IRQHandler(void);
|
|
void LPUART9_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(9);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART9 */
|
|
|
|
#if defined(LPUART10)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART10_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(10);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART10_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(10);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART10_IRQHandler(void);
|
|
void LPUART10_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(10);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART10 */
|
|
|
|
#if defined(LPUART11)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART11_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(11);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART11_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(11);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART11_IRQHandler(void);
|
|
void LPUART11_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(11);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART11 */
|
|
|
|
#if defined(LPUART12)
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
void LPUART12_TX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(12);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
void LPUART12_RX_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(12);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#else
|
|
void LPUART12_IRQHandler(void);
|
|
void LPUART12_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(12);
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
#endif /* LPUART12 */
|
|
|
|
#if defined(CM4_0__LPUART)
|
|
void M4_0_LPUART_IRQHandler(void);
|
|
void M4_0_LPUART_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(LPUART_GetInstance(CM4_0__LPUART));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(CM4_1__LPUART)
|
|
void M4_1_LPUART_IRQHandler(void);
|
|
void M4_1_LPUART_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(LPUART_GetInstance(CM4_1__LPUART));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(CM4__LPUART)
|
|
void M4_LPUART_IRQHandler(void);
|
|
void M4_LPUART_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle((uint8_t)LPUART_GetInstance(CM4__LPUART));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(DMA__LPUART0)
|
|
void DMA_UART0_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(LPUART_GetInstance(DMA__LPUART0));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(DMA__LPUART1)
|
|
void DMA_UART1_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(LPUART_GetInstance(DMA__LPUART1));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(DMA__LPUART2)
|
|
void DMA_UART2_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(LPUART_GetInstance(DMA__LPUART2));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(DMA__LPUART3)
|
|
void DMA_UART3_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(LPUART_GetInstance(DMA__LPUART3));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(DMA__LPUART4)
|
|
void DMA_UART4_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle(LPUART_GetInstance(DMA__LPUART4));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(ADMA__LPUART0)
|
|
void ADMA_UART0_INT_IRQHandler(void);
|
|
void ADMA_UART0_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle((uint8_t)LPUART_GetInstance(ADMA__LPUART0));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(ADMA__LPUART1)
|
|
void ADMA_UART1_INT_IRQHandler(void);
|
|
void ADMA_UART1_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle((uint8_t)LPUART_GetInstance(ADMA__LPUART1));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(ADMA__LPUART2)
|
|
void ADMA_UART2_INT_IRQHandler(void);
|
|
void ADMA_UART2_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle((uint8_t)LPUART_GetInstance(ADMA__LPUART2));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#if defined(ADMA__LPUART3)
|
|
void ADMA_UART3_INT_IRQHandler(void);
|
|
void ADMA_UART3_INT_IRQHandler(void)
|
|
{
|
|
HAL_UartInterruptHandle((uint8_t)LPUART_GetInstance(ADMA__LPUART3));
|
|
SDK_ISR_EXIT_BARRIER;
|
|
}
|
|
#endif
|
|
|
|
#endif /* HAL_UART_TRANSFER_MODE */
|
|
|
|
#endif /* UART_ADAPTER_NON_BLOCKING_MODE */
|
|
|
|
#if (defined(HAL_UART_DMA_ENABLE) && (HAL_UART_DMA_ENABLE > 0U))
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
static volatile uint32_t ringBufferFlag = 0U;
|
|
/* LPUART RX EDMA call back. */
|
|
static void LPUART_RxEDMACallback(edma_handle_t *handle, void *param, bool transferDone, uint32_t tcds)
|
|
{
|
|
if (true == transferDone)
|
|
{
|
|
ringBufferFlag++;
|
|
}
|
|
}
|
|
|
|
/* Start ring buffer. */
|
|
static void LPUART_StartRingBufferEDMA(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
edma_transfer_config_t xferConfig;
|
|
|
|
/* Install TCD memory for using only one TCD queue. */
|
|
EDMA_InstallTCDMemory(&uartDmaHandle->rxEdmaHandle, (edma_tcd_t *)&tcdMemoryPoolPtr[uartHandle->instance], 1U);
|
|
|
|
/* Prepare transfer to receive data to ring buffer. */
|
|
EDMA_PrepareTransfer(&xferConfig,
|
|
(void *)(uint32_t *)LPUART_GetDataRegisterAddress(s_LpuartAdapterBase[uartHandle->instance]),
|
|
sizeof(uint8_t), &s_ringBuffer[uartHandle->instance], sizeof(uint8_t), sizeof(uint8_t),
|
|
LPUART_RING_BUFFER_SIZE, kEDMA_PeripheralToMemory);
|
|
|
|
/* Submit transfer. */
|
|
uartDmaHandle->rxEdmaHandle.tcdUsed = 1U;
|
|
uartDmaHandle->rxEdmaHandle.tail = 0U;
|
|
EDMA_TcdReset(&uartDmaHandle->rxEdmaHandle.tcdPool[0U]);
|
|
EDMA_TcdSetTransferConfig(&uartDmaHandle->rxEdmaHandle.tcdPool[0U], &xferConfig,
|
|
tcdMemoryPoolPtr[uartHandle->instance]);
|
|
|
|
/* Enable major interrupt for counting received bytes. */
|
|
uartDmaHandle->rxEdmaHandle.tcdPool[0U].CSR |= 0x2U;
|
|
|
|
/* There is no live chain, TCD block need to be installed in TCD registers. */
|
|
EDMA_InstallTCD(uartDmaHandle->rxEdmaHandle.base, uartDmaHandle->rxEdmaHandle.channel,
|
|
&uartDmaHandle->rxEdmaHandle.tcdPool[0U]);
|
|
|
|
/* Setup call back function. */
|
|
EDMA_SetCallback(&uartDmaHandle->rxEdmaHandle, LPUART_RxEDMACallback, NULL);
|
|
|
|
/* Start EDMA transfer. */
|
|
EDMA_StartTransfer(&uartDmaHandle->rxEdmaHandle);
|
|
|
|
/* Enable LPUART RX EDMA. */
|
|
LPUART_EnableRxDMA(s_LpuartAdapterBase[uartHandle->instance], true);
|
|
|
|
/* Enable RX interrupt for detecting the IDLE line interrupt. */
|
|
LPUART_EnableInterrupts(s_LpuartAdapterBase[uartHandle->instance], (uint32_t)kLPUART_IdleLineInterruptEnable);
|
|
// EnableIRQ(s_LpuartRxIRQ[uartHandle->instance]);
|
|
}
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
static void LPUART_DMACallbacks(LPUART_Type *base, lpuart_edma_handle_t *handle, status_t status, void *userData)
|
|
{
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
hal_uart_status_t uartStatus = HAL_UartGetStatus(status);
|
|
hal_dma_callback_msg_t msg;
|
|
assert(handle);
|
|
|
|
uartDmaHandle = (hal_uart_dma_state_t *)userData;
|
|
|
|
if (NULL != uartDmaHandle->dma_callback)
|
|
{
|
|
if (kStatus_HAL_UartTxIdle == uartStatus)
|
|
{
|
|
msg.status = kStatus_HAL_UartDmaTxIdle;
|
|
msg.data = uartDmaHandle->dma_tx.buffer;
|
|
msg.dataSize = uartDmaHandle->dma_tx.bufferLength;
|
|
uartDmaHandle->dma_tx.buffer = NULL;
|
|
}
|
|
else if (kStatus_HAL_UartRxIdle == uartStatus)
|
|
{
|
|
msg.status = kStatus_HAL_UartDmaRxIdle;
|
|
msg.data = uartDmaHandle->dma_rx.buffer;
|
|
msg.dataSize = uartDmaHandle->dma_rx.bufferLength;
|
|
uartDmaHandle->dma_rx.buffer = NULL;
|
|
}
|
|
else
|
|
{
|
|
/* MISRA */
|
|
}
|
|
|
|
uartDmaHandle->dma_callback(uartDmaHandle, &msg, uartDmaHandle->dma_callback_param);
|
|
}
|
|
}
|
|
#endif
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
static void TimeoutTimer_Callbcak(void *param)
|
|
{
|
|
hal_lpuart_dma_list_t *uartDmaHandleList;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
hal_dma_callback_msg_t msg;
|
|
uint32_t newReceived = 0U;
|
|
|
|
uartDmaHandleList = (hal_lpuart_dma_list_t *)param;
|
|
uartDmaHandle = uartDmaHandleList->dma_list;
|
|
|
|
while (NULL != uartDmaHandle)
|
|
{
|
|
if ((NULL != uartDmaHandle->dma_rx.buffer) && (false == uartDmaHandle->dma_rx.receiveAll))
|
|
{
|
|
/* HAL_UartDMAGetReceiveCount(uartDmaHandle, &msg.dataSize); */
|
|
#if (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
|
|
#elif (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
LPUART_TransferGetReceiveCountEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle,
|
|
&msg.dataSize);
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
newReceived = msg.dataSize - uartDmaHandle->dma_rx.bufferSofar;
|
|
uartDmaHandle->dma_rx.bufferSofar = msg.dataSize;
|
|
|
|
/* 1, If it is in idle state. */
|
|
if ((0U == newReceived) && (0U < uartDmaHandle->dma_rx.bufferSofar))
|
|
{
|
|
uartDmaHandle->dma_rx.timeout++;
|
|
if (uartDmaHandle->dma_rx.timeout >= HAL_UART_DMA_IDLELINE_TIMEOUT)
|
|
{
|
|
/* HAL_UartDMAAbortReceive(uartDmaHandle); */
|
|
#if (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
|
|
#elif (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
LPUART_TransferAbortReceiveEDMA(s_LpuartAdapterBase[uartDmaHandle->instance],
|
|
&uartDmaHandle->edmaHandle);
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
msg.data = uartDmaHandle->dma_rx.buffer;
|
|
msg.status = kStatus_HAL_UartDmaIdleline;
|
|
uartDmaHandle->dma_rx.buffer = NULL;
|
|
uartDmaHandle->dma_callback(uartDmaHandle, &msg, uartDmaHandle->dma_callback_param);
|
|
}
|
|
}
|
|
/* 2, If got new data again. */
|
|
if ((0U < newReceived) && (0U < uartDmaHandle->dma_rx.bufferSofar))
|
|
{
|
|
uartDmaHandle->dma_rx.timeout = 0U;
|
|
}
|
|
}
|
|
|
|
uartDmaHandle = uartDmaHandle->next;
|
|
}
|
|
}
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
|
|
hal_uart_dma_status_t HAL_UartDMAInit(hal_uart_handle_t handle,
|
|
hal_uart_dma_handle_t dmaHandle,
|
|
hal_uart_dma_config_t *dmaConfig)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
#if (defined(HAL_UART_DMA_INIT_ENABLE) && (HAL_UART_DMA_INIT_ENABLE > 0U))
|
|
edma_config_t config;
|
|
#endif /* HAL_UART_DMA_INIT_ENABLE > 0 */
|
|
#endif
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = (hal_uart_dma_state_t *)dmaHandle;
|
|
uartHandle->dmaHandle = uartDmaHandle;
|
|
|
|
/* DMA init process. */
|
|
uartDmaHandle->instance = dmaConfig->uart_instance;
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
#if (defined(FSL_FEATURE_SOC_DMAMUX_COUNT) && (FSL_FEATURE_SOC_DMAMUX_COUNT > 0U))
|
|
dma_mux_configure_t *dmaMux = dmaConfig->dma_mux_configure;
|
|
/* Set channel for LPUART */
|
|
DMAMUX_Type *dmaMuxBases[] = DMAMUX_BASE_PTRS;
|
|
DMAMUX_Init(dmaMuxBases[dmaMux->dma_dmamux_configure.dma_mux_instance]);
|
|
DMAMUX_SetSource(dmaMuxBases[dmaMux->dma_dmamux_configure.dma_mux_instance], dmaConfig->tx_channel,
|
|
dmaMux->dma_dmamux_configure.tx_request);
|
|
DMAMUX_SetSource(dmaMuxBases[dmaMux->dma_dmamux_configure.dma_mux_instance], dmaConfig->rx_channel,
|
|
dmaMux->dma_dmamux_configure.rx_request);
|
|
DMAMUX_EnableChannel(dmaMuxBases[dmaMux->dma_dmamux_configure.dma_mux_instance], dmaConfig->tx_channel);
|
|
DMAMUX_EnableChannel(dmaMuxBases[dmaMux->dma_dmamux_configure.dma_mux_instance], dmaConfig->rx_channel);
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER) && (HAL_UART_ADAPTER_LOWPOWER > 0U))
|
|
(void)memcpy(&uartDmaHandle->dma_mux_configure, dmaConfig->dma_mux_configure, sizeof(dma_mux_configure_t));
|
|
#endif /* HAL_UART_ADAPTER_LOWPOWER */
|
|
#endif /* FSL_FEATURE_SOC_DMAMUX_COUNT */
|
|
/* Init the EDMA module */
|
|
#if defined(EDMA_BASE_PTRS)
|
|
EDMA_Type *dmaBases[] = EDMA_BASE_PTRS;
|
|
IRQn_Type s_edmaIRQNumbers[][FSL_FEATURE_EDMA_MODULE_MAX_CHANNEL] = EDMA_CHN_IRQS;
|
|
#elif (defined(FSL_FEATURE_LPUART_IS_LPFLEXCOMM) && (FSL_FEATURE_LPUART_IS_LPFLEXCOMM > 0U))
|
|
DMA_Type *dmaBases[] = DMA_BASE_PTRS;
|
|
IRQn_Type s_edmaIRQNumbers[][FSL_FEATURE_EDMA_MODULE_MAX_CHANNEL] = DMA_CHN_IRQS;
|
|
#else
|
|
DMA_Type *dmaBases[] = DMA_BASE_PTRS;
|
|
IRQn_Type s_edmaIRQNumbers[][FSL_FEATURE_EDMA_MODULE_CHANNEL] = DMA_CHN_IRQS;
|
|
#endif
|
|
|
|
#if (defined(HAL_UART_DMA_INIT_ENABLE) && (HAL_UART_DMA_INIT_ENABLE > 0U))
|
|
EDMA_GetDefaultConfig(&config);
|
|
#if defined FSL_FEATURE_EDMA_HAS_CHANNEL_CONFIG && FSL_FEATURE_EDMA_HAS_CHANNEL_CONFIG
|
|
edma_channel_config_t channelConfig = {
|
|
.enableMasterIDReplication = true,
|
|
.securityLevel = kEDMA_ChannelSecurityLevelSecure,
|
|
.protectionLevel = kEDMA_ChannelProtectionLevelPrivileged,
|
|
};
|
|
|
|
config.enableMasterIdReplication = true;
|
|
config.channelConfig[dmaConfig->tx_channel] = &channelConfig;
|
|
config.channelConfig[dmaConfig->rx_channel] = &channelConfig;
|
|
#endif
|
|
EDMA_Init(dmaBases[dmaConfig->dma_instance], &config);
|
|
#endif /* HAL_UART_DMA_INIT_ENABLE > 0 */
|
|
EDMA_CreateHandle(&uartDmaHandle->txEdmaHandle, dmaBases[dmaConfig->dma_instance], dmaConfig->tx_channel);
|
|
EDMA_CreateHandle(&uartDmaHandle->rxEdmaHandle, dmaBases[dmaConfig->dma_instance], dmaConfig->rx_channel);
|
|
#if (defined(FSL_FEATURE_EDMA_HAS_CHANNEL_MUX) && (FSL_FEATURE_EDMA_HAS_CHANNEL_MUX > 0U))
|
|
dma_channel_mux_configure_t *dmaChannelMux = dmaConfig->dma_channel_mux_configure;
|
|
EDMA_SetChannelMux(dmaBases[dmaConfig->dma_instance], dmaConfig->tx_channel,
|
|
(dma_request_source_t)dmaChannelMux->dma_dmamux_configure.dma_tx_channel_mux);
|
|
EDMA_SetChannelMux(dmaBases[dmaConfig->dma_instance], dmaConfig->rx_channel,
|
|
(dma_request_source_t)dmaChannelMux->dma_dmamux_configure.dma_rx_channel_mux);
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER) && (HAL_UART_ADAPTER_LOWPOWER > 0U))
|
|
(void)memcpy(&uartDmaHandle->dma_channel_mux_configure, dmaConfig->dma_channel_mux_configure,
|
|
sizeof(dma_channel_mux_configure_t));
|
|
#endif /* HAL_UART_ADAPTER_LOWPOWER */
|
|
#endif /* FSL_FEATURE_EDMA_HAS_CHANNEL_MUX */
|
|
#if (defined(HAL_UART_ADAPTER_LOWPOWER) && (HAL_UART_ADAPTER_LOWPOWER > 0U))
|
|
(void)memcpy(&uartDmaHandle->hal_uart_dma_config, dmaConfig, sizeof(hal_uart_dma_config_t));
|
|
uartDmaHandle->hal_uart_dma_config.dma_mux_configure = &uartDmaHandle->dma_mux_configure;
|
|
uartDmaHandle->hal_uart_dma_config.dma_channel_mux_configure = &uartDmaHandle->dma_channel_mux_configure;
|
|
#endif /* HAL_UART_ADAPTER_LOWPOWER */
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
NVIC_SetPriority(s_edmaIRQNumbers[dmaConfig->dma_instance][dmaConfig->tx_channel], HAL_UART_ISR_PRIORITY);
|
|
NVIC_SetPriority(s_edmaIRQNumbers[dmaConfig->dma_instance][dmaConfig->rx_channel], HAL_UART_ISR_PRIORITY);
|
|
#endif
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
s_UartDmaState[uartDmaHandle->instance] = uartDmaHandle;
|
|
|
|
/* Enable RX interrupt for detecting the IDLE line interrupt. */
|
|
LPUART_EnableInterrupts(s_LpuartAdapterBase[uartHandle->instance], (uint32_t)kLPUART_IdleLineInterruptEnable);
|
|
#if defined(FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ) && FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ
|
|
(void)EnableIRQ(s_LpuartRxIRQ[uartHandle->instance]);
|
|
#else /* FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ */
|
|
(void)EnableIRQ(s_LpuartIRQ[uartHandle->instance]);
|
|
#endif /* FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ */
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
|
|
if (0 == s_dmaHandleList.activeCount)
|
|
{
|
|
s_dmaHandleList.dma_list = uartDmaHandle;
|
|
uartDmaHandle->next = NULL;
|
|
s_dmaHandleList.activeCount++;
|
|
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
timer_status_t timerStatus;
|
|
timerStatus = TM_Open((timer_handle_t)s_dmaHandleList.timerManagerHandle);
|
|
assert(kStatus_TimerSuccess == timerStatus);
|
|
|
|
timerStatus = TM_InstallCallback((timer_handle_t)s_dmaHandleList.timerManagerHandle, TimeoutTimer_Callbcak,
|
|
&s_dmaHandleList);
|
|
assert(kStatus_TimerSuccess == timerStatus);
|
|
|
|
(void)TM_Start((timer_handle_t)s_dmaHandleList.timerManagerHandle, (uint8_t)kTimerModeIntervalTimer, 1);
|
|
|
|
(void)timerStatus;
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
}
|
|
else
|
|
{
|
|
uartDmaHandle->next = s_dmaHandleList.dma_list;
|
|
s_dmaHandleList.dma_list = uartDmaHandle;
|
|
}
|
|
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
|
|
hal_uart_dma_status_t HAL_UartDMADeinit(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
hal_uart_dma_state_t *prev;
|
|
hal_uart_dma_state_t *curr;
|
|
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
uartHandle->dmaHandle = NULL;
|
|
|
|
assert(uartDmaHandle);
|
|
|
|
/* Abort rx/tx */
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
/* Here we should not abort before create transfer handle. */
|
|
if (NULL != uartDmaHandle->edmaHandle.rxEdmaHandle)
|
|
{
|
|
LPUART_TransferAbortReceiveEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle);
|
|
}
|
|
if (NULL != uartDmaHandle->edmaHandle.txEdmaHandle)
|
|
{
|
|
LPUART_TransferAbortSendEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle);
|
|
}
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
|
|
/* Disable rx/tx channels */
|
|
|
|
/* Remove handle from list */
|
|
prev = NULL;
|
|
curr = s_dmaHandleList.dma_list;
|
|
while (curr != NULL)
|
|
{
|
|
if (curr == uartDmaHandle)
|
|
{
|
|
/* 1, if it is the first one */
|
|
if (prev == NULL)
|
|
{
|
|
s_dmaHandleList.dma_list = curr->next;
|
|
}
|
|
/* 2, if it is the last one */
|
|
else if (curr->next == NULL)
|
|
{
|
|
prev->next = NULL;
|
|
}
|
|
/* 3, if it is in the middle */
|
|
else
|
|
{
|
|
prev->next = curr->next;
|
|
}
|
|
break;
|
|
}
|
|
|
|
prev = curr;
|
|
curr = curr->next;
|
|
}
|
|
|
|
/* Reset all handle data. */
|
|
(void)memset(uartDmaHandle, 0, sizeof(hal_uart_dma_state_t));
|
|
|
|
s_dmaHandleList.activeCount = (s_dmaHandleList.activeCount > 0) ? (s_dmaHandleList.activeCount - 1) : 0;
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
if (0 == s_dmaHandleList.activeCount)
|
|
{
|
|
(void)TM_Close((timer_handle_t)s_dmaHandleList.timerManagerHandle);
|
|
}
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
|
|
hal_uart_dma_status_t HAL_UartDMATransferInstallCallback(hal_uart_handle_t handle,
|
|
hal_uart_dma_transfer_callback_t callback,
|
|
void *callbackParam)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
assert(uartDmaHandle);
|
|
|
|
uartDmaHandle->dma_callback = callback;
|
|
uartDmaHandle->dma_callback_param = callbackParam;
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
LPUART_TransferCreateHandleEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle,
|
|
LPUART_DMACallbacks, uartDmaHandle, &uartDmaHandle->txEdmaHandle,
|
|
&uartDmaHandle->rxEdmaHandle);
|
|
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
#if (defined(FSL_FEATURE_LPUART_IS_LPFLEXCOMM) && (FSL_FEATURE_LPUART_IS_LPFLEXCOMM > 0U))
|
|
LP_FLEXCOMM_SetIRQHandler(uartHandle->instance, HAL_LpUartInterruptHandle_Wapper, handle,
|
|
LP_FLEXCOMM_PERIPH_LPUART);
|
|
#endif /* FSL_FEATURE_LPUART_IS_LPFLEXCOMM */
|
|
#endif /* UART_ADAPTER_NON_BLOCKING_MODE */
|
|
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
LPUART_StartRingBufferEDMA(handle);
|
|
#endif /* HAL_UART_DMA_RING_BUFFER_ENABLE */
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
|
|
hal_uart_dma_status_t HAL_UartDMATransferReceive(hal_uart_handle_t handle,
|
|
uint8_t *data,
|
|
size_t length,
|
|
bool receiveAll)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
|
|
assert(handle);
|
|
assert(data);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
assert(uartDmaHandle);
|
|
|
|
if (NULL == uartDmaHandle->dma_rx.buffer)
|
|
{
|
|
uartDmaHandle->dma_rx.buffer = data;
|
|
uartDmaHandle->dma_rx.bufferLength = length;
|
|
uartDmaHandle->dma_rx.bufferSofar = 0U;
|
|
uartDmaHandle->dma_rx.timeout = 0U;
|
|
uartDmaHandle->dma_rx.receiveAll = receiveAll;
|
|
}
|
|
else
|
|
{
|
|
/* Already in reading process. */
|
|
return kStatus_HAL_UartDmaRxBusy;
|
|
}
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
HAL_UartDMAIdlelineInterruptHandle(uartHandle->instance);
|
|
#endif
|
|
#else /* HAL_UART_DMA_RING_BUFFER_ENABLE */
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
lpuart_transfer_t xfer;
|
|
xfer.data = data;
|
|
xfer.dataSize = length;
|
|
#endif
|
|
#if (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
|
|
#elif (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
(void)LPUART_ReceiveEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle, &xfer);
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
|
|
#endif
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else
|
|
/* Enable RX interrupt for detecting the IDLE line interrupt. */
|
|
LPUART_EnableInterrupts(s_LpuartAdapterBase[uartHandle->instance], (uint32_t)kLPUART_IdleLineInterruptEnable);
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
|
|
hal_uart_dma_status_t HAL_UartDMATransferSend(hal_uart_handle_t handle, uint8_t *data, size_t length)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
lpuart_transfer_t xfer;
|
|
#endif
|
|
assert(handle);
|
|
assert(data);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
assert(uartDmaHandle);
|
|
|
|
if (NULL == uartDmaHandle->dma_tx.buffer)
|
|
{
|
|
uartDmaHandle->dma_tx.buffer = data;
|
|
uartDmaHandle->dma_tx.bufferLength = length;
|
|
uartDmaHandle->dma_tx.bufferSofar = 0U;
|
|
}
|
|
else
|
|
{
|
|
/* Already in writing process. */
|
|
return kStatus_HAL_UartDmaTxBusy;
|
|
}
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
xfer.data = data;
|
|
xfer.dataSize = length;
|
|
(void)LPUART_SendEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle, &xfer);
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
|
|
#if (defined(HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION) && (HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION > 0U))
|
|
#else
|
|
/* Enable RX interrupt for detecting the IDLE line interrupt. */
|
|
LPUART_EnableInterrupts(s_LpuartAdapterBase[uartHandle->instance], (uint32_t)kLPUART_IdleLineInterruptEnable);
|
|
#endif /* HAL_UART_DMA_USE_SOFTWARE_IDLELINE_DETECTION */
|
|
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
|
|
hal_uart_dma_status_t HAL_UartDMAGetReceiveCount(hal_uart_handle_t handle, uint32_t *reCount)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
assert(uartDmaHandle);
|
|
(void)uartDmaHandle;
|
|
#if (defined(UART_ADAPTER_NON_BLOCKING_MODE) && (UART_ADAPTER_NON_BLOCKING_MODE > 0U))
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
*reCount = HAL_UartGetDmaReceivedBytes(uartDmaHandle->instance);
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
#else /* HAL_UART_DMA_RING_BUFFER_ENABLE */
|
|
#if (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
if (kStatus_Success != LPUART_TransferGetReceiveCountEDMA(s_LpuartAdapterBase[uartDmaHandle->instance],
|
|
&uartDmaHandle->edmaHandle, reCount))
|
|
{
|
|
return kStatus_HAL_UartDmaError;
|
|
}
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_DMA_COUNT */
|
|
|
|
#endif
|
|
#else
|
|
*reCount = 0;
|
|
|
|
#endif
|
|
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
|
|
hal_uart_dma_status_t HAL_UartDMAGetSendCount(hal_uart_handle_t handle, uint32_t *seCount)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
assert(uartDmaHandle);
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
if (kStatus_Success != LPUART_TransferGetSendCountEDMA(s_LpuartAdapterBase[uartDmaHandle->instance],
|
|
&uartDmaHandle->edmaHandle, seCount))
|
|
{
|
|
return kStatus_HAL_UartDmaError;
|
|
}
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
|
|
hal_uart_dma_status_t HAL_UartDMAAbortReceive(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
assert(uartDmaHandle);
|
|
|
|
#if (defined(HAL_UART_DMA_RING_BUFFER_ENABLE) && (HAL_UART_DMA_RING_BUFFER_ENABLE > 0U))
|
|
/* Make sure to re-initialize the ring bufferIndex */
|
|
ringBufferIndex[uartDmaHandle->instance] = 0U;
|
|
#endif
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
LPUART_TransferAbortReceiveEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle);
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
|
|
hal_uart_dma_status_t HAL_UartDMAAbortSend(hal_uart_handle_t handle)
|
|
{
|
|
hal_uart_state_t *uartHandle;
|
|
hal_uart_dma_state_t *uartDmaHandle;
|
|
|
|
assert(handle);
|
|
|
|
uartHandle = (hal_uart_state_t *)handle;
|
|
uartDmaHandle = uartHandle->dmaHandle;
|
|
|
|
assert(uartDmaHandle);
|
|
|
|
#if (defined(FSL_FEATURE_SOC_EDMA_COUNT) && (FSL_FEATURE_SOC_EDMA_COUNT > 0U))
|
|
LPUART_TransferAbortSendEDMA(s_LpuartAdapterBase[uartDmaHandle->instance], &uartDmaHandle->edmaHandle);
|
|
#elif (defined(FSL_FEATURE_SOC_DMA_COUNT) && (FSL_FEATURE_SOC_DMA_COUNT > 0U))
|
|
#endif /* FSL_FEATURE_SOC_EDMA_COUNT */
|
|
|
|
return kStatus_HAL_UartDmaSuccess;
|
|
}
|
|
#endif /* HAL_UART_DMA_ENABLE */
|