fatfs - 读写fatfs格式#

示例

-- 通常只使用fatfs.mount挂载tf/sd卡,其他操作走io库就可以了

fatfs.mount(mode,mount_point, spiid_or_spidevice, spi_cs, spi_speed, power_pin, power_on_delay, auto_format)#

挂载fatfs

参数

传入值类型

解释

int

fatfs模式,可选fatfs.SPI,fatfs.SDIO,fatfs.RAM,fatfs.USB

string

虚拟文件系统的挂载点, 默认是 /fatfs

int

传入spi device指针,或者spi的id,或者sdio的id

int

片选脚的GPIO 号, spi模式有效,若前一个参数传的是spi device,这个参数就不需要传

int

SPI最高速度,默认10M, 若前2个参数传的是spi device,这个参数就不需要传

int

TF卡电源控制脚,TF卡初始前先拉低复位再拉高,如果没有,或者是内置电源控制方式,这个参数就不需要传

int

TF卡电源复位过程时间,单位ms,默认值是1

bool

挂载失败是否尝试格式化,默认是true,即自动格式化. 本参数在2023.8.16添加

返回值

返回值类型

解释

bool

成功返回true, 否则返回nil或者false

string

失败的原因

例子

-- 方法1, 使用SPI模式
    local spiId = 2
    local result = spi.setup(
        spiId,--串口id
        255, -- 不使用默认CS脚
        0,--CPHA
        0,--CPOL
        8,--数据宽度
        400*1000  -- 初始化时使用较低的频率
    )
    local TF_CS = pin.PB3
    gpio.setup(TF_CS, 1)
    --fatfs.debug(1) -- 若挂载失败,可以尝试打开调试信息,查找原因
    -- 提醒, 若TF/SD模块带电平转换, 通常不支持10M以上的波特率!!
    fatfs.mount(fatfs.SPI,"SD", spiId, TF_CS, 24000000)
    local data, err = fatfs.getfree("SD")
    if data then
        log.info("fatfs", "getfree", json.encode(data))
    else
        log.info("fatfs", "err", err)
    end
    -- 往下的操作, 使用 io.open("/sd/xxx", "w+") 等io库的API就可以了

fatfs.unmount(mount_point)#

取消挂载fatfs

参数

传入值类型

解释

string

虚拟文件系统的挂载点, 默认是 fatfs,必须与fatfs.mount一致

返回值

返回值类型

解释

int

成功返回0, 否则返回失败码

例子

fatfs.mount("SD")

fatfs.getfree(mount_point)#

获取可用空间信息

参数

传入值类型

解释

string

挂载点, 需要跟fatfs.mount传入的值一致

返回值

返回值类型

解释

table

若成功会返回table,否则返回nil

int

导致失败的底层返回值

例子

-- table包含的内容有
-- total_sectors 总扇区数量
-- free_sectors 空闲扇区数量
-- total_kb 总字节数,单位kb
-- free_kb 空闲字节数, 单位kb
-- 注意,当前扇区大小固定在512字节

    local data, err = fatfs.getfree("SD")
    if data then
        log.info("fatfs", "getfree", json.encode(data))
    else
        log.info("fatfs", "err", err)
    end

fatfs.debug(value)#

设置调试模式

参数

传入值类型

解释

bool

是否进入调试模式,true代表进入调试模式,增加调试日志

返回值

返回值类型

解释

nil

无返回值

例子