首页 > 其他分享 >[单片机框架][bsp层][AT32F415][bsp_uart] uart配置和使用

[单片机框架][bsp层][AT32F415][bsp_uart] uart配置和使用

时间:2022-10-31 18:03:41浏览次数:72  
标签:rx AT32F415 USART uart BSP bsp BS


14 通用同步异步收发器(USART)

14.1 USART介绍
通用同步异步收发器(USART)提供了一种灵活的方法与使用工业标准 NRZ 异步串行数据格式的外部设备之间进行全双工数据交换。USART 利用分数波特率发生器提供宽范围的波特率选择。 它支持同步单向通信和半双工单线通信,也支持 LIN(局部互连网) ,智能卡协议和 IrDA(红外数据组织)SIRENDEC 规范,以及 CTS/RTS(Clear To Send/Request To Send)硬件流操作。它还允许多处理器通信。 使用多缓冲器配置的 DMA 方式,可以实现高速数据通信。

14.2 USART主要特性

  • 全双工异步通信
  • 单线半双工通信
  • NRZ 标准格式(Mark/Space)
  • 可编程的波特率发生器 – 发送和接收共用的可编程波特率,最高达 6.25MBits/s
  • 可编程数据字长度(8 位或 9 位)
  • 可配置的停止位-支持 1 或 2 个停止位
  • LIN 主机有发送断开符的能力以及 LIN 从机有检测断开符的能力 ─ 当 USART 硬件配置成 LIN 时,生成 13 位断开符;检测 10/11 位断开符
  • 发送方为同步传输提供时钟
  • IrDA SIR 编码器解码器 ─ 在普通模式下支持 3/16 位的持续时间
  • ISO7816-3 标准里定义的异步智能卡协议 ─ 智能卡模式支持 0.5 或 1.5 个停止位
  • 可配置的DMA多缓冲器通信 ─ 利用 DMA 缓冲接收/发送数据
  • 单独的发送器和接收器使能位
  • 检测标志
    ①接收缓冲器满
    ②发送缓冲器空
    ③传输结束标志
  • 校验控制
    ①发送校验位
    ②对接收数据进行校验
  • 四个错误检测标志
    ①溢出错误
    ②噪音错误
    ③帧错误
    ④校验错误
  • 10 个带标志的中断源
    ① CTSF 改变
    ②LIN 断开符检测
    ③ 发送数据寄存器空
    ④发送完成
    ⑤接收数据寄存器满
    ⑥ 检测到总线为空闲
    ⑦溢出错误
    ⑧帧错误
    ⑨噪音错误
    十。校验错误
  • 多处理器通信–如果地址不匹配,则进入静默模式
  • 从静默模式中唤醒(通过空闲总线检测或地址检测)
  • 两种唤醒接收器的方式:地址位(MSB,第9位),总线空闲
/********************************************************************************
* @file bsp_uart.c
* @author jianqiang.xue
* @version V1.0.0
* @date 2021-10-08
* @brief uart驱动
********************************************************************************/
/* Includes ------------------------------------------------------------------*/
#include <stdio.h>
#include <stdint.h>
#include <stdbool.h>
#include <string.h>

#include "RTE_Components.h"
#include CMSIS_device_header

#include "bsp_gpio.h"
#include "bsp_exti.h"
#include "bsp_uart.h"

/* Private Includes ----------------------------------------------------------*/
#include "business_gpio.h"
#include "business_function.h"

/* Private Define ------------------------------------------------------------*/
#define AF_TXD 0
#define AF_RXD 1

/* Private Typedef -----------------------------------------------------------*/
typedef void(*bsp_uart_callback)(void);

/* Private Variables ---------------------------------------------------------*/
#if BS_UART0_EN
#define BSP_UART0 USART1
#define BSP_UART0_APBX_CLOCK() RCC_APB2PeriphClockCmd(RCC_APB2PERIPH_AFIO, ENABLE); \
RCC_APB2PeriphClockCmd(RCC_APB2PERIPH_USART1, ENABLE)
#define BSP_UART0_IRQN USART1_IRQn
#define BSP_UART0_IRQ_HANDLER USART1_IRQHandler

