0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

RT-Thread文件系统的基本知识和使用方法

lPCU_elecfans 来源:未知 作者:李倩 2018-08-17 10:01 次阅读

本应用笔记介绍了 RT-Thread 文件系统的基本知识和使用方法,帮助开发者更好地使用 RT-Thread 文件系统。并给出了在正点原子STM32F429-apollo开发板上验证的代码示例。

本文的目的和结构

本文的目的和背景

第一次接触 RT-Thread 文件系统的开发者可能觉得 RT-Thread 文件系统过于复杂,不知道该从何入手。想要在项目中使用文件系统,却不知道该怎么做。产生这种印象的原因是对 RT-Thread DFS 框架没有足够的了解,如果理解了 DFS 框架,在使用 RT-Thread 文件系统时就可以得心应手了。

为了能让开发者清楚地理解 RT-Thread DFS 框架的概念,学会使用 RT-Thread 文件系统。本应用笔记将一步步深入介绍 RT-Thread DFS 框架的相关知识以及实现原理。通过演示 shell 命令和使用示例的方式来操作文件系统,让开发者能够学会 RT-Thread 文件系统的使用方法。

本文的结构

本应用笔记将从以下三个方面来介绍 RT-Thread 文件系统:

RT-Thread DFS 框架

RT-Thread 文件系统的移植

RT-Thread 文件系统的使用

问题阐述

本应用笔记将围绕下面几个问题来介绍RT-Thread 文件系统。

如何移植各种类型的文件系统?

如何对文件系统进行操作?

如何在文件系统中对文件和文件夹进行操作?

想要解决这些问题,就要了解 RT-Thread DFS 框架。下面我们就通过 DFS 框架一步一步地将文件系统使用起来。

问题的解决

DFS 框架介绍

RT-Thread 的文件系统采用了三层结构,这种结构就是 RT-Thread DFS 框架。

下图为RT-Thread 文件系统结构图:

DFS 框架的最顶层是一套面向嵌入式系统,专门优化过的设备虚拟文件系统 POSIX 文件接口,中间层是各种文件系统的实现,最底层是各类存储设备驱动。

DFS 框架的来源

RT-Thread 为了能够支持各种文件系统,设计了这样一个 DFS 框架,各个层次独立实现,提高了操作系统的可扩展性。使用 DFS 框架可以使得各种文件系统经过简单的修改即可匹配到这个框架上,降低了文件系统移植难度,让 开发者有更多的文件系统类型可供选择。

DFS 框架各层次说明

顶层:POSIX 文件接口层

这一层是给开发者使用的接口函数层,开发者使用这一层提供的POSIX文件接口进行文件的相关操作,不用关心文件系统是如何实现的,也不用关心数据是存放在哪个存储器中。

中间层:文件系统实现层

中间层是各种具体文件系统的实现,这里所说文件系统指各种不同类型的文件系统,比如ELM FatFS、RomFS、devfs、Yaffs2、Uffs2等。需要知道的是,不同的文件系统类型是独立于存储设备驱动而实现的。因此,想要正确地使用这些文件系统,需要把底层存储设备的驱动接口和文件系统对接起来。

底层:存储设备驱动层

这一层是存储设备驱动层,具体的功能是初始化存储设备并向上层提供存储设备的驱动接口。存储设备的类型可能是SPI Flash,SD卡等。

文件系统的移植

本次演示使用正点原子开发板STM32F429-Apollo,选择的文件系统类型是 elm FatFS。由于 RT-Thread 自带了这个文件系统,所以移植工作较为简单,只需要通过 env 工具对系统进行合适的配置既可。其他 RT-Thread 支持的文件系统,移植过程也是类似的,只需要对系统进行合适的配置即可使用。

准备工程

下载 RT-Thread 源码 。

env 工具

移植过程介绍

文件系统的移植主要包括下面几个方面:

开启/配置 DFS 框架

开启/配置 指定的文件系统

确保开发板上的存储设备驱动正常工作

