|
8 tahun lalu | |
---|---|---|
.. | ||
inc | 8 tahun lalu | |
src | 8 tahun lalu | |
LICENSE | 8 tahun lalu | |
README.md | 8 tahun lalu |
SFUD 是一款开源的串行 SPI Flash 通用驱动库。由于现有市面的串行 Flash 种类居多,各个 Flash 的规格及命令存在差异, SFUD 就是为了解决这些 Flash 的差异现状而设计,让我们的产品能够支持不同品牌及规格的 Flash,提高了涉及到 Flash 功能的软件的可重用性及可扩展性,同时也可以规避 Flash 缺货或停产给产品所带来的风险。
/sfud/inc/sfud_flash_def.h
) 中提供的 Flash 参数信息表 中是否支持该款 Flash。如果不支持,则可以在配置文件中添加该款 Flash 的参数信息(添加方法详细见 2.5 添加库目前不支持的 Flash)。获取到了 Flash 的规格参数后,就可以实现对 Flash 的全部操作。下表为所有在 Demo 平台上进行过真机测试的 Flash。目前 SFUD 提供的 Flash 参数信息表 只包括下表中 不支持 SFDP 标准的 Flash,其他不支持 SFDP 标准的 Flash 需要大家以后 共同来完善和维护 (Github|OSChina|Coding) 。如果觉得这个开源项目很赞,可以点击 项目主页 右上角的 Star ,同时把它推荐给更多有需要的朋友。
型号 | 制造商 | 容量 | 最高速度 | SFDP | 备注 |
---|---|---|---|---|---|
W25Q40BV | Winbond | 4Mb | 50Mhz | 不支持 | 已停产 |
W25Q80DV | Winbond | 8Mb | 104Mhz | 支持 | |
W25Q16CV | Winbond | 16Mb | 104Mhz | 支持 | |
W25Q32BV | Winbond | 32Mb | 104Mhz | 支持 | |
W25Q64CV | Winbond | 64Mb | 80Mhz | 支持 | |
W25Q128BV | Winbond | 128Mb | 104Mhz | 支持 | |
W25Q256FV | Winbond | 256Mb | 104Mhz | 支持 | |
MX25L3206E | Macronix | 32Mb | 86MHz | 支持 | |
KH25L3206E | Macronix | 32Mb | 86Mhz | 支持 | |
SST25VF016B | Microchip | 16Mb | 50MHz | 不支持 | SST 已被 Microchip 收购 |
M25P32 | Micron | 32Mb | 75Mhz | 不支持 | |
EN25Q32B | EON | 32Mb | 104MHz | 不支持 | |
GD25Q64B | GigaDevice | 64Mb | 120Mhz | 不支持 | |
S25FL216K | Cypress | 16Mb | 65Mhz | 不支持 | |
S25FL164K | Cypress | 64Mb | 108Mhz | 支持 | |
A25LQ64 | AMIC | 64Mb | 104Mhz | 支持 | |
A25L080 | AMIC | 8Mb | 100Mhz | 不支持 | |
F25L004 | ESMT | 4Mb | 100Mhz | 不支持 | |
PCT25VF016B | PCT | 16Mb | 80Mhz | 不支持 | SST 授权许可,会被识别为 SST25VF016B |
AT45DB161E | ADESTO | 16Mb | 85MHz | 不支持 | ADESTO 收购 Atmel 串行闪存产品线 |
sfud_err sfud_init(void)
在 SFUD 配置文件中会定义 Flash 设备表,负责存放所有将要使用的 Flash 设备对象,所以 SFUD 支持多个 Flash 设备同时驱动。设备表的配置在 /sfud/inc/sfud_cfg.h
中 SFUD_FLASH_DEVICE_TABLE
宏定义,详细配置方法参照 2.3 配置方法 Flash)。本方法通过 Flash 设备位于设备表中索引值来返回 Flash 设备对象,超出设备表范围返回 NULL
。
sfud_flash *sfud_get_device(size_t index)
参数 | 描述 |
---|---|
index | Flash 设备位于 FLash 设备表中的索引值 |
返回 Flash 设备表的总长度。
size_t sfud_get_device_num(void)
const sfud_flash *sfud_get_device_table(void)
sfud_err sfud_read(const sfud_flash *flash, uint32_t addr, size_t size, uint8_t *data)
参数 | 描述 |
---|---|
flash | Flash 设备对象 |
addr | 起始地址 |
size | 读取数据的大小 |
data | 读取到的数据 |
sfud_err sfud_erase(const sfud_flash *flash, uint32_t addr, size_t size)
参数 | 描述 |
---|---|
flash | Flash 设备对象 |
addr | 起始地址 |
size | 擦除数据的大小 |
sfud_err sfud_chip_erase(const sfud_flash *flash)
参数 | 描述 |
---|---|
flash | Flash 设备对象 |
sfud_err sfud_write(const sfud_flash *flash, uint32_t addr, size_t size, const uint8_t *data)
参数 | 描述 |
---|---|
flash | Flash 设备对象 |
addr | 起始地址 |
size | 写数据的大小 |
data | 待写入的数据 |
sfud_err sfud_erase_write(const sfud_flash *flash, uint32_t addr, size_t size, const uint8_t *data)
参数 | 描述 |
---|---|
flash | Flash 设备对象 |
addr | 起始地址 |
size | 写数据的大小 |
data | 待写入的数据 |
sfud_err sfud_read_status(const sfud_flash *flash, uint8_t *status)
参数 | 描述 |
---|---|
flash | Flash 设备对象 |
status | 当前状态寄存器值 |
sfud_err sfud_write_status(const sfud_flash *flash, bool is_volatile, uint8_t status)
参数 | 描述 |
---|---|
flash | Flash 设备对象 |
is_volatile | 是否为易闪失的,true: 易闪失的,及断电后会丢失 |
status | 当前状态寄存器值 |
所有配置位于 /sfud/inc/sfud_cfg.h
,请参考下面的配置介绍,选择适合自己项目的配置。
打开/关闭 SFUD_DEBUG_MODE
宏定义
打开/关闭 SFUD_USING_SFDP
宏定义
注意:关闭后只会查询该库在
/sfud/inc/sfud_flash_def.h
中提供的 Flash 信息表。这样虽然会降低软件的适配性,但减少代码量。
打开/关闭 SFUD_USING_FLASH_INFO_TABLE
宏定义
注意:关闭后该库只驱动支持 SFDP 规范的 Flash,也会适当的降低部分代码量。另外 2.3.2 及 2.3.3 这两个宏定义至少定义一种,也可以两种方式都选择。
主要修改 SFUD_FLASH_DEVICE_TABLE
这个宏定义,示例如下:
enum {
SFUD_W25Q64CV_DEVICE_INDEX = 0,
SFUD_GD25Q64B_DEVICE_INDEX = 1,
};
#define SFUD_FLASH_DEVICE_TABLE \
{ \
[SFUD_W25Q64CV_DEVICE_INDEX] = {.name = "W25Q64CV", .spi.name = "SPI1"}, \
[SFUD_GD25Q64B_DEVICE_INDEX] = {.name = "GD25Q64B", .spi.name = "SPI3"}, \
}
上面定义了两个 Flash 设备(大部分产品一个足以),两个设备的名称为 "W25Q64CV"
及 "GD25Q64B"
,分别对应 "SPI1"
及 "SPI3"
这两个 SPI 设备名称(在移植 SPI 接口时会用到,位于 /sfud/port/sfud_port.c
), SFUD_W25Q16CV_DEVICE_INDEX
与 SFUD_GD25Q64B_DEVICE_INDEX
这两个枚举定义了两个设备位于设备表中的索引,可以通过 sfud_get_device_table()
方法获取到设备表,再配合这个索引值来访问指定的设备。
移植文件位于 /sfud/port/sfud_port.c
,文件中的 sfud_err sfud_spi_port_init(sfud_flash *flash)
方法是库提供的移植方法,在里面完成各个设备 SPI 读写驱动(必选)、重试次数(必选)、重试接口(可选)及 SPI 锁(可选)的配置。更加详细的移植内容,可以参考 demo 中的各个平台的移植文件。
这里需要修改 /sfud/inc/sfdu_flash_def.h
,所有已经支持的 Flash 见 SFUD_FLASH_CHIP_TABLE
宏定义,需要提前准备的 Flash 参数内容分别为:| 名称 | 制造商 ID | 类型 ID | 容量 ID | 容量 | 写模式 | 擦除粗粒度(擦除的最小单位) | 擦除粗粒度对应的命令 | 。这里以添加 兆易创新 ( GigaDevice ) 的 GD25Q64B
Flash 来举例。
此款 Flash 为兆易创新的早期生产的型号,所以不支持 SFDP 标准。首先需要下载其数据手册,找到 0x9F 命令返回的 3 种 ID, 这里需要最后面两字节 ID ,即 type id
及 capacity id
。 GD25Q64B
对应这两个 ID 分别为 0x40
及 0x17
。上面要求的其他 Flash 参数都可以在数据手册中找到,这里要重点说明下 写模式 这个参数,库本身提供的写模式共计有 4 种,详见文件顶部的 sfud_write_mode
枚举类型,同一款 Flash 可以同时支持多种写模式,视情况而定。对于 GD25Q64B
而言,其支持的写模式应该为 SFUD_WM_PAGE_256B
,即写 1-256 字节每页。结合上述 GD25Q64B
的 Flash 参数应如下:
{"GD25Q64B", SFUD_MF_ID_GIGADEVICE, 0x40, 0x17, 8*1024*1024, SFUD_WM_PAGE_256B, 4096, 0x20},
再将其增加到 SFUD_FLASH_CHIP_TABLE
宏定义末尾,即可完成该库对 GD25Q64B
的支持。
目前已支持如下平台下的 Demo
路径 | 平台描述 |
---|---|
/demo/stm32f10x_non_os | STM32F10X 裸机平台 |
/demo/stm32f2xx_rtt | STM32F2XX + RT-Thread 操作系统平台 |
采用 MIT 开源协议,细节请阅读项目中的 LICENSE 文件内容。