// 定义串口信息初始化结构体
USART_InitType huart0 =
{
.USART_BaudRate = BS_UART0_BAUD_RATE,
.USART_StopBits = USART_StopBits_1,
.USART_WordLength = USART_WordLength_8b,
.USART_Parity = USART_Parity_No,
.USART_HardwareFlowControl = USART_HardwareFlowControl_None,
.USART_Mode = USART_Mode_Rx | USART_Mode_Tx
};

// 定义串口缓存区
uint8_t bsp_uart0_tx_buff[BS_UART0_CACHE_SIZE] = {0};
uint8_t bsp_uart0_rx_buff[BS_UART0_CACHE_SIZE] = {0};

// 定义串口初始化标记位 0--未初始化 1--初始化完成
bool g_uart0_init = false;
// 定义串口发送标记位 0--free闲 1--bus忙
bool g_uart0_send_lock = false;
// 记录当前接收长度
uint8_t g_uart0_rx_len = 0;
// 定义串口接收回调函数
static bsp_uart_callback uart0_irq_rx_callback;
#endif

#if BS_UART1_EN
#define BSP_UART1 USART2
#define BSP_UART1_APBX_CLOCK() RCC_APB2PeriphClockCmd(RCC_APB2PERIPH_AFIO, ENABLE); \
RCC_APB1PeriphClockCmd(RCC_APB1PERIPH_USART2, ENABLE)
#define BSP_UART1_IRQN USART2_IRQn
#define BSP_UART1_IRQ_HANDLER USART2_IRQHandler

// 定义串口信息初始化结构体
USART_InitType huart1 =
{
.USART_BaudRate = BS_UART1_BAUD_RATE,
.USART_StopBits = USART_StopBits_1,
.USART_WordLength = USART_WordLength_8b,
.USART_Parity = USART_Parity_No,
.USART_HardwareFlowControl = USART_HardwareFlowControl_None,
.USART_Mode = USART_Mode_Rx | USART_Mode_Tx
};

// 定义串口缓存区
uint8_t bsp_uart1_tx_buff[BS_UART1_CACHE_SIZE] = {0};
uint8_t bsp_uart1_rx_buff[BS_UART1_CACHE_SIZE] = {0};

// 定义串口初始化标记位 0--未初始化 1--初始化完成
bool g_uart1_init = false;
// 定义串口发送标记位 0--free闲 1--bus忙
bool g_uart1_send_lock = false;
// 记录当前接收长度
uint8_t g_uart1_rx_len = 0;
// 定义串口接收回调函数
static bsp_uart_callback uart1_irq_rx_callback;
#endif

#if BS_UART2_EN
#define BSP_UART2 USART3
#define BSP_UART2_APBX_CLOCK() RCC_APB2PeriphClockCmd(RCC_APB2PERIPH_AFIO, ENABLE); \
RCC_APB1PeriphClockCmd(RCC_APB1PERIPH_USART3, ENABLE)
#define BSP_UART2_IRQN USART3_IRQn
#define BSP_UART2_IRQ_HANDLER USART3_IRQHandler

// 定义串口信息初始化结构体
USART_InitType huart2 =
{
.USART_BaudRate = BS_UART2_BAUD_RATE,
.USART_StopBits = USART_StopBits_1,
.USART_WordLength = USART_WordLength_8b,
.USART_Parity = USART_Parity_No,
.USART_HardwareFlowControl = USART_HardwareFlowControl_None,
.USART_Mode = USART_Mode_Rx | USART_Mode_Tx
};

// 定义串口缓存区
uint8_t bsp_uart2_tx_buff[BS_UART2_CACHE_SIZE] = {0};
uint8_t bsp_uart2_rx_buff[BS_UART2_CACHE_SIZE] = {0};

