文件系统分析报告.docVIP

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
JFFS2文件系统分析报告 本文在深入研究jffs2源代码基础上,对JFFS2文件系统的实现机制进行了分析,包括关键的数据结构及其之间的联系,文件系统的注册和挂载,以及其他主要的操作流程。 1 JFFS2层次结构 在Linux系统中,JFFS2文件系统处于虚拟文件系统层VFS与存储技术设备层MTD之间,如图1所示。VFS为内核中的各种文件系统提供一个统一的抽象层,并为上层用户提供具有统一格式的接口函数;MTD子系统整合底层芯片驱动,为上层文件系统提供了统一访问MTD设备(主要是NOR闪存和NAND闪存等设备)的接口。JFFS2在内存中建立超级块信息jffs2_sb_info管理文件系统操作,建立索引节点信息jffs2_inode_info管理打开的文件。VFS层的超级块super_block和索引节点inode分别包含JFFS2文件系统的超级块信息jffs2_sb_info和索引节点信息jffs2_inode_info,它们是JFFS2和VFS间通信的主要接口。JFFS2文件系统的超级块信息jffs2_sb_info包含底层MTD设备信息mtd_info指针,文件系统通过该指针访问MTD设备,实现JFFS2和底层MTD设备驱动之间的通信。 图1 JFFS2文件系统层次 2 JFFS2数据实体 JFFS2在Flash上只存储两种类型的数据实体,分别为jffs2_raw_inode和jffs2_raw_ dirent。 jffs2_raw_dirent:包括文件名、ino号、父节点ino号、版本号、校验码等信息,它用来形成整个文件系统的层次目录结构。 jffs2_raw_inode:包括文件ino号、版本号、访问权限、修改时间、本节点所包含的数据文件中的起始位置及本节点所包含的数据大小等信息,它用来管理文件的所有数据。 一个目录文件由多个jffs2_raw_dirent组成。而普通文件,符号链接文件,设备文件,FIFO文件等都由一个或多个jffs2_raw_inode数据实体组成。图2表示了一个Flash中数据实体的逻辑分布,物理上所有的数据实体是离散分布的,其位置由写入时Flash空闲空间位置决定的。 图2 Flash空间上的数据实体 JFFS2文件系统在挂载时扫描整个Flash,每个jffs2_raw_inode数据实体都会记录其所属的文件的inode号及其他元数据,以及数据实体中存储的数据的长度及在文件内部的偏移。而jffs2_raw_dirent数据实体中存有目录项对应的文件的inode号及目录项所在的目录的inode号等信息。JFFS2在扫描时根据jffs2_raw_dirent数据实体中的信息在内存中建立文件系统的目录树信息,类似的,根据jffs2_raw_inode数据实体中的信息建立起文件数据的寻址信息。为了提高文件数据的寻址效率,JFFS2将属于同一个文件的jffs2_raw_inode数据实体组织为一颗红黑树,在挂载扫描过程中检测到的每一个有效的jffs2_raw_inode都会被添加到所属文件的红黑树。在文件数据被更新的情况下,被更新的旧数据所在的jffs2_raw_inode数据实体会被标记为无效,同时从文件的红黑树中删除。然后将新的数据组织为jffs2_raw_inode数据实体写入Flash并将新的数据实体加入红黑树。 3 JFFS2逻辑结构 与磁盘文件系统不同,JFFS2文件系统不在Flash设备上存储文件系统结构信息,所有的信息都分散在各个数据实体节点之中,在系统初始化的时候,扫描整个Flash设备,从中建立起文件系统在内存中的映像,系统在运行期间,就利用这些内存中的信息进行各种文件操作。JFFS2为每一个Flash设备维护一个超级块结构jffs2_sb_info,这个结构含有整个Flash设备的信息。通过这个数据结构,系统维护了几个重要的链表,这几个链表构成了整个文件系统的骨架。 3.1 擦除块信息链表 在jffs2_sb_info中维护着多个擦除块链表,如表1所示,链表中每一个节点包含一个擦除块。 表1 擦除块信息链表 链表 链表中擦除块的性质 clean_list 只包含有效数据结点 very_dirty_list 所含数据结点大部分都已过时 dirty_list 至少含有一个过时数据结点 erasable_list 所有的数据结点都过时需要擦除。但尚未“调度”到erase_pending_list erasable_pending_wbuf_list 同erase_pending_list,但擦除必须等待wbuf冲刷后 erasing_list 当前正在擦除 erase_pending_list 当前正等待擦除 erase_complete_list 擦除已完成,但尚未写入CL

文档评论(0)

118books + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档