通过 env 工具可以方便地开启文件系统,将所需的文件系统类型添加到工程中。

对存储设备进行功能测试,可以确保存储设备驱动是正常工作的。驱动程序的稳定工作是文件系统正常使用的基础。

文件系统的配置

使用 env 工具进入rt-threadspstm32f429-apollo目录,在命令行中输入menuconfig命令进入配置界面。

在menuconfig配置界面依次选择RT-Thread Components → Device virtual file system,如下图所示:

下面介绍 DFS 的配置项:

Using device virtual file system : 使用设备虚拟文件系统,即 RT-Thread 文件系统。

Using working directory : 打开这个选项,在finsh/msh中就可以使用基于当前工作目录的相对路径。

The maximal number of mounted file system : 最大挂载文件系统的数量。

The maximal number of file system type : 最大支持文件系统类型的数量。

The maximal number of opened files : 打开文件的最大数量。

Enable elm-chan fatfs : 使用 elm-chan FatFs。

elm-chan’s FatFs, Generic FAT Filesystem Module : elm-chan 文件系统的配置项。

Using devfs for device objects : 开启 devfs 文件系统。

Enable BSD socket operated by file system API : 使 BSD socket 可以使用文件系统的 API 来管理,比如读写操作和 select/poll 的 POSIX API 调用。

Enable ReadOnly file system on flash : 在 Flash 上使用只读文件系统。

Enable RAM file system : 使用 RAM 文件系统。

Enable UFFS file system: Ultra-low-cost Flash File System :使用 UFFS。

Enable JFFS2 file system : 使用 JFFS2 文件系统。

Using NFS v3 client file system :使用 NFS 文件系统。

进入到 DFS 的配置界面,开启下图所示的选项,就可以将FatFS添加到系统中。如图所示:

这里需要注意的是还需要进入到elm-chan's FatFs, Generic FAT Filesystem Module选项中修改关于长文件名支持的选项,否则在后面使用文件系统的过程中,创建的文件或者文件夹的名称不能超过 8 个字符。修改方式如下图所示:

因为要使用一些 C 库函数,所以需要打开libc功能:

保存选项后即可退出,此时elm FatFS已经添加到项目中 。

存储设备初始化

开启 SPI 设备驱动

DFS 框架的文件系统实现层需要存储设备驱动层提供驱动接口用于对接,本次使用的存储设备为SPI Flash,底层设备初始化过程可以参考 《SPI 设备应用笔记》 。

重新打开 menuconfig 配置界面,在RT-Thread Components → Device Drivers界面中选中Using SPI Bus/Device device drivers以及Using Serial Flash Universal Driver选项,如下图所示:

为了方便地使用 shell 命令,我们在RT-Thread Components → Command shell选项中开启Using module shell选项,如下图所示:

保存选项并退出,在 env 中输入命令scons --target=mdk5 -s生成 mdk5 工程,编译并下载程序。

检查存储设备驱动

在 stm32f429-apollo 开发板上SPI Flash挂在了 SPI5 总线上,对应的SPI Device的设备名为spi50。在终端输入list_device命令可以看到名为spi50的设备类型为SPI Device,就说明 SPI 设备添加成功。如果没有出现相应的设备,则需要检查驱动程序,查找错误。

为了确保该驱动工作正常,可以使用sf命令对该设备做benchmark测试。该功能由sfud组件提供,可以通过检查存储设备的读、写和擦除功能来判断存储设备的驱动程序是否正常。 如果像下图一样提示成功,所示则认为该驱动工作正常。如果无法通过测试,则需要检查驱动程序,使用逻辑分析仪对存储设备的接口波形进行分析。测试过程如下图:

创建存储设备

由于只有块设备类型的设备才能和文件系统对接,所以需要根据SPI Device找到SPI Flash设备,并创建与其对应的Block Device。

这里需要使用到万能 SPI Flash 驱动库:SFUD ,RT-Thread 已经集成了该组件,在上面的配置过程中我们已经开启这个功能。此时只需要使用 SFUD 提供的rt_sfud_flash_probe函数即可。该函数将执行如下操作:

根据名为spi50的SPI Device设备找到对应的Flash存储设备。

初始化Flash设备。

在 Flash 存储设备上创建名为W25Q256的 Block Device。

如果开启了组件自动初始化功能,该函数会被自动执行,否则需要手动调用运行。

static int rt_hw_spi_flash_with_sfud_init(void) { if (RT_NULL == rt_sfud_flash_probe("W25Q256", "spi50")) { return RT_ERROR; }; return RT_EOK; } INIT_COMPONENT_EXPORT(rt_hw_spi_flash_with_sfud_init)

在终端输入list_device命令如果看到名为W25Q256的设备类型为Block Device,这说明块设备已经创建成功,如果失败则需要对spi50设备进行检查。

如下图所示:

获得可以用于挂载的块类型设备,那么移植的工作就算完成了。

文件系统的使用

文件系统的初始化

RT-Thread 文件系统初始化过程一般按以下流程来进行:

初始化 DFS 框架

初始化具体文件系统

初始化存储设备

下面我们按照这样的顺序来逐步讲解文件系统的初始化过程:

DFS 框架的初始化

DFS 框架的初始化主要是对内部数据结构以及资源的初始化。这一过程包括初始化文件系统必须的数据表,以及互斥锁。该功能由如下函数完成。如果开启了组件自动初始化功能,该函数会被自动执行,否则需要手动调用运行。

中间层文件系统的初始化

这一步的初始化主要是将elm FatFS的操作函数注册到 DFS 框架中。该功能由如下函数完成。如果开启了组件自动初始化功能,该函数会被自动执行,否则需要手动调用运行。

存储设备的初始化

存储设备的初始化可以参考 《创建存储设备》章节。

创建文件系统

第一次使用SPI Flash作为文件系统地存储设备时,如果我们直接重启开发板来挂载文件系统,就会看到spi flash mount to /spi failed!的提示。这是因为此时在 SPI Flash 中还没有创建相应类型的文件系统,这就用到了创建文件系统 shell 命令:mkfs。

mkfs命令的功能是在指定的存储设备上创建指定类型的文件系统。使用格式为:mkfs [-t type] device。第一次挂载文件系统前需要使用mkfs命令在存储设备上创建相应的文件系统,否则就会挂载失败。如果要在W25Q256设备上创建elm类型的文件系统,就可以使用mkfs -t elm W25Q256命令,使用方法如下图:

文件系统创建完成后需要重启设备。

文件系统的挂载

文件系统的挂载指的是将文件系统和具体的存储设备关联起来,并挂载到某个挂载点,这个挂载点即为这个文件系统的根目录。在下面的示例中,我们将elm FatFS文件系统和名为W25Q256的存储设备关联起来,并且挂载到/spi文件夹中。(这里可以挂载到/spi文件夹的原因是stm32f429-apollo BSP的文件系统根目录已经挂载了RomFS,并且已经创建了/spi文件夹。如果没有特殊情况,文件系统可以直接挂载到根目录/上。)

挂载文件系统的操作由dfs_mount()函数完成,dfs_mount()函数的参数分别为:块设备名、文件系统挂载点路径、挂载文件系统类型、读写标志位以及文件系统的私有数据,使用方法如下图所示:

经过了上面的创建文件系统操作,我们重启开发板(会自动重新执行挂载函数),就可以成功地挂载文件系统了。可以看到提示spi flash mount to /spi !。这时再次使用list_device命令可以看到W25Q256设备已经被挂载成功。如下图所示:

到这一步为止,文件系统已经初始化完成,接下来可以对文件和目录进行操作了。

文件与目录操作 shell 命令

在这一小节介绍关于文件和目录操作常用的 shell 命令:

ls功能:显示文件和目录的信息,示例如下图:

cd功能:切换到指定工作目录,示例如下图:

cp功能:copy 文件,示例如下图:

rm功能:删除文件或目录,示例如下图:

mv功能:将文件移动位置或者改名,示例如下图:

echo功能:将指定内容写入文件:

cat功能:展示文件的内容,示例如下图:

pwd功能:打印出当前目录地址,示例如下图:

mkdir功能:创建文件夹,示例如下图:

文件操作示例

本节以创建文件夹操作为例,介绍如何使用 RT-Thread 文件系统 Sample 来对文件系统进行操作。

在menuconfig配置界面依次选择RT-Thread online packages → miscellaneous packages → filesystem sample options,选中 [filesystem] mkdir选项,如下图所示:

保存并退出后,使用pkgs --update命令更新软件包,然后使用scons --target=mdk5 -s命令重新生成工程。可以看到该 Sample 已经添加到工程中:

这里需要注意的是由于我们文件系统的根目录挂载了RomFS,不可修改,所以我们不能直接在根目录创建文件夹。因此,我们需要对程序进行简单的修改,如下图所示:

重新编译后下载运行,在 msh 中可以使用mkdir_sample_init命令来创建 web 文件夹,效果如下图所示:

此时切换到/spi文件夹中可以看到 web 文件夹已经被创建。

文件系统提供的 Sample 还有openfile、readwrite、stat、rename、opendir、readdir、tell_seek_dir,大家可以用上面的方法来使用这些功能。

常见问题

(1)发现文件名或者文件夹名称显示不正常怎么办?

检查是否开启了长文件名支持,可以参考本应用笔记《文件系统的配置》章节。

(2)文件系统初始化失败怎么办?

检查文件系统配置项目中的允许挂载的文件系统类型和数量是否充足。

(3)创建文件系统mkfs命令失败怎么办?

检查存储设备是否存在,如果存在检查设备驱动是否可以通过功能测试,如果不能通过,则检查驱动错误。

检查 libc 功能是否开启,参见 《文件系统的配置》章节。

(4)文件系统挂载失败怎么办?

检查指定的挂载路径是否存在。文件系统可以直接挂载到根目录(“/”),但是如果想要挂载到其他路径上,如 (“/sdcard”)。需要确保(“/sdcard”)路径是存在的,否则需要先在根目录创建sdcard文件夹才能挂载成功。

检查是否在存储设备上创建了文件系统,如果存储设备上没有文件系统,需要使用mkfs命令在存储器上创建文件系统。

(5)SFUD 探测不到 Flash 所使用的具体型号怎么办?

检查硬件引脚设置错误

SPI 设备是否已经注册

SPI 设备是否已经挂载到总线

检查在RT-Thread Components → Device Drivers -> Using SPI Bus/Device device drivers -> Using Serial Flash Universal Driver菜单下的Using auto probe flash JEDEC SFDP parameter和Using defined supported flash chip information table配置项是否选中,如果没有选中那么需要开启这两个选项。配置图可参考 《开启 SPI 设备驱动》 章节。

如果开启了上面的选项仍然无法识别存储设备,那么可以在 SFUD 项目中提出 issues。

(6)elm FatFS 的最大扇区大小该如何设置?

根据所使用的存储设备的不同,也会有些不一样,一般根据 Flash 设备的要求可以设置为 4K,也就是填写 4096。

一般常见的 TF 卡和 SD 卡的扇区大小设置为 512。

(7)存储设备的benchmark测试耗时过长是怎么回事?

可对比system tick为 1000 时的 benchmark 测试数据 和本次测试所需的时长,如果耗时差距过大,则可以认为测试工作运行不正常。

检查系统 tick 的设置,因为一些延时操作会根据 tick 时间来决定,所以需要根据系统情况来设置合适的system tick值。如果系统的system tick值不低于 1000,则需要使用逻辑分析仪检查波形确定通信速率正常。

(8)SPI Flash 实现 elmfat 文件系统,如何保留部分扇区不被文件系统使用?

可以使用 RT-Thread 提供的 partition 工具软件包为整个存储设备创建多个块设备,为创建的多个块设备分配不同的功能即可。