// 定义串口初始化标记位 0--未初始化 1--初始化完成
bool g_uart2_init = false;
// 定义串口发送标记位 0--free闲 1--bus忙
bool g_uart2_send_lock = false;
// 记录当前接收长度
uint8_t g_uart2_rx_len = 0;
// 定义串口接收回调函数
static bsp_uart_callback uart2_irq_rx_callback;
#endif

/* Public Function Prototypes ------------------------------------------------*/
/**
* @brief 设置串口波特率
* @param uart: 串口组号
* @param baud: 波特率
*/
void biz_uart_set_baud_rate(bsp_uart_t uart, uint32_t baud)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
huart0.USART_BaudRate = baud;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
huart1.USART_BaudRate = baud;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
huart2.USART_BaudRate = baud;
#endif
}
return;
}

/**
* @brief 串口初始化
* @param uart: 串口组号
*/
void bsp_uart_init(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
if (g_uart0_init)
{
return;
}
bsp_exit_set(BSP_UART0_IRQN, 0);

BS_UART0_RX_GPIO_CLK_ENABLE();
BS_UART0_TX_GPIO_CLK_ENABLE();

bsp_gpio_init_uart(BS_UART0_TX_GPIO_PORT, BS_UART0_TX_PIN, AF_TXD);
bsp_gpio_init_uart(BS_UART0_RX_GPIO_PORT, BS_UART0_RX_PIN, AF_RXD);

BSP_UART0_APBX_CLOCK();

/* Configure USART0 */
USART_Init(BSP_UART0, &huart0);
g_uart0_rx_len = 0;
USART_INTConfig(BSP_UART0, USART_INT_RDNE, ENABLE);
/* Enable the USART0 */
USART_Cmd(BSP_UART0, ENABLE);
g_uart0_init = true;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
if (g_uart1_init)
{
return;
}
bsp_exit_set(BSP_UART1_IRQN, 5);
bsp_gpio_set_clk(GPIO_APBx, BS_UART1_RX_GPIO_CLK, true);
bsp_gpio_set_clk(GPIO_APBx, BS_UART1_TX_GPIO_CLK, true);

bsp_gpio_init_uart(BS_UART1_TX_GPIO_PORT, BS_UART1_TX_PIN, AF_TXD);
bsp_gpio_init_uart(BS_UART1_RX_GPIO_PORT, BS_UART1_RX_PIN, AF_RXD);

BSP_UART1_APBX_CLOCK();

/* Configure USART1 */
USART_Init(BSP_UART1, &huart1);
g_uart1_rx_len = 0;
USART_INTConfig(BSP_UART1, USART_INT_RDNE, ENABLE);
/* Enable the USART1 */
USART_Cmd(BSP_UART1, ENABLE);
g_uart1_init = true;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
if (g_uart2_init)
{
return;
}
bsp_exit_set(BSP_UART2_IRQN, 5);
bsp_gpio_set_clk(GPIO_APBx, BS_UART2_RX_GPIO_CLK, true);
bsp_gpio_set_clk(GPIO_APBx, BS_UART2_TX_GPIO_CLK, true);

bsp_gpio_init_uart(BS_UART2_TX_GPIO_PORT, BS_UART2_TX_PIN, AF_TXD);
bsp_gpio_init_uart(BS_UART2_RX_GPIO_PORT, BS_UART2_RX_PIN, AF_RXD);

BSP_UART2_APBX_CLOCK();

/* Configure USART2 */
USART_Init(BSP_UART2, &huart2);
g_uart2_rx_len = 0;
USART_INTConfig(BSP_UART2, USART_INT_RDNE, ENABLE);
/* Enable the USART2 */
USART_Cmd(BSP_UART2, ENABLE);
g_uart2_init = true;
#endif
}
}

