81 lines
3.0 KiB
C
81 lines
3.0 KiB
C
/*
|
|
* Copyright 2018 NXP
|
|
* All rights reserved.
|
|
*
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#ifndef __SERIAL_PORT_UART_H__
|
|
#define __SERIAL_PORT_UART_H__
|
|
|
|
#include "fsl_adapter_uart.h"
|
|
|
|
/*!
|
|
* @addtogroup serial_port_uart
|
|
* @{
|
|
*/
|
|
|
|
/*******************************************************************************
|
|
* Definitions
|
|
******************************************************************************/
|
|
/*! @brief serial port uart handle size*/
|
|
#if (defined(SERIAL_MANAGER_NON_BLOCKING_MODE) && (SERIAL_MANAGER_NON_BLOCKING_MODE > 0U))
|
|
#define SERIAL_PORT_UART_HANDLE_SIZE (76U + HAL_UART_HANDLE_SIZE)
|
|
#define SERIAL_PORT_UART_BLOCK_HANDLE_SIZE (HAL_UART_BLOCK_HANDLE_SIZE)
|
|
#else
|
|
#define SERIAL_PORT_UART_HANDLE_SIZE (HAL_UART_HANDLE_SIZE)
|
|
#endif
|
|
|
|
#ifndef SERIAL_USE_CONFIGURE_STRUCTURE
|
|
#define SERIAL_USE_CONFIGURE_STRUCTURE (0U) /*!< Enable or disable the confgure structure pointer */
|
|
#endif
|
|
|
|
/*! @brief serial port uart parity mode*/
|
|
typedef enum _serial_port_uart_parity_mode
|
|
{
|
|
kSerialManager_UartParityDisabled = 0x0U, /*!< Parity disabled */
|
|
kSerialManager_UartParityEven = 0x1U, /*!< Parity even enabled */
|
|
kSerialManager_UartParityOdd = 0x2U, /*!< Parity odd enabled */
|
|
} serial_port_uart_parity_mode_t;
|
|
|
|
/*! @brief serial port uart stop bit count*/
|
|
typedef enum _serial_port_uart_stop_bit_count
|
|
{
|
|
kSerialManager_UartOneStopBit = 0U, /*!< One stop bit */
|
|
kSerialManager_UartTwoStopBit = 1U, /*!< Two stop bits */
|
|
} serial_port_uart_stop_bit_count_t;
|
|
|
|
#if (defined(SERIAL_MANAGER_NON_BLOCKING_MODE) && (SERIAL_MANAGER_NON_BLOCKING_MODE > 0U))
|
|
/*! @brief serial port uart block mode*/
|
|
typedef enum _serial_port_uart_block_mode
|
|
{
|
|
kSerialManager_UartNonBlockMode = 0x0U, /*!< Uart NonBlock Mode */
|
|
kSerialManager_UartBlockMode = 0x1U, /*!< Uart Block Mode */
|
|
} serial_port_uart_block_mode_t;
|
|
#endif /* SERIAL_MANAGER_NON_BLOCKING_MODE */
|
|
|
|
typedef struct _serial_port_uart_config
|
|
{
|
|
uint32_t clockRate; /*!< clock rate */
|
|
uint32_t baudRate; /*!< baud rate */
|
|
serial_port_uart_parity_mode_t parityMode; /*!< Parity mode, disabled (default), even, odd */
|
|
serial_port_uart_stop_bit_count_t stopBitCount; /*!< Number of stop bits, 1 stop bit (default) or 2 stop bits */
|
|
|
|
uint8_t enableRx; /*!< Enable RX */
|
|
uint8_t enableTx; /*!< Enable TX */
|
|
uint8_t enableRxRTS; /*!< Enable RX RTS */
|
|
uint8_t enableTxCTS; /*!< Enable TX CTS */
|
|
uint8_t instance; /*!< Instance (0 - UART0, 1 - UART1, ...), detail information
|
|
please refer to the SOC corresponding RM. */
|
|
#if (defined(SERIAL_MANAGER_NON_BLOCKING_MODE) && (SERIAL_MANAGER_NON_BLOCKING_MODE > 0U))
|
|
serial_port_uart_block_mode_t mode; /*!< serial port uart block mode */
|
|
#endif /* SERIAL_MANAGER_NON_BLOCKING_MODE */
|
|
#if (defined(HAL_UART_ADAPTER_FIFO) && (HAL_UART_ADAPTER_FIFO > 0u))
|
|
uint8_t txFifoWatermark;
|
|
uint8_t rxFifoWatermark;
|
|
#endif
|
|
} serial_port_uart_config_t;
|
|
/*! @} */
|
|
#endif /* __SERIAL_PORT_UART_H__ */
|