微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > NAND Flash的坏块管理设计

NAND Flash的坏块管理设计

时间:11-15 来源:互联网 点击:

摘要:主要介绍了基于嵌入式Linux的NAND Flash坏块管理设计和实现方案,详细阐述了坏块映射表的建立、维护及其相关算法,同时分析了此坏块算法在Linux内核及Bootloader中的具体应用。测试结果表明该算法能够处理NANDFlash的相关坏块问题,具有较高的稳定性。
关键词:NAND Flash;嵌入式IAnux;映射表;坏块管理

在拥有诸多优点的同时,NAND Flash由于生产工艺的问题,其在出厂时可能存在一定的坏块。这些固有坏块不能用于存储数据,已被产家标识好。另外,使用过程中由于读写次数增多,好块也会变得不稳定或失效,成为坏块,这就是出厂后产生的坏块。
NAND Flash在生产及使用过程中都有可能产生坏块,这将使得系统变得不稳定。应用中一般采用跳块策略来管理坏块,但它不能解决系统运行中产生的坏块情况。针对此情形,本文提出基于嵌入式Linux系统平台下的一种基于坏块映射的NAND Flash坏块管理的方案,并详细介绍其相关映射算法和整套系统的相关坏块管理流程。

1 坏块管理层次结构
Linux下的MTD(Memory Technology Device)是用于管理ROM、Flash等内存设备的一层子系统,它使编写管理内存设备驱动变得更加简单。
MTD子系统将Flash设备或其分区抽象为MTD设备,使底层驱动只需实现MTD设备,而向上层文件系统提供标准的接口,如MTD字符设备、MTD块设备。
如图1所示,本方案设计中,将坏块管理层(BBMlayer)紧靠在驱动层之上MTD层之下,从而使得MTD层对坏块不可见,并使坏块的管理是基于整个芯片而不是某个分区,便于上层文件系统实现损耗平衡。


BBM层基于驱动层提供的读、写、擦除相关操作实现接口read()、write()、erase()、read_oob()、write_oob()、isbad()、mark_bad()。对于其上层MTD子系统而言,关于坏块的相关接口将不存在,物理介质类似于NORFlash。其中read_oob()、write_oob()接口为文件系统提供相关用途,如JFFS2的cleanmarker相关载体。

2 坏块管理模块的设计实现
2.1 坏块管理原理
本文的设计的坏块管理是基于坏块映射原理的一种实现。在本坏块映射的设计中,NAND Flash被划分为基本空间和预留空间。基本空间为用户看到的NANDFlash的总的存储空间。基本空间中的坏块被映射到预留空间中的相应好块。基本映射关系如图2所示。映射管理信息记录在坏块映射表中,它存储在预留空间。


2.2 坏块映射表的描述
在预留空间存在4种形式的块:空闲的好块、坏块、被映射的块、存放映射表的块。
存放映射表的块较为特殊,其中映射表不仅描述基本空间中的坏块映射相关信息,还描述预留空间占整个Flash空间的比例等。
设计中一张坏块表存于一个Flash块,表的信息存于块中最前面的相关页中。表的头部长度固定,表的整个长度可变,与坏块数目相关。
坏块映射表结构描述如下:


其中hdr_crc和tbl_crc用于检验表的完整性;rese_start_blk即预留空间的起始块号;version用于标识该表的版本;num_bad_blk用于描述已发现的坏块数,即坏块映射表项的数目;map_tbl为记录坏块映射表项内容的首地址。任何一个映射表项包括坏块块号及其映射的好块的块号。
由于使用过程中会产生新的坏块,映射表中的表项需要增加,从而要更新Flash中的映射表。为了防止系统意外掉电产生映射表不一致问题,采用日志技术。其中version版本号标识映射表的新旧,在更新Flash映射表的同时,版本号递增,同时Flash旧版本映射表并不立即擦除。只有出现预留空间不足的情况,擦除旧版本映射表的动作才执行。此方案还有利于调试,查看映射表的更改历史记录。
在出现坏块Bn后,通常包括两个动作:写映射表和标识坏块。标识坏块是通过在块的00B相应字节写非0xFF来实现。
为了支持意外掉电情形,每个版本的映射表必须在Flash里保存两份,如果发现最高的版本映射表没有两份,或者两份不一致,则属于非正常情况,必须重新建立映射表。
考虑如下情况:写完映射表Vn,接着标识坏块Bn,此时掉电,则下次系统启动后,出现映射表的坏快Bn,实际上并没有被标识,导致不一致问题。写2份Vn可以解决此问题:写第一份Vn后,标识坏块Bn,接着再写第二份Vn。这样即使在标识坏块Bn时掉电,下次系统加电时由于没有发现2份版本相同且最高的映射表,从而识别出此非正常情况。
同时,维护2份同版本坏块表可以处理存放映射表的块突然坏死而导致系统无法启动的异常,起到备份的作用。
2.2.1 坏块映射表的管理算法
系统初始化时读入坏块表的内容,在内存中建立所有坏块的映射信息。由于每次发现新的坏块而更新坏块表时,都会写入两个版本一样的坏块表,所以在读入坏块表时就要检查两个表是否有效和一致,可以分为以下情况:
①发现2张最高版本并且有效的坏块表Vn+1——系统按表Vn+1建立映射;
②只发现1张最高版本并且有效的坏块表Vn+1,并且有2张有效坏块表Vn——发生在上次写完一个Vn+1后突然掉电,使得第二个表Vn+1未写入或写入不完整,这时需要恢复,以建立完整映射,恢复算法如图3所示。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top