/**
* @brief 串口反注册 关闭串口时钟并复位引脚
* @param uart: 串口组号
*/
void bsp_uart_deinit(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
if (!g_uart0_init)
{
return;
}
USART_Reset(BSP_UART0);
bsp_gpio_deinit(BS_UART0_TX_GPIO_PORT, BS_UART0_TX_PIN);
bsp_gpio_deinit(BS_UART0_RX_GPIO_PORT, BS_UART0_RX_PIN);
g_uart0_init = false;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
if (!g_uart1_init)
{
return;
}
USART_Reset(BSP_UART1);
bsp_gpio_deinit(BS_UART1_TX_GPIO_PORT, BS_UART1_TX_PIN);
bsp_gpio_deinit(BS_UART1_RX_GPIO_PORT, BS_UART1_RX_PIN);
g_uart1_init = false;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
if (!g_uart2_init)
{
return;
}
USART_Reset(BSP_UART2);
bsp_gpio_deinit(BS_UART2_TX_GPIO_PORT, BS_UART2_TX_PIN);
bsp_gpio_deinit(BS_UART2_RX_GPIO_PORT, BS_UART2_RX_PIN);
g_uart2_init = false;
#endif
}
}

/**
* @brief 注册串口接收回调函数
* @param uart: 串口组号
* @param event: 事件回调函数
* @retval 0--失败 1--成功
*/
bool bsp_uart_rx_irq_callback(bsp_uart_t uart, void *event)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
if (uart0_irq_rx_callback != NULL)
{
return true;
}
else
{
uart0_irq_rx_callback = (bsp_uart_callback)event;
}
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
if (uart1_irq_rx_callback != NULL)
{
return true;
}
else
{
uart1_irq_rx_callback = (bsp_uart_callback)event;
}
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
if (uart2_irq_rx_callback != NULL)
{
return true;
}
else
{
uart2_irq_rx_callback = (bsp_uart_callback)event;
}
#endif
}
return false;
}

#if BS_UART0_EN
/**
* @brief This function handles USART global interrupt request.
*/
void BSP_UART0_IRQ_HANDLER(void)
{
if (USART_GetITStatus(BSP_UART0, USART_INT_RDNE) != RESET)
{
/* Read one byte from the receive data register */
bsp_uart0_rx_buff[g_uart0_rx_len++] = USART_ReceiveData(BSP_UART0);
if (uart0_irq_rx_callback)
{
uart0_irq_rx_callback();
}
if (g_uart0_rx_len >= (BS_UART0_CACHE_SIZE - 1))
{
g_uart0_rx_len = 0;
}
}
}
#endif

#if BS_UART1_EN
/**
* @brief This function handles USART global interrupt request.
*/
void BSP_UART1_IRQ_HANDLER(void)
{
if (USART_GetITStatus(BSP_UART1, USART_INT_RDNE) != RESET)
{
/* Read one byte from the receive data register */
bsp_uart1_rx_buff[g_uart1_rx_len++] = USART_ReceiveData(BSP_UART1);
if (uart1_irq_rx_callback)
{
uart1_irq_rx_callback();
}
if (g_uart1_rx_len >= (BS_UART1_CACHE_SIZE - 1))
{
g_uart1_rx_len = 0;
}
}
}
#endif

#if BS_UART2_EN
/**
* @brief This function handles USART global interrupt request.
*/
void BSP_UART2_IRQ_HANDLER(void)
{
if (USART_GetITStatus(BSP_UART2, USART_INT_RDNE) != RESET)
{
/* Read one byte from the receive data register */
bsp_uart2_rx_buff[g_uart2_rx_len++] = USART_ReceiveData(BSP_UART2);
if (uart2_irq_rx_callback)
{
uart2_irq_rx_callback();
}
if (g_uart2_rx_len >= (BS_UART2_CACHE_SIZE - 1))
{
g_uart2_rx_len = 0;
}
}
}
#endif

