2022-10-20 17:13:02 +08:00
|
|
|
#ifndef BSP_RC_H
|
|
|
|
#define BSP_RC_H
|
|
|
|
|
2022-12-12 22:29:51 +08:00
|
|
|
#include <stdint.h>
|
2022-10-20 17:13:02 +08:00
|
|
|
#include "main.h"
|
|
|
|
|
2022-11-01 22:32:15 +08:00
|
|
|
#define DEVICE_USART_CNT 3 // C板至多分配3个串口
|
2023-01-01 17:32:22 +08:00
|
|
|
#define USART_RXBUFF_LIMIT 256 // 如果协议需要更大的buff,请修改这里
|
2022-10-20 17:13:02 +08:00
|
|
|
|
2023-01-01 17:32:22 +08:00
|
|
|
// 模块回调函数,用于解析协议
|
2022-10-20 17:13:02 +08:00
|
|
|
typedef void (*usart_module_callback)();
|
|
|
|
|
2023-03-18 20:36:21 +08:00
|
|
|
/* 发送模式枚举 */
|
2023-01-04 21:26:11 +08:00
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
USART_TRANSFER_NONE=0,
|
2023-03-18 14:50:50 +08:00
|
|
|
USART_TRANSFER_BLOCKING,
|
|
|
|
USART_TRANSFER_IT,
|
|
|
|
USART_TRANSFER_DMA,
|
2023-01-04 21:26:11 +08:00
|
|
|
} USART_TRANSFER_MODE;
|
|
|
|
|
2023-02-14 11:13:32 +08:00
|
|
|
// 串口实例结构体,每个module都要包含一个实例.
|
|
|
|
// 由于串口是独占的点对点通信,所以不需要考虑多个module同时使用一个串口的情况,因此不用加入id;当然也可以选择加入,这样在bsp层可以访问到module的其他信息
|
2022-10-20 17:13:02 +08:00
|
|
|
typedef struct
|
|
|
|
{
|
2022-11-01 22:32:15 +08:00
|
|
|
uint8_t recv_buff[USART_RXBUFF_LIMIT]; // 预先定义的最大buff大小,如果太小请修改USART_RXBUFF_LIMIT
|
|
|
|
uint8_t recv_buff_size; // 模块接收一包数据的大小
|
|
|
|
UART_HandleTypeDef *usart_handle; // 实例对应的usart_handle
|
|
|
|
usart_module_callback module_callback; // 解析收到的数据的回调函数
|
2022-12-05 21:01:26 +08:00
|
|
|
} USARTInstance;
|
2022-10-20 17:13:02 +08:00
|
|
|
|
2022-11-28 17:54:07 +08:00
|
|
|
/* usart 初始化配置结构体 */
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
uint8_t recv_buff_size; // 模块接收一包数据的大小
|
|
|
|
UART_HandleTypeDef *usart_handle; // 实例对应的usart_handle
|
|
|
|
usart_module_callback module_callback; // 解析收到的数据的回调函数
|
|
|
|
} USART_Init_Config_s;
|
|
|
|
|
2022-10-20 17:13:02 +08:00
|
|
|
/**
|
2023-03-18 20:36:21 +08:00
|
|
|
* @brief 注册一个串口实例,返回一个串口实例指针
|
2022-10-20 17:13:02 +08:00
|
|
|
*
|
2022-11-28 17:54:07 +08:00
|
|
|
* @param init_config 传入串口初始化结构体
|
2022-10-20 17:13:02 +08:00
|
|
|
*/
|
2022-12-05 21:01:26 +08:00
|
|
|
USARTInstance *USARTRegister(USART_Init_Config_s *init_config);
|
2022-10-20 17:13:02 +08:00
|
|
|
|
2023-03-18 20:36:21 +08:00
|
|
|
/**
|
|
|
|
* @brief 启动串口服务,需要传入一个usart实例.一般用于lost callback的情况(使用串口的模块daemon)
|
|
|
|
*
|
|
|
|
* @param _instance
|
|
|
|
*/
|
|
|
|
void USARTServiceInit(USARTInstance *_instance);
|
|
|
|
|
|
|
|
|
2022-10-20 17:13:02 +08:00
|
|
|
/**
|
2023-01-01 17:32:22 +08:00
|
|
|
* @brief 通过调用该函数可以发送一帧数据,需要传入一个usart实例,发送buff以及这一帧的长度
|
2023-03-18 20:36:21 +08:00
|
|
|
* @note 在短时间内连续调用此接口,若采用IT/DMA会导致上一次的发送未完成而新的发送取消.
|
|
|
|
* @note 若希望连续使用DMA/IT进行发送,请配合USARTIsReady()使用,或自行为你的module实现一个发送队列和任务.
|
|
|
|
* @todo 是否考虑为USARTInstance增加发送队列以进行连续发送?
|
2023-02-14 11:13:32 +08:00
|
|
|
*
|
2023-01-01 17:32:22 +08:00
|
|
|
* @param _instance 串口实例
|
|
|
|
* @param send_buf 待发送数据的buffer
|
2022-10-20 17:13:02 +08:00
|
|
|
* @param send_size how many bytes to send
|
|
|
|
*/
|
2023-03-18 14:50:50 +08:00
|
|
|
void USARTSend(USARTInstance *_instance, uint8_t *send_buf, uint16_t send_size,USART_TRANSFER_MODE mode);
|
2023-01-04 21:26:11 +08:00
|
|
|
|
2023-03-18 20:36:21 +08:00
|
|
|
/**
|
|
|
|
* @brief 判断串口是否准备好,用于连续或异步的IT/DMA发送
|
|
|
|
*
|
|
|
|
* @param _instance 要判断的串口实例
|
|
|
|
* @return uint8_t ready 1, busy 0
|
|
|
|
*/
|
|
|
|
uint8_t USARTIsReady(USARTInstance *_instance);
|
|
|
|
|
2022-10-20 17:13:02 +08:00
|
|
|
#endif
|