sentry_gimbal_hzz/bsp/iic/bsp_iic.h

106 lines
3.5 KiB
C
Raw Normal View History

#include "i2c.h"
#include "stdint.h"
#define IIC_DEVICE_CNT 2 // C板引出了I2C2和I2C3
#define MX_IIC_SLAVE_CNT 8 // 最大从机数目,根据需要修改
/* i2c 工作模式枚举 */
typedef enum
{
// 基本工作模式
IIC_BLOCK_MODE = 0, // 阻塞模式
IIC_IT_MODE, // 中断模式
IIC_DMA_MODE, // DMA模式
} IIC_Work_Mode_e;
/* I2C MEM工作模式枚举,这两种方法都是阻塞 */
typedef enum
{
IIC_READ_MEM = 0, // 读取从机内部的寄存器or内存
IIC_WRITE_MEM, // 写入从机内部的寄存器or内存
} IIC_Mem_Mode_e;
/* Seq传输工作模式枚举,注意HOLD_ON要在IT或DMA下使用 */
// 必须以IIC_RELEASE为最后一次传输,否则会导致总线占有权无法释放
typedef enum
{
IIC_RELEASE, // 完成传输后释放总线占有权,这是默认的传输方式
IIC_HOLD_ON = 0, // 保持总线占有权不释放,只支持IT和DMA模式
} IIC_Seq_Mode_e;
/* i2c实例 */
typedef struct iic_temp_s
{
I2C_HandleTypeDef *handle; // i2c handle
uint8_t dev_address; // 暂时只支持7位地址(还有一位是读写位)
IIC_Work_Mode_e work_mode; // 工作模式
uint8_t *rx_buffer; // 接收缓冲区指针
uint8_t rx_len; // 接收长度
void (*callback)(struct iic_temp_s *); // 接收完成后的回调函数
void *id; // 用于标识i2c instance
} IICInstance;
/* I2C 初始化结构体配置 */
typedef struct
{
I2C_HandleTypeDef *handle; // i2c handle
uint8_t dev_address; // 暂时只支持7位地址(还有一位是读写位),注意不需要左移
IIC_Work_Mode_e work_mode; // 工作模式
void (*callback)(IICInstance *); // 接收完成后的回调函数
void *id; // 用于标识i2c instance
} IIC_Init_Config_s;
/**
* @brief IIC初始化
*
* @param conf
* @return IICInstance*
*/
IICInstance *IICRegister(IIC_Init_Config_s *conf);
/**
* @brief IIC设置工作模式
*
* @param iic iic实例
* @param mode
*/
void IICSetMode(IICInstance *iic, IIC_Work_Mode_e mode);
/**
* @brief IIC发送数据
*
* @param iic iic实例
* @param data
* @param size
* @param mode
* @note ,,使#pragma pack(1),使#pragma pack()
*
*/
void IICTransmit(IICInstance *iic, uint8_t *data, uint16_t size, IIC_Seq_Mode_e mode);
/**
* @brief IIC接收数据
*
* @param iic iic实例
* @param data
* @param size
* @param mode
* @note ,memcpy到目标结构体或通过强制类型转换进行逐字节写入,
* 使#pragma pack(1),使#pragma pack()
*/
void IICReceive(IICInstance *iic, uint8_t *data, uint16_t size,IIC_Seq_Mode_e mode);
/**
* @brief IIC读取从机寄存器(),,1ms
*
* @param iic iic实例
* @param mem_addr ,8
* @param data
* @param size
* @param mode : IIC_READ_MEM or IIC_WRITE_MEM
*/
void IICAcessMem(IICInstance *iic, uint8_t mem_addr, uint8_t *data, uint16_t size, IIC_Mem_Mode_e mode);