/************************************[uart] 使用函数************************************/
/**
* @brief 发送一个字节
* @param uart: 串口组号
* @param data: 字节值
*/
void bsp_uart_send_byte(bsp_uart_t uart, uint8_t data)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
if (!g_uart0_init)
{
return;
}
USART_SendData(BSP_UART0, data);
//send data empty flag
while(RESET == USART_GetFlagStatus(BSP_UART0, USART_FLAG_TDE));
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
if (!g_uart1_init)
{
return;
}
USART_SendData(BSP_UART1, data);
//send data empty flag
while(RESET == USART_GetFlagStatus(BSP_UART1, USART_FLAG_TDE));
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
if (!g_uart2_init)
{
return;
}
USART_SendData(BSP_UART2, data);
//send data empty flag
while(RESET == USART_GetFlagStatus(BSP_UART2, USART_FLAG_TDE));
#endif
}
return;
}

/**
* @brief 发送多个字节(堵塞)
* @param uart: 串口组号
* @param *data: 数据头指针
* @param len: 数据长度
*/
bool bsp_uart_send_nbyte(bsp_uart_t uart, uint8_t *data, uint16_t len)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
if (!g_uart0_init)
{
return false;
}
if (g_uart0_send_lock)
{
return false;
}
g_uart0_send_lock = true;
if (data != NULL)
{
for (uint16_t i = 0; i < len; i++)
{
bsp_uart_send_byte(BSP_UART_0, data[i]);
}
}
else
{
for (uint16_t i = 0; i < len; i++)
{
bsp_uart_send_byte(BSP_UART_0, bsp_uart0_tx_buff[i]);
}
}
g_uart0_send_lock = false;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
if (!g_uart1_init)
{
return false;
}
if (g_uart1_send_lock)
{
return false;
}
g_uart1_send_lock = true;
if (data != NULL)
{
for (uint16_t i = 0; i < len; i++)
{
bsp_uart_send_byte(BSP_UART_1, data[i]);
}
}
else
{
for (uint16_t i = 0; i < len; i++)
{
bsp_uart_send_byte(BSP_UART_1, bsp_uart1_tx_buff[i]);
}
}
g_uart1_send_lock = false;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
if (!g_uart2_init)
{
return false;
}
if (g_uart2_send_lock)
{
return false;
}
g_uart2_send_lock = true;
if (data != NULL)
{
for (uint16_t i = 0; i < len; i++)
{
bsp_uart_send_byte(BSP_UART_2, data[i]);
}
}
else
{
for (uint16_t i = 0; i < len; i++)
{
bsp_uart_send_byte(BSP_UART_2, bsp_uart2_tx_buff[i]);
}
}
g_uart2_send_lock = false;
#endif
}
return true;
}

/**
* @brief 发送多个字节(非堵塞) 一般DMA方式
* @param uart: 串口组号
* @param *data: 数据头指针
* @param len: 数据长度
*/
void bsp_uart_send_nbyte_nowait(bsp_uart_t uart, uint8_t *data, uint16_t len)
{
return;
}

/**
* @brief 得到txbuff头指针
* @param uart: 串口组号
*/
uint8_t *bsp_uart_get_txbuff(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
if (g_uart0_send_lock == false)
{
return bsp_uart0_tx_buff;
}
return NULL;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
if (g_uart1_send_lock == false)
{
return bsp_uart1_tx_buff;
}
return NULL;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
if (g_uart2_send_lock == false)
{
return bsp_uart2_tx_buff;
}
return NULL;
#endif
}
return NULL;
}

/**
* @brief 得到rxbuff头指针
* @param uart: 串口组号
*/
uint8_t *bsp_uart_get_rxbuff(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
return bsp_uart0_rx_buff;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
return bsp_uart1_rx_buff;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
return bsp_uart2_rx_buff;
#endif
}
return NULL;
}

