mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-23 08:37:24 +08:00
816 lines
26 KiB
C
816 lines
26 KiB
C
/*
|
|
* The Clear BSD License
|
|
* Copyright 2017 NXP
|
|
* All rights reserved.
|
|
*
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
* are permitted (subject to the limitations in the disclaimer below) provided
|
|
* that the following conditions are met:
|
|
*
|
|
* o Redistributions of source code must retain the above copyright notice, this list
|
|
* of conditions and the following disclaimer.
|
|
*
|
|
* o Redistributions in binary form must reproduce the above copyright notice, this
|
|
* list of conditions and the following disclaimer in the documentation and/or
|
|
* other materials provided with the distribution.
|
|
*
|
|
* o Neither the name of Freescale Semiconductor, Inc. nor the names of its
|
|
* contributors may be used to endorse or promote products derived from this
|
|
* software without specific prior written permission.
|
|
*
|
|
* NO EXPRESS OR IMPLIED LICENSES TO ANY PARTY'S PATENT RIGHTS ARE GRANTED BY THIS LICENSE.
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
* ANY EPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
*/
|
|
#include "fsl_io.h"
|
|
#include "fsl_debug_console_conf.h"
|
|
|
|
/*******************************************************************************
|
|
* Definitions
|
|
******************************************************************************/
|
|
/* check avaliable device */
|
|
#if (defined(FSL_FEATURE_SOC_UART_COUNT) && (FSL_FEATURE_SOC_UART_COUNT != 0))
|
|
#define DEBUG_CONSOLE_IO_UART
|
|
#endif
|
|
|
|
#if (defined(FSL_FEATURE_SOC_IUART_COUNT) && (FSL_FEATURE_SOC_IUART_COUNT != 0))
|
|
#define DEBUG_CONSOLE_IO_IUART
|
|
#endif
|
|
|
|
#if (defined(FSL_FEATURE_SOC_LPUART_COUNT) && (FSL_FEATURE_SOC_LPUART_COUNT != 0))
|
|
#define DEBUG_CONSOLE_IO_LPUART
|
|
#endif
|
|
|
|
#if (defined(FSL_FEATURE_SOC_LPSCI_COUNT) && (FSL_FEATURE_SOC_LPSCI_COUNT != 0))
|
|
#define DEBUG_CONSOLE_IO_LPSCI
|
|
#endif
|
|
|
|
#if ((defined(FSL_FEATURE_SOC_USB_COUNT) && (FSL_FEATURE_SOC_USB_COUNT != 0)) && \
|
|
(defined(BOARD_USE_VIRTUALCOM) && (BOARD_USE_VIRTUALCOM != 0)))
|
|
#define DEBUG_CONSOLE_IO_USBCDC
|
|
#endif
|
|
|
|
#if (defined(FSL_FEATURE_SOC_FLEXCOMM_COUNT) && (FSL_FEATURE_SOC_FLEXCOMM_COUNT != 0))
|
|
#define DEBUG_CONSOLE_IO_FLEXCOMM
|
|
#endif
|
|
|
|
#if (defined(FSL_FEATURE_SOC_VFIFO_COUNT) && (FSL_FEATURE_SOC_VFIFO_COUNT != 0))
|
|
#define DEBUG_CONSOLE_IO_VUSART
|
|
#endif
|
|
|
|
/* If none of above io is supported, enable the swo for debug console, or swo can be enabled by define
|
|
* DEBUG_CONSOLE_IO_SWO directly */
|
|
#if (!defined(DEBUG_CONSOLE_IO_SWO) && !defined(DEBUG_CONSOLE_IO_UART) && !defined(DEBUG_CONSOLE_IO_IUART) && \
|
|
!defined(DEBUG_CONSOLE_IO_LPUART) && \
|
|
!defined(DEBUG_CONSOLE_IO_LPSCI) && !defined(DEBUG_CONSOLE_IO_USBCDC) && \
|
|
!defined(DEBUG_CONSOLE_IO_FLEXCOMM) && \
|
|
!defined(DEBUG_CONSOLE_IO_VUSART))
|
|
#define DEBUG_CONSOLE_IO_SWO
|
|
#endif
|
|
|
|
/* configuration for debug console device */
|
|
/* If new device is required as the low level device for debug console,
|
|
* Add the #elif branch and add the preprocessor macro to judge whether
|
|
* this kind of device exist in this SOC. */
|
|
#if (defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART)
|
|
#include "fsl_uart.h"
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
static uart_handle_t s_ioUartHandler;
|
|
#endif /* DEBUG_CONSOLE_TRANSFER_NON_BLOCKING */
|
|
#endif /* defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART */
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPUART
|
|
#include "fsl_lpuart.h"
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
static lpuart_handle_t s_ioLpuartHandler;
|
|
#endif /* DEBUG_CONSOLE_TRANSFER_NON_BLOCKING */
|
|
#endif /* DEBUG_CONSOLE_IO_LPUART */
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPSCI
|
|
#include "fsl_lpsci.h"
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
static lpsci_handle_t s_ioLpsciHandler;
|
|
#endif /* DEBUG_CONSOLE_TRANSFER_NON_BLOCKING */
|
|
#endif /* DEBUG_CONSOLE_IO_LPSCI */
|
|
|
|
#if defined DEBUG_CONSOLE_IO_USBCDC
|
|
#include "usb_device_config.h"
|
|
#include "usb.h"
|
|
#include "usb_device_cdc_acm.h"
|
|
#include "usb_device_ch9.h"
|
|
#include "virtual_com.h"
|
|
#endif /* DEBUG_CONSOLE_IO_USBCDC */
|
|
|
|
#if (defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART)
|
|
#include "fsl_usart.h"
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
static usart_handle_t s_ioUsartHandler;
|
|
#endif /* DEBUG_CONSOLE_TRANSFER_NON_BLOCKING */
|
|
#endif /* defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART */
|
|
|
|
#if defined DEBUG_CONSOLE_IO_SWO
|
|
#include "fsl_swo.h"
|
|
#endif
|
|
|
|
/*******************************************************************************
|
|
* Variables
|
|
******************************************************************************/
|
|
|
|
/*! @brief Debug console IO state information. */
|
|
static io_state_t s_debugConsoleIO = {
|
|
.ioBase = NULL,
|
|
.ioType = DEBUG_CONSOLE_DEVICE_TYPE_NONE,
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
.callBack = NULL,
|
|
#endif /* DEBUG_CONSOLE_TRANSFER_NON_BLOCKING */
|
|
};
|
|
|
|
/*******************************************************************************
|
|
* Code
|
|
******************************************************************************/
|
|
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
|
|
#if (defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART)
|
|
static void UART_Callback(UART_Type *base, uart_handle_t *handle, status_t status, void *userData)
|
|
{
|
|
bool tx = false, rx = false;
|
|
size_t size = 0U;
|
|
|
|
if (status == kStatus_UART_RxIdle)
|
|
{
|
|
rx = true;
|
|
size = handle->txDataSizeAll;
|
|
}
|
|
|
|
if (status == kStatus_UART_TxIdle)
|
|
{
|
|
tx = true;
|
|
size = handle->txDataSizeAll;
|
|
}
|
|
|
|
/* inform the buffer layer that transfer is complete */
|
|
if (s_debugConsoleIO.callBack != NULL)
|
|
{
|
|
/* call buffer callback function */
|
|
s_debugConsoleIO.callBack(&size, rx, tx);
|
|
}
|
|
}
|
|
#endif /* defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART */
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPSCI
|
|
static void LPSCI_Callback(UART0_Type *base, lpsci_handle_t *handle, status_t status, void *userData)
|
|
{
|
|
bool tx = false, rx = false;
|
|
size_t size = 0U;
|
|
|
|
if (status == kStatus_LPSCI_RxIdle)
|
|
{
|
|
rx = true;
|
|
size = handle->txDataSizeAll;
|
|
}
|
|
|
|
if (status == kStatus_LPSCI_TxIdle)
|
|
{
|
|
tx = true;
|
|
size = handle->txDataSizeAll;
|
|
}
|
|
|
|
/* inform the buffer layer that transfer is complete */
|
|
if (s_debugConsoleIO.callBack != NULL)
|
|
{
|
|
/* call buffer callback function */
|
|
s_debugConsoleIO.callBack(&size, rx, tx);
|
|
}
|
|
}
|
|
#endif /* DEBUG_CONSOLE_IO_LPSCI */
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPUART
|
|
static void LPUART_Callback(LPUART_Type *base, lpuart_handle_t *handle, status_t status, void *userData)
|
|
{
|
|
bool tx = false, rx = false;
|
|
size_t size = 0U;
|
|
|
|
if (status == kStatus_LPUART_RxIdle)
|
|
{
|
|
rx = true;
|
|
size = handle->txDataSizeAll;
|
|
}
|
|
|
|
if (status == kStatus_LPUART_TxIdle)
|
|
{
|
|
tx = true;
|
|
size = handle->txDataSizeAll;
|
|
}
|
|
|
|
/* inform the buffer layer that transfer is complete */
|
|
if (s_debugConsoleIO.callBack != NULL)
|
|
{
|
|
/* call buffer callback function */
|
|
s_debugConsoleIO.callBack(&size, rx, tx);
|
|
}
|
|
}
|
|
#endif /* DEBUG_CONSOLE_IO_LPUART */
|
|
|
|
#if (defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART)
|
|
static void USART_Callback(USART_Type *base, usart_handle_t *handle, status_t status, void *userData)
|
|
{
|
|
bool tx = false, rx = false;
|
|
size_t size = 0U;
|
|
|
|
if (status == kStatus_USART_RxIdle)
|
|
{
|
|
rx = true;
|
|
size = handle->txDataSizeAll;
|
|
}
|
|
|
|
if (status == kStatus_USART_TxIdle)
|
|
{
|
|
tx = true;
|
|
size = handle->txDataSizeAll;
|
|
}
|
|
|
|
/* inform the buffer layer that transfer is complete */
|
|
if (s_debugConsoleIO.callBack != NULL)
|
|
{
|
|
/* call buffer callback function */
|
|
s_debugConsoleIO.callBack(&size, rx, tx);
|
|
}
|
|
}
|
|
#endif /* defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART */
|
|
#endif /* DEBUG_CONSOLE_TRANSFER_NON_BLOCKING */
|
|
|
|
void IO_Init(io_state_t *io, uint32_t baudRate, uint32_t clkSrcFreq, uint8_t *ringBuffer)
|
|
{
|
|
assert(NULL != io);
|
|
|
|
/* record device type/base */
|
|
s_debugConsoleIO.ioType = io->ioType;
|
|
s_debugConsoleIO.ioBase = (void *)(io->ioBase);
|
|
|
|
switch (s_debugConsoleIO.ioType)
|
|
{
|
|
#if (defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_UART:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_IUART:
|
|
{
|
|
uart_config_t uart_config;
|
|
UART_GetDefaultConfig(&uart_config);
|
|
uart_config.baudRate_Bps = baudRate;
|
|
/* Enable clock and initial UART module follow user configure structure. */
|
|
UART_Init((UART_Type *)s_debugConsoleIO.ioBase, &uart_config, clkSrcFreq);
|
|
UART_EnableTx(s_debugConsoleIO.ioBase, true);
|
|
UART_EnableRx(s_debugConsoleIO.ioBase, true);
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
s_debugConsoleIO.callBack = io->callBack;
|
|
/* create handler for interrupt transfer */
|
|
UART_TransferCreateHandle(s_debugConsoleIO.ioBase, &s_ioUartHandler, UART_Callback, NULL);
|
|
/* start ring buffer */
|
|
UART_TransferStartRingBuffer(s_debugConsoleIO.ioBase, &s_ioUartHandler, ringBuffer,
|
|
DEBUG_CONSOLE_RECEIVE_BUFFER_LEN);
|
|
#endif
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPUART
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPUART:
|
|
{
|
|
lpuart_config_t lpuart_config;
|
|
LPUART_GetDefaultConfig(&lpuart_config);
|
|
lpuart_config.baudRate_Bps = baudRate;
|
|
/* Enable clock and initial UART module follow user configure structure. */
|
|
LPUART_Init((LPUART_Type *)s_debugConsoleIO.ioBase, &lpuart_config, clkSrcFreq);
|
|
LPUART_EnableTx(s_debugConsoleIO.ioBase, true);
|
|
LPUART_EnableRx(s_debugConsoleIO.ioBase, true);
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
s_debugConsoleIO.callBack = io->callBack;
|
|
/* create handler for interrupt transfer */
|
|
LPUART_TransferCreateHandle(s_debugConsoleIO.ioBase, &s_ioLpuartHandler, LPUART_Callback, NULL);
|
|
/* start ring buffer */
|
|
LPUART_TransferStartRingBuffer(s_debugConsoleIO.ioBase, &s_ioLpuartHandler, ringBuffer,
|
|
DEBUG_CONSOLE_RECEIVE_BUFFER_LEN);
|
|
#endif
|
|
}
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_LPSCI
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPSCI:
|
|
{
|
|
lpsci_config_t lpsci_config;
|
|
LPSCI_GetDefaultConfig(&lpsci_config);
|
|
lpsci_config.baudRate_Bps = baudRate;
|
|
/* Enable clock and initial UART module follow user configure structure. */
|
|
LPSCI_Init((UART0_Type *)s_debugConsoleIO.ioBase, &lpsci_config, clkSrcFreq);
|
|
LPSCI_EnableTx(s_debugConsoleIO.ioBase, true);
|
|
LPSCI_EnableRx(s_debugConsoleIO.ioBase, true);
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
s_debugConsoleIO.callBack = io->callBack;
|
|
/* create handler for interrupt transfer */
|
|
LPSCI_TransferCreateHandle(s_debugConsoleIO.ioBase, &s_ioLpsciHandler, LPSCI_Callback, NULL);
|
|
/* start ring buffer */
|
|
LPSCI_TransferStartRingBuffer(s_debugConsoleIO.ioBase, &s_ioLpsciHandler, ringBuffer,
|
|
DEBUG_CONSOLE_RECEIVE_BUFFER_LEN);
|
|
#endif
|
|
}
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_USBCDC
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_USBCDC:
|
|
{
|
|
s_debugConsoleIO.ioBase = USB_VcomInit();
|
|
}
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_FLEXCOMM
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_FLEXCOMM:
|
|
{
|
|
usart_config_t usart_config;
|
|
USART_GetDefaultConfig(&usart_config);
|
|
usart_config.baudRate_Bps = baudRate;
|
|
/* Enable clock and initial UART module follow user configure structure. */
|
|
USART_Init((USART_Type *)s_debugConsoleIO.ioBase, &usart_config, clkSrcFreq);
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
s_debugConsoleIO.callBack = io->callBack;
|
|
/* create handler for interrupt transfer */
|
|
USART_TransferCreateHandle(s_debugConsoleIO.ioBase, &s_ioUsartHandler, USART_Callback, NULL);
|
|
/* start ring buffer */
|
|
USART_TransferStartRingBuffer(s_debugConsoleIO.ioBase, &s_ioUsartHandler, ringBuffer,
|
|
DEBUG_CONSOLE_RECEIVE_BUFFER_LEN);
|
|
#endif
|
|
}
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_VUSART
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_VUSART:
|
|
{
|
|
usart_config_t usart_config;
|
|
USART_GetDefaultConfig(&usart_config);
|
|
usart_config.baudRate_Bps = baudRate;
|
|
usart_config.enableRx = true;
|
|
usart_config.enableTx = true;
|
|
/* Enable rx fifo for user's continously input */
|
|
usart_config.fifoConfig.enableRxFifo = true;
|
|
usart_config.fifoConfig.rxFifoSize = 8;
|
|
/* Enable clock and initial UART module follow user configure structure. */
|
|
USART_Init((USART_Type *)s_debugConsoleIO.ioBase, &usart_config, clkSrcFreq);
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
s_debugConsoleIO.callBack = io->callBack;
|
|
/* create handler for interrupt transfer */
|
|
USART_TransferCreateHandle(s_debugConsoleIO.ioBase, &s_ioUsartHandler, USART_Callback, NULL);
|
|
/* start ring buffer */
|
|
USART_TransferStartRingBuffer(s_debugConsoleIO.ioBase, &s_ioUsartHandler, ringBuffer,
|
|
DEBUG_CONSOLE_RECEIVE_BUFFER_LEN);
|
|
#endif
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_SWO
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_SWO:
|
|
SWO_Init((uint32_t)s_debugConsoleIO.ioBase, baudRate, clkSrcFreq);
|
|
break;
|
|
#endif
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
status_t IO_Deinit(void)
|
|
{
|
|
if (s_debugConsoleIO.ioType == DEBUG_CONSOLE_DEVICE_TYPE_NONE)
|
|
{
|
|
return kStatus_Success;
|
|
}
|
|
|
|
switch (s_debugConsoleIO.ioType)
|
|
{
|
|
#if (defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_UART:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_IUART:
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
/* stop ring buffer */
|
|
UART_TransferStopRingBuffer(s_debugConsoleIO.ioBase, &s_ioUartHandler);
|
|
#endif
|
|
/* Disable UART module. */
|
|
UART_Deinit((UART_Type *)s_debugConsoleIO.ioBase);
|
|
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_LPSCI
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPSCI:
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
/* stop ring buffer */
|
|
LPSCI_TransferStopRingBuffer(s_debugConsoleIO.ioBase, &s_ioLpsciHandler);
|
|
#endif
|
|
/* Disable LPSCI module. */
|
|
LPSCI_Deinit((UART0_Type *)s_debugConsoleIO.ioBase);
|
|
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_LPUART
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPUART:
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
/* stop ring buffer */
|
|
LPUART_TransferStopRingBuffer(s_debugConsoleIO.ioBase, &s_ioLpuartHandler);
|
|
#endif
|
|
/* Disable LPUART module. */
|
|
LPUART_Deinit((LPUART_Type *)s_debugConsoleIO.ioBase);
|
|
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_USBCDC
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_USBCDC:
|
|
/* Disable USBCDC module. */
|
|
USB_VcomDeinit(s_debugConsoleIO.ioBase);
|
|
break;
|
|
#endif
|
|
#if (defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_FLEXCOMM:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_VUSART:
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
/* stop ring buffer */
|
|
USART_TransferStopRingBuffer(s_debugConsoleIO.ioBase, &s_ioUsartHandler);
|
|
#endif
|
|
/* deinit IO */
|
|
USART_Deinit((USART_Type *)s_debugConsoleIO.ioBase);
|
|
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_SWO
|
|
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_SWO:
|
|
SWO_Deinit((uint32_t)s_debugConsoleIO.ioBase);
|
|
break;
|
|
#endif
|
|
default:
|
|
s_debugConsoleIO.ioType = DEBUG_CONSOLE_DEVICE_TYPE_NONE;
|
|
break;
|
|
}
|
|
|
|
s_debugConsoleIO.ioType = DEBUG_CONSOLE_DEVICE_TYPE_NONE;
|
|
|
|
return kStatus_Success;
|
|
}
|
|
|
|
status_t IO_WaitIdle(void)
|
|
{
|
|
switch (s_debugConsoleIO.ioType)
|
|
{
|
|
#if (defined DEBUG_CONSOLE_IO_UART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_UART:
|
|
/* wait transfer complete flag */
|
|
while (!(UART_GetStatusFlags(s_debugConsoleIO.ioBase) & kUART_TransmissionCompleteFlag))
|
|
{
|
|
}
|
|
|
|
break;
|
|
#endif
|
|
|
|
#if (defined DEBUG_CONSOLE_IO_IUART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_IUART:
|
|
/* wait transfer complete flag */
|
|
while (!(UART_GetStatusFlag(s_debugConsoleIO.ioBase, kUART_TxCompleteFlag)))
|
|
{
|
|
}
|
|
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPSCI
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPSCI:
|
|
/* wait transfer complete flag */
|
|
while (!(LPSCI_GetStatusFlags(s_debugConsoleIO.ioBase) & kLPSCI_TransmissionCompleteFlag))
|
|
{
|
|
}
|
|
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPUART
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPUART:
|
|
/* wait transfer complete flag */
|
|
while (!(LPUART_GetStatusFlags(s_debugConsoleIO.ioBase) & kLPUART_TransmissionCompleteFlag))
|
|
{
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if (defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_FLEXCOMM:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_VUSART:
|
|
/* wait transfer complete flag */
|
|
while (!(USART_GetStatusFlags(s_debugConsoleIO.ioBase) & kUSART_TxFifoEmptyFlag))
|
|
{
|
|
}
|
|
break;
|
|
#endif
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return kStatus_Success;
|
|
}
|
|
|
|
#ifdef DEBUG_CONSOLE_TRANSFER_NON_BLOCKING
|
|
|
|
status_t IO_Transfer(uint8_t *ch, size_t size, bool tx)
|
|
{
|
|
status_t status = kStatus_Fail;
|
|
|
|
switch (s_debugConsoleIO.ioType)
|
|
{
|
|
#if (defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_UART:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_IUART:
|
|
{
|
|
uart_transfer_t transfer = {0U};
|
|
transfer.data = ch;
|
|
transfer.dataSize = size;
|
|
/* transfer data */
|
|
if (tx)
|
|
{
|
|
status = UART_TransferSendNonBlocking(s_debugConsoleIO.ioBase, &s_ioUartHandler, &transfer);
|
|
}
|
|
else
|
|
{
|
|
status = UART_TransferReceiveNonBlocking(s_debugConsoleIO.ioBase, &s_ioUartHandler, &transfer, NULL);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_LPSCI
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPSCI:
|
|
{
|
|
lpsci_transfer_t transfer = {0U};
|
|
transfer.data = ch;
|
|
transfer.dataSize = size;
|
|
/* transfer data */
|
|
if (tx)
|
|
{
|
|
status = LPSCI_TransferSendNonBlocking(s_debugConsoleIO.ioBase, &s_ioLpsciHandler, &transfer);
|
|
}
|
|
else
|
|
{
|
|
status = LPSCI_TransferReceiveNonBlocking(s_debugConsoleIO.ioBase, &s_ioLpsciHandler, &transfer, NULL);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPUART
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPUART:
|
|
{
|
|
lpuart_transfer_t transfer = {0U};
|
|
transfer.data = ch;
|
|
transfer.dataSize = size;
|
|
/* transfer data */
|
|
if (tx)
|
|
{
|
|
status = LPUART_TransferSendNonBlocking(s_debugConsoleIO.ioBase, &s_ioLpuartHandler, &transfer);
|
|
}
|
|
else
|
|
{
|
|
status =
|
|
LPUART_TransferReceiveNonBlocking(s_debugConsoleIO.ioBase, &s_ioLpuartHandler, &transfer, NULL);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_USBCDC
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_USBCDC:
|
|
{
|
|
if (tx)
|
|
{
|
|
USB_VcomWriteBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
else
|
|
{
|
|
USB_VcomReadBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if (defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_FLEXCOMM:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_VUSART:
|
|
{
|
|
usart_transfer_t transfer = {0U};
|
|
transfer.data = ch;
|
|
transfer.dataSize = size;
|
|
/* transfer data */
|
|
if (tx)
|
|
{
|
|
status = USART_TransferSendNonBlocking(s_debugConsoleIO.ioBase, &s_ioUsartHandler, &transfer);
|
|
}
|
|
else
|
|
{
|
|
status = USART_TransferReceiveNonBlocking(s_debugConsoleIO.ioBase, &s_ioUsartHandler, &transfer, NULL);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_SWO
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_SWO:
|
|
status = SWO_SendBlocking((uint32_t)s_debugConsoleIO.ioBase, ch, size);
|
|
break;
|
|
#endif
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return status;
|
|
}
|
|
|
|
status_t IO_TryReceiveCharacter(uint8_t *ch)
|
|
{
|
|
status_t status = kStatus_Fail;
|
|
uint32_t size = 1U;
|
|
|
|
switch (s_debugConsoleIO.ioType)
|
|
{
|
|
#if (defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_UART:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_IUART:
|
|
{
|
|
uart_transfer_t transfer = {0U};
|
|
transfer.data = ch;
|
|
transfer.dataSize = size;
|
|
if (UART_TransferGetRxRingBufferLength(&s_ioUartHandler) >= size)
|
|
{
|
|
/* transfer data */
|
|
status = UART_TransferReceiveNonBlocking(s_debugConsoleIO.ioBase, &s_ioUartHandler, &transfer, NULL);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_LPSCI
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPSCI:
|
|
{
|
|
lpsci_transfer_t transfer = {0U};
|
|
transfer.data = ch;
|
|
transfer.dataSize = size;
|
|
if (LPSCI_TransferGetRxRingBufferLength(&s_ioLpsciHandler) >= size)
|
|
{
|
|
/* transfer data */
|
|
status = LPSCI_TransferReceiveNonBlocking(s_debugConsoleIO.ioBase, &s_ioLpsciHandler, &transfer, NULL);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPUART
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPUART:
|
|
{
|
|
lpuart_transfer_t transfer = {0U};
|
|
transfer.data = ch;
|
|
transfer.dataSize = size;
|
|
if (LPUART_TransferGetRxRingBufferLength(s_debugConsoleIO.ioBase, &s_ioLpuartHandler) >= size)
|
|
{
|
|
/* transfer data */
|
|
status =
|
|
LPUART_TransferReceiveNonBlocking(s_debugConsoleIO.ioBase, &s_ioLpuartHandler, &transfer, NULL);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_USBCDC
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_USBCDC:
|
|
break;
|
|
#endif
|
|
|
|
#if (defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_FLEXCOMM:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_VUSART:
|
|
{
|
|
usart_transfer_t transfer = {0U};
|
|
transfer.data = ch;
|
|
transfer.dataSize = size;
|
|
if (USART_TransferGetRxRingBufferLength(&s_ioUsartHandler) >= size)
|
|
{
|
|
/* transfer data */
|
|
status = USART_TransferReceiveNonBlocking(s_debugConsoleIO.ioBase, &s_ioUsartHandler, &transfer, NULL);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return status;
|
|
}
|
|
|
|
#else
|
|
|
|
status_t IO_Transfer(uint8_t *ch, size_t size, bool tx)
|
|
{
|
|
status_t status = kStatus_Success;
|
|
switch (s_debugConsoleIO.ioType)
|
|
{
|
|
#if (defined DEBUG_CONSOLE_IO_UART) || (defined DEBUG_CONSOLE_IO_IUART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_UART:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_IUART:
|
|
{
|
|
if (tx)
|
|
{
|
|
UART_WriteBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
else
|
|
{
|
|
status = UART_ReadBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
#if defined DEBUG_CONSOLE_IO_LPSCI
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPSCI:
|
|
{
|
|
if (tx)
|
|
{
|
|
LPSCI_WriteBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
else
|
|
{
|
|
status = LPSCI_ReadBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_LPUART
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_LPUART:
|
|
{
|
|
if (tx)
|
|
{
|
|
LPUART_WriteBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
else
|
|
{
|
|
status = LPUART_ReadBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_USBCDC
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_USBCDC:
|
|
{
|
|
if (tx)
|
|
{
|
|
USB_VcomWriteBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
else
|
|
{
|
|
status = USB_VcomReadBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if (defined DEBUG_CONSOLE_IO_FLEXCOMM) || (defined DEBUG_CONSOLE_IO_VUSART)
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_FLEXCOMM:
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_VUSART:
|
|
{
|
|
if (tx)
|
|
{
|
|
USART_WriteBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
else
|
|
{
|
|
status = USART_ReadBlocking(s_debugConsoleIO.ioBase, ch, size);
|
|
}
|
|
}
|
|
break;
|
|
#endif
|
|
|
|
#if defined DEBUG_CONSOLE_IO_SWO
|
|
case DEBUG_CONSOLE_DEVICE_TYPE_SWO:
|
|
status = SWO_SendBlocking((uint32_t)s_debugConsoleIO.ioBase, ch, size);
|
|
break;
|
|
#endif
|
|
default:
|
|
status = kStatus_Fail;
|
|
break;
|
|
}
|
|
|
|
return status;
|
|
}
|
|
|
|
#endif /* DEBUG_CONSOLE_TRANSFER_NON_BLOCKING */
|