(9)测试文件系统过程中程序卡住了怎么办?

尝试使用调试器或者打印一些必要的调试信息,确定程序卡住的位置再提出问题。

(10)如何一步步检查文件系统出现的问题?

可以采用从底层到上层的方法来逐步排查问题。

首先检查存储设备是否注册成功,功能是否正常。

检查存储设备中是否创建了文件系统。

检查指定文件系统类型是否注册到 DFS 框架,经常要检查允许的文件系统类型和数量是否足够。

检查 DFS 是否初始化成功,这一步的初始化操作是纯软件的,因此出错的可能性不高。需要注意的是如果开启了组件自动初始化,就无需再次手动初始化。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 文件系统
    +关注

    关注

    0

    文章

    284

    浏览量

    19904
  • RTOS
    +关注

    关注

    22

    文章

    811

    浏览量

    119597
  • RT-Thread
    +关注

    关注

    31

    文章

    1285

    浏览量

    40091
  • 物联网操作系统

    关注

    3

    文章

    114

    浏览量

    13354
  • 嵌入式实时操作系统

    关注

    1

    文章

    127

    浏览量

    7838

原文标题:10分钟学会文件系统的基本知识和使用方法——周四RTOS专栏

文章出处:【微信号:elecfans,微信公众号:电子发烧友网】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    RT-Thread上CAN实践

    开箱测试RT-Thread官方已完成了对英飞凌XMC7200EVK的移植,通过shell可以看到做好了uart3的console。本文将介绍如何进行RT-ThreadCan移植。接下来我们要完成CAN_FD的驱动移植,并正常启动RT-T
    的头像 发表于 11-13 01:03 1148次阅读
    <b class='flag-5'>RT-Thread</b>上CAN实践

    stm32单片机基于rt-thread 的 littlefs 文件系统 的使用

    简介littlefs是ARM官方推出的,专为嵌入式系统设计的文件系统,相比传统的文件系统,littlefs具有以下优点:1、自带擦写均衡2、支持掉电保护3、占用的
    的头像 发表于 11-06 08:04 633次阅读
    stm32单片机基于<b class='flag-5'>rt-thread</b> 的 littlefs <b class='flag-5'>文件系统</b> 的使用

    2024 RT-Thread全球巡回 线下培训火热来袭!

    亲爱的RT-Thread社区成员们:我们非常高兴地宣布,2024年RT-Thread全球开发者线下培训即将拉开帷幕!24年全球巡回培训将覆盖超10座城市及国家,为开发者提供一个深入学习RT-Thread嵌入式开发的绝佳机会。
    的头像 发表于 08-07 08:35 1181次阅读
    2024 <b class='flag-5'>RT-Thread</b>全球巡回 线下培训火热来袭!

    怎样修改LVGL的lv_port_fs文件,让它使用rt-thread的DFS文件系统中的API函数读取SD卡中的图片?

    我想问一下,怎样修改LVGL的lv_port_fs文件,可以让它使用rt-thread的DFS文件系统中的API函数(这些API函数在rt-thread的dfs_posix.c中)读取
    发表于 07-11 06:53

    RT-Thread 新里程碑达成——GitHub Star 破万!

    RT-Thread实时操作系统开源项目在GitHub上的star数量突破一万!截止发文,RT-Thread作为实时操作系统在业界Star数量排名第一!仓库地址:https://gith
    的头像 发表于 07-04 08:35 472次阅读
    <b class='flag-5'>RT-Thread</b> 新里程碑达成——GitHub Star 破万!

    6月6日杭州站RT-Thread线下workshop,探索RT-Thread混合部署新模式!

    嵌入式软件工程师郭占鑫老师为您讲解有关威廉希尔官方网站 知识和实践经验。通过本次workshop能深入理解RT-Thread专业版与混合部署的潜力,在RK3568平台上提升系统实时
    的头像 发表于 05-28 08:35 442次阅读
    6月6日杭州站<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    新书发布——《实时操作系统应用威廉希尔官方网站 :RT-Thread与ARM编程实践》

    RT-Thread又一本新书《实时操作系统应用威廉希尔官方网站 ——基于RT-Thread与ARM的编程实践》发布,标志着RT-Thread生态和实时操作系统
    的头像 发表于 05-11 08:35 793次阅读
    新书发布——《实时操作<b class='flag-5'>系统</b>应用威廉希尔官方网站