/**
* @brief [串口信息] 返回串口缓存指针位置,即当前缓存数量(byte)
* @param uart: 串口号
* @retval 串口缓存指针位置
*/
uint16_t bsp_uart_get_rxbuff_position(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
return g_uart0_rx_len;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
return g_uart1_rx_len;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
return g_uart2_rx_len;
#endif
}
return NULL;
}

/**
* @brief 得到rxbuff大小
* @param uart: 串口组号
* @retval 字节大小
*/
uint16_t bsp_uart_get_rxbuff_size(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
return BS_UART0_CACHE_SIZE;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
return BS_UART1_CACHE_SIZE;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
return BS_UART2_CACHE_SIZE;
#endif
}
return 0;
}

/**
* @brief [串口操作] 关闭串口接收:关闭串口中断,终止接收中断回调
* @note 由于无DMA,只能先关闭,再处理数据,防止数据错乱。然后重新读取。
* @param uart: 串口号
*/
void bsp_uart_rx_close(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
if (!g_uart0_init)
{
return;
}
USART_Reset(BSP_UART0);
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
if (!g_uart1_init)
{
return;
}
USART_Reset(BSP_UART1);
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
if (!g_uart2_init)
{
return;
}
USART_Reset(BSP_UART2);
#endif
}
return;
}

/**
* @brief [串口操作] 打开串口接收:打开串口中断,设置接收中断回调
* @note 由于无DMA,只能先关闭,再处理数据,防止数据错乱。然后重新读取。
* @param uart: 串口号
*/
void bsp_uart_rx_open(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
bsp_uart_init(BSP_UART_0);
g_uart0_rx_len = 0;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
bsp_uart_init(BSP_UART_1);
g_uart1_rx_len = 0;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
bsp_uart_init(BSP_UART_2);
g_uart2_rx_len = 0;
#endif
}
return;
}

/**
* @brief [串口操作] 复位接收缓存指针
* @param uart: 串口号
*/
void bsp_uart_reset_rxbuff(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
g_uart0_rx_len = 0;
memset(bsp_uart0_rx_buff, 0, BS_UART0_CACHE_SIZE);
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
g_uart1_rx_len = 0;
memset(bsp_uart1_rx_buff, 0, BS_UART1_CACHE_SIZE);
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
g_uart2_rx_len = 0;
memset(bsp_uart2_rx_buff, 0, BS_UART2_CACHE_SIZE);
#endif
}
return;
}

bool bsp_uart_get_bus(bsp_uart_t uart)
{
if (uart == BSP_UART_0)
{
#if BS_UART0_EN
return g_uart0_send_lock;
#endif
}
else if (uart == BSP_UART_1)
{
#if BS_UART1_EN
return g_uart1_send_lock;
#endif
}
else if (uart == BSP_UART_2)
{
#if BS_UART2_EN
return g_uart2_send_lock;
#endif
}
return false;
}
/********************************************************************************
* @file bsp_uart.h
* @author jianqiang.xue
* @version V1.0.0
* @date 2021-04-13
* @brief NULL
********************************************************************************/

#ifndef __BSP_UART_H
#define __BSP_UART_H

/* Includes ------------------------------------------------------------------*/
#include <stdint.h>
#include <stdbool.h>

/* Public enum ---------------------------------------------------------------*/
typedef enum
{
BSP_UART_0 = 0,
BSP_UART_1 = 1,
BSP_UART_2 = 2,
} bsp_uart_t;

/* Public Function Prototypes ------------------------------------------------*/

// uart基础功能

void bsp_uart_init(bsp_uart_t uart);
void bsp_uart_deinit(bsp_uart_t uart);
void biz_uart_set_baud_rate(bsp_uart_t uart, uint32_t baud);

void bsp_uart_rx_close(bsp_uart_t uart);
void bsp_uart_rx_open(bsp_uart_t uart);

bool bsp_uart_rx_irq_callback(bsp_uart_t uart, void *event);

// uart发送函数

