- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
YAFFS
YAFFS(Yet Another Flash File System)是第一个专门为NAND
Yet Another Flash File System
Flash 存储器设计的嵌入式文件系统,适用于大容量的存储设备;并
大容量
且是在GPL (General Public License )协议下发布的,可在其网站免
费获得源代码。
YAFFS 中,文件是以固定大小的数据块进行存储的,块的大小
数据块
可以是512 字节、1 024 字节或者2 048 字节。这种实现依赖于它能
够将一个数据块头和每个数据块关联起来。每个文件(包括目录)都
有一个数据块头与之相对应,数据块头中保存了ECC(Error Correction
有 数据块头 数据块头
Code)和文件系统的组织信息,用于错误检测和坏块处理。充分考虑
错误检测 坏块处理
了NAND Flash 的特点,YAFFS 把这个数据块头存储在Flash 的16
字节备用空间中。当文件系统被挂载时,只须扫描存储器的备用空间
就能将文件系统信息读入内存,并且驻留在内存中,不仅加快了文件
加快
系统的加载速度,也提高了文件的访问速度,但是增加了内存的消耗。
加载速度 提高 访问速度 增加了内存的消耗
为了在节省内存的同时提高文件数据块的查找速度,YAFFS 利
用更高效的映射结构把文件位置映射到物理位置。文件的数据段被组
高效 映射结构
织成树型结构,这个树型结构具有32 字节的节点,每个内部节点都
包括8 个指向其他节点的指针,叶节点包括 16 个2 字节的指向物理
地址的指针。YAFFS 在文件进行改写时总是先写入新的数据块,然
后将旧的数据块从文件中删除。这样即使在修改文件时意外掉电,丢
失的也只是这一次修改数据的最小写入单位,从而实现了掉电保护,
掉电保护
保证了数据完整性。
结合贪心算法的高效性和随机选择的平均性,YAFFS 实现了兼
贪心算法
顾损耗平均和减小系统开销的目的。当满足特定的小概率条件时,就
损耗平均
会尝试随机选择一个可回收的页面;而在其他情况下,则使用贪心算
法来回收最“脏”的块。
YAFFS 文件系统是按层次结构设计的,分成以下 4 部分:
yaffs_guts.c ,文件系统的主要算法,这部分代码完全是用可移植的C
语言编写的;yaffs_fs.c ,Linux VFS 层的接口;NAND 接口,yaffs_guts
和NAND 内存访问函数之间的包装层,例如调用Linux mtd 层或者
RAM 模拟层;可移植函数,服务的包装函数。最重要的一点是,为
了获得更好的移植性,YAFFS 提供直接调用的模式,这才使得我们
移植性
有机会来实现YAFFS 文件系统在C51 系统上的移植。
JFFS2
JFFS2 是JFFS 的后继者,由Red Hat 重新改写而成。JFFS2 的全
名为 (闪存日志型文件系统
第2 版),其功能就是管理在
文档评论(0)