uav/bsp/spi/bsp_spi.h

98 lines
3.6 KiB
C
Raw Permalink Normal View History

2024-09-22 16:53:51 +08:00
#include "spi.h"
#include "stdint.h"
#include "gpio.h"
/* 根据开发板引出的spi引脚以及CubeMX中的初始化配置设定 */
#define SPI_DEVICE_CNT 2 // C型开发板引出两路spi,分别连接BMI088/作为扩展IO在8pin牛角座引出
#define MX_SPI_BUS_SLAVE_CNT 4 // 单个spi总线上挂载的从机数目
/* spi transmit recv mode enumerate*/
typedef enum
{
SPI_BLOCK_MODE = 0, // 默认使用阻塞模式
SPI_IT_MODE,
SPI_DMA_MODE,
} SPI_TXRX_MODE_e;
/* SPI实例结构体定义 */
typedef struct spi_ins_temp
{
SPI_HandleTypeDef *spi_handle; // SPI外设handle
GPIO_TypeDef *GPIOx; // 片选信号对应的GPIO,如GPIOA,GPIOB等等
uint16_t cs_pin; // 片选信号对应的引脚号,GPIO_PIN_1,GPIO_PIN_2等等
SPI_TXRX_MODE_e spi_work_mode; // 传输工作模式
uint8_t rx_size; // 本次接收的数据长度
uint8_t *rx_buffer; // 本次接收的数据缓冲区
void (*callback)(struct spi_ins_temp *); // 接收回调函数
void *id; // 模块指针
} SPIInstance;
/* 接收回调函数定义,包含SPI的module按照此格式构建回调函数 */
typedef void (*spi_rx_callback)(SPIInstance *);
// @todo: 这里可以将GPIO_TypeDef *GPIOx; uint16_t cs_pin合并为bsp_gpio以简化代码实现
/* SPI初始化配置,其实基本和SPIIstance一模一样,为了代码风格统一因此再次定义 */
typedef struct
{
SPI_HandleTypeDef *spi_handle; // SPI外设handle
GPIO_TypeDef *GPIOx; // 片选信号对应的GPIO,如GPIOA,GPIOB等等
uint16_t cs_pin; // 片选信号对应的引脚号,GPIO_PIN_1,GPIO_PIN_2等等
SPI_TXRX_MODE_e spi_work_mode; // 传输工作模式
spi_rx_callback callback; // 接收回调函数
void *id; // 模块指针
} SPI_Init_Config_s;
/**
* @brief spi instance
*
* @param conf spi配置
* @return SPIInstance* spi实例指针,spi外设
*/
SPIInstance *SPIRegister(SPI_Init_Config_s *conf);
/**
* @brief spi向对应从机发送数据
* @todo timeout参数
*
* @param spi_ins spi实例指针
* @param ptr_data
* @param len
*/
void SPITransmit(SPIInstance *spi_ins, uint8_t *ptr_data, uint8_t len);
/**
* @brief spi从从机获取数据
* @attention :ptr_data在回调函数被调用之前仍然在作用域内,!!!
*
* @param spi_ins spi实例指针
* @param ptr_data buffer的首地址
* @param len
*/
void SPIRecv(SPIInstance *spi_ins, uint8_t *ptr_data, uint8_t len);
/**
* @brief spi利用移位寄存器同时收发数据
* @todo timeout参数
* @attention :ptr_data_rx在回调函数被调用之前仍然在作用域内,!!!
*
* @param spi_ins spi实例指针
* @param ptr_data_rx
* @param ptr_data_tx
* @param len &
*/
void SPITransRecv(SPIInstance *spi_ins, uint8_t *ptr_data_rx, uint8_t *ptr_data_tx, uint8_t len);
/**
* @brief spi收发的工作模式
*
* @param spi_ins spi实例指针
* @param spi_mode ,(block),(IT),DMA模式.SPI_TXRX_MODE_e的定义
*
* @todo mode作为transmit/recv的参数,spi实例的属性?
*/
void SPISetMode(SPIInstance *spi_ins, SPI_TXRX_MODE_e spi_mode);