void bsp_uart_send_byte(bsp_uart_t uart, uint8_t data);
bool bsp_uart_send_nbyte(bsp_uart_t uart, uint8_t *data, uint16_t len);
void bsp_uart_send_nbyte_nowait(bsp_uart_t uart, uint8_t *data, uint16_t len);

bool bsp_uart_get_bus(bsp_uart_t uart);

// 获得tx/rx缓冲区首指针

uint8_t *bsp_uart_get_txbuff(bsp_uart_t uart);
uint8_t *bsp_uart_get_rxbuff(bsp_uart_t uart);

uint16_t bsp_uart_get_rxbuff_position(bsp_uart_t uart);
void bsp_uart_set_rxbuff_position(bsp_uart_t uart, uint16_t val);
void bsp_uart_add_rxbuff_position(bsp_uart_t uart);

uint16_t bsp_uart_get_rxbuff_size(bsp_uart_t uart);
void bsp_uart_reset_rxbuff(bsp_uart_t uart);

#endif


标签:rx,AT32F415,USART,uart,BSP,bsp,BS
From: https://blog.51cto.com/xuejianqiang/5810729

相关文章

  • [单片机框架][bsp层][AT32F415][bsp_tim] tim定时器配置和使用
    9定时器(TIMER)9.1通用定时器(TMR2到TMR5)9.1.1TMRx简介通用定时器是一个通过可编程预分频器驱动的16位自动装载计数器构成。它适用于多种场合,包括测量输入信号的脉冲长度......
  • [单片机框架][bsp层][AT32F415][bsp_adc] adc配置和使用
    12.1ADC介绍12位ADC是一种逐次逼近型模拟数字转换器。它有多达18个通道,可测量16个外部和2个内部信号源。各通道的A/D转换可以单次、连续、扫描或间断模式执行。......
  • [单片机框架][bsp层][AT32F415][bsp_exti] EXTI配置和使用
    7.2.1主要特性EXTI控制器的主要特性如下:●每个中断/事件都有独立的触发和屏蔽●每个中断线都有专用的状态位●支持多达23个软件的中断/事件请求●检测脉冲宽度......
  • [单片机框架][bsp层][AT32F415][bsp_led] LED配置和使用
    重新封装一层函数,用于bsp层函数,方便调用。voidbsp_led_init(void);voidbsp_led_deinit(void);voidbsp_led_on(bsp_led_tch);voidbsp_led_off(bsp_led_tch);voidb......
  • [单片机框架][bsp层][AT32F415][bsp_gpio] GPIO配置和使用
    6.1简介GPIO接口包括5组通用输入/输出端口。每个GPIO组提供16个通用输入/输出引脚;每个GPIO端口都有相关的控制和配置寄存器来满足特定的功能,GPIO引脚上的外部......
  • 三大低速总线之UART
    1、串口又叫通用异步收发传输器,即UART;是一种通用的数据通信协议。2、接受数据时:将接收到的串行数据转换成并行数据;(涉及到串转并)发送数据时:将并行数据转换成串行数据来传......
  • 十四,SpringBoot-整合Quartz
     Quartz是一个任务调度框架,在以前我们使用它的时候都是xml配置的方式,在spingboot中只需要几个注解就可以轻松搞定。主要用到以下几个注解:1.@Scheduled可以理解成触发器2.......
  • Quartz定时调度
    在SpringBoot中有Java自带的av.util.Timer类,SpringBoot自带的Scheduled来实现也有强大的调度器Quartz.Scheduled在Spring3.X引入,默认SpringBoot自带该功能使用起来也......
  • Quartz Scheduler
    SchedulerFactory&Scheduler&QuartzScheduler&QuartzSchedulerThread&ThreadExecutor(DefaultThreadExecutor)&ThreadPool(SimpleThreadPoolandWorkThread)是Qu......
  • ElementUI 季度选择器 QuarterPicker
    一、在项目 components 路径下创建 quarter-picker 文件夹1<!--2*@Descripttion:季度选择器3*@version:1.04*@Author:https://www.lervor.......