:<b class='flag-5'>RT-Thread</b>与ARM编程实践》

    5月16日南京站RT-Thread线下workshop,探索RT-Thread混合部署新模式!

    嵌入式软件工程师郭占鑫老师为您讲解有关威廉希尔官方网站 知识和实践经验。通过本次workshop能深入理解RT-Thread专业版与混合部署的潜力,在RK3568平台上提升系统
    的头像 发表于 05-01 08:35 360次阅读
    5月16日南京站<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    RT-Thread混合部署Workshop北京站来啦!

    嵌入式软件工程师郭占鑫老师为您讲解有关威廉希尔官方网站 知识和实践经验。通过本次workshop能深入理解RT-Thread专业版与混合部署的潜力,在RK3568平台上提升系统
    的头像 发表于 04-19 08:34 437次阅读
    <b class='flag-5'>RT-Thread</b>混合部署Workshop北京站来啦!

    4月25日北京站RT-Thread线下workshop,探索RT-Thread混合部署新模式

    嵌入式软件工程师郭占鑫老师为您讲解有关威廉希尔官方网站 知识和实践经验。通过本次workshop能深入理解RT-Thread专业版与混合部署的潜力,在RK3568平台上提升系统
    的头像 发表于 04-16 08:35 417次阅读
    4月25日北京站<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式

    【4月10日-深圳-workshop】RT-Thread带你探索混合部署新模式

    嵌入式软件工程师农晓明老师为您讲解有关威廉希尔官方网站 知识和实践经验。通过本次workshop能深入理解RT-Thread专业版与混合部署的潜力,在RK3568平台上提升系统
    的头像 发表于 04-04 08:34 337次阅读
    【4月10日-深圳-workshop】<b class='flag-5'>RT-Thread</b>带你探索混合部署新模式

    4月10日深圳场RT-Thread线下workshop,探索RT-Thread混合部署新模式!

    4月10日我们将在深圳福田举办RT-Thread混合部署线下workshop,在瑞芯微RK3568平台上实现同时运行RT-Thread和linux,本次workshop邀请到RT-Thread资深嵌入式软件工程师农晓明老师为您讲
    的头像 发表于 03-27 11:36 816次阅读
    4月10日深圳场<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    4月10日深圳场RT-Thread线下workshop,探索RT-Thread混合部署新模式!

    嵌入式软件工程师农晓明老师为您讲解有关威廉希尔官方网站 知识和实践经验。通过本次workshop能深入理解RT-Thread专业版与混合部署的潜力,在RK3568平台上提升系统
    的头像 发表于 03-27 08:34 527次阅读
    4月10日深圳场<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    RT-Thread设备驱动开发指南》基础篇--以先楫bsp的hwtimer设备为例

    一、概述(一)RT-Thread设备驱动《RT-Thread设备驱动开发指南》书籍是RT-thread官方出品撰写,系统讲解RT-threa
    的头像 发表于 02-24 08:16 1636次阅读
    《<b class='flag-5'>RT-Thread</b>设备驱动开发指南》基础篇--以先楫bsp的hwtimer设备为例

    RT-Thread设备驱动开发指南基础篇—以先楫bsp的hwtimer设备为例

    RT-Thread设备驱动开发指南》书籍是RT-thread官方出品撰写,系统讲解RT-thread IO设备驱动开发方法,从三方面进行讲解
    的头像 发表于 02-20 16:01 1686次阅读
    <b class='flag-5'>RT-Thread</b>设备驱动开发指南基础篇—以先楫bsp的hwtimer设备为例