sfd - SPI FLASH操作库#
sfd.init(type, spi_id, spi_cs)#
初始化spi flash
参数
传入值类型 |
解释 |
---|---|
string |
类型, 可以是”spi”, 也可以是”zbuff”, 或者”onchip” |
int |
SPI总线的id, 或者 zbuff实例 |
int |
SPI FLASH的片选脚对应的GPIO, 当类型是spi时才需要传 |
返回值
返回值类型 |
解释 |
---|---|
userdata |
成功返回一个数据结构,否则返回nil |
例子
local drv = sfd.init("spi", 0, 17)
if drv then
log.info("sfd", "chip id", sfd.id(drv):toHex())
end
-- 2023.01.15之后的固件支持onchip类型, 支持直接读写片上flash的一小块区域,一般是64k
-- 这块区域通常是fdb/fskv库所在的区域, 所以不要混着用
local onchip = sfd.init("onchip")
local data = sfd.read(onchip, 0x100, 256)
sfd.erase(onchip, 0x100)
sfd.write(onchip, 0x100, data or "Hi")
sfd.status(drv)#
检查spi flash状态
参数
传入值类型 |
解释 |
---|---|
userdata |
sfd.init返回的数据结构 |
返回值
返回值类型 |
解释 |
---|---|
int |
状态值, 0 未初始化成功,1初始化成功且空闲,2正忙 |
例子
local drv = sfd.init("spi", 0, 17)
if drv then
log.info("sfd", "status", sfd.status(drv))
end
sfd.read(drv, offset, len)#
读取数据
参数
传入值类型 |
解释 |
---|---|
userdata |
sfd.init返回的数据结构 |
int |
起始偏移量 |
int |
读取长度,当前限制在256以内 |
返回值
返回值类型 |
解释 |
---|---|
string |
数据 |
例子
local drv = sfd.init("spi", 0, 17)
if drv then
log.info("sfd", "read", sfd.read(drv, 0x100, 256))
end
sfd.write(drv, offset, data)#
写入数据
参数
传入值类型 |
解释 |
---|---|
userdata |
sfd.init返回的数据结构 |
int |
起始偏移量 |
string |
需要写入的数据,当前支持256字节及以下 |
返回值
返回值类型 |
解释 |
---|---|
boolean |
成功返回true,失败返回false |
例子
local drv = sfd.init("spi", 0, 17)
if drv then
log.info("sfd", "write", sfd.write(drv, 0x100, "hi,luatos"))
end
sfd.erase(drv, offset)#
擦除数据
参数
传入值类型 |
解释 |
---|---|
userdata |
sfd.init返回的数据结构 |
int |
起始偏移量 |
返回值
返回值类型 |
解释 |
---|---|
boolean |
成功返回true,失败返回false |
例子
local drv = sfd.init("spi", 0, 17)
if drv then
log.info("sfd", "write", sfd.erase(drv, 0x100))
end
sfd.id(drv)#
芯片唯一id
参数
传入值类型 |
解释 |
---|---|
userdata |
sfd.init返回的数据结构 |
返回值
返回值类型 |
解释 |
---|---|
string |
8字节(64bit)的芯片id |
例子
local drv = sfd.init("spi", 0, 17)
if drv then
log.info("sfd", "chip id", sfd.id(drv))
end