This commit is contained in:
JiXieShi
2024-05-09 13:56:55 +08:00
commit 97aa90ab4a
12 changed files with 832 additions and 0 deletions

119
lib/inc/spi/spi.h Normal file
View File

@@ -0,0 +1,119 @@
//
// Created by lydxh on 2024/4/8.
//
#ifndef HW_LIB_SPI_H
#define HW_LIB_SPI_H
#include <stdint.h>
#define HIGH 1
#define LOW 0
#define NOP() ;
#define DELAY1US() NOP()
/**
* @brief SPI通信模式枚举
**/
typedef enum {
Mode0, // 时钟空闲状态为低电平,数据在时钟的下降沿采样
Mode1, // 时钟空闲状态为低电平,数据在时钟的上升沿采样
Mode2, // 时钟空闲状态为高电平,数据在时钟的下降沿采样
Mode3 // 时钟空闲状态为高电平,数据在时钟的上升沿采样
} mode;
/**
* @brief 数据端序枚举
**/
typedef enum {
LTL, // 小端模式,低字节在低地址
LTB, // 小端模式,低字节在高地址
BTB, // 大端模式,低字节在低地址
BTL // 大端模式,低字节在高地址
} endian;
/**
* @brief SPI设备结构体
**/
typedef struct {
uint8_t (*MOSI_SET)(uint8_t); // 设置MOSI引脚状态的函数指针
uint8_t (*SCK_SET)(uint8_t); // 设置SCK引脚状态的函数指针
uint8_t (*CS_SET)(uint8_t); // 设置CS引脚状态的函数指针
uint8_t (*MISO)(); // 读取MISO引脚状态的函数指针
mode MODE; // SPI模式
uint8_t CS; // CS引脚编号
endian ENDIAN; // 数据端序
} HW_Dev_Spi;
/**
* @brief 向 SPI 设备写入一个字节并读取返回的数据
* @param Dev: [输入] SPI 设备
* @param Write_Date: [输入]要写入的数据
* @return 读取到的数据
**/
uint8_t HW_SPI_RW(HW_Dev_Spi Dev, uint8_t Write_Date);
/**
* @brief 向 SPI 设备写入数据流
* @param Dev: [输入] SPI 设备
* @param Write_Date: [输入]要写入的数据流指针
* @param Len: [输入] 数据流长度
* @return void
**/
void HW_SPI_WL(HW_Dev_Spi Dev, uint8_t *Write_Date, uint32_t Len);
/**
* @brief 从 SPI 设备读取数据流
* @param Dev: [输入] SPI 设备
* @param Read_Date: [输出]存储读取数据的缓冲区指针
* @param Len: [输入] 读取数据流长度
* @return void
**/
void HW_SPI_RL(HW_Dev_Spi Dev, uint8_t *Read_Date, uint32_t Len);
/**
* @brief 向 SPI 设备写入数据并读取返回数据流
* @param Dev: [输入] SPI 设备
* @param Read_Date: [输出]存储读取数据的缓冲区指针
* @param Write_Date: [输入]要写入的数据流指针
* @param Len: [输入] 数据流长度
* @return void
**/
void HW_SPI_RWL(HW_Dev_Spi Dev, uint8_t *Read_Date, uint8_t *Write_Date, uint32_t Len);
/**
* @brief 向 SPI 设备写入一个字16位并读取返回的数据
* @param Dev: [输入] SPI 设备
* @param Write_Date: [输入]要写入的数据
* @return 读取到的数据
**/
uint16_t HW_SPI_RW16(HW_Dev_Spi Dev, uint16_t Write_Date);
/**
* @brief 从 SPI 设备读取数据流16位
* @param Dev: [输入] SPI 设备
* @param Read_Date: [输出]存储读取数据的缓冲区指针
* @param Len: [输入] 读取数据流长度
* @return void
**/
void HW_SPI_RL16(HW_Dev_Spi Dev, uint16_t *Read_Date, uint32_t Len);
/**
* @brief 向 SPI 设备写入数据流16位
* @param Dev: [输入] SPI 设备
* @param Write_Date: [输入]要写入的数据流指针
* @param Len: [输入] 数据流长度
* @return void
**/
void HW_SPI_WL16(HW_Dev_Spi Dev, uint16_t *Write_Date, uint32_t Len);
/**
* @brief 向 SPI 设备写入数据并读取返回数据流16位
* @param Dev: [输入] SPI 设备
* @param Read_Date: [输出]存储读取数据的缓冲区指针
* @param Write_Date: [输入]要写入的数据流指针
* @param Len: [输入] 数据流长度
* @return void
**/
void HW_SPI_RWL16(HW_Dev_Spi Dev, uint16_t *Read_Date, uint16_t *Write_Date, uint32_t Len);
#endif //HW_LIB_SPI_H