加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

NAND flash坏块管理

发布时间:2020-12-15 20:01:12 所属栏目:百科 来源:网络整理
导读:? 在Flash的每一个Page中都会有一个区域叫OOB,其实就是Spare area,用来放ECC校验值。 ? OOB用途就是标记坏块,存储ECC之,还有一些文件系统的东西。 坏块有两类: ? ? ? ?(1)固有坏块,生产时产生的。一般芯片厂会在出厂时将每个坏块的第一个Page的spare ar
? 在Flash的每一个Page中都会有一个区域叫OOB,其实就是Spare area,用来放ECC校验值。
? OOB用途就是标记坏块,存储ECC之,还有一些文件系统的东西。
坏块有两类:

? ? ? ?(1)固有坏块,生产时产生的。一般芯片厂会在出厂时将每个坏块的第一个Page的spare area的第6个byte标记为不等于0xff的值?

? ? ? (2)使用坏块。这是在NAND flash使用中,Block erase或者Page program错误,就可以简单的将这个快作为坏块来处理,将新发现的坏块的第一个page的spare area的第6个Byte标记为非0xff的值。

坏块管理

? ? ?在擦除一个块之前,一定要先check一下第一页的spare area的第6个byte是否是0xff,如果是就证明这是一个好快,可以擦除,如果是非0xff,那么就不能擦除,以免将坏块标记擦掉。

? ? ? ? 可以用BBT:bad block table,即坏块表来进行管理。各家厂商有不同的方式。比如专门用nand做存储的,会把bbt放到block0,因为第0块一定是好的块,但是如果nand本身被用来做boot,那么第0块就要存放程序,不能放BBT了。有的把BBT放到最后一块。BBT大小和nand大小有关,随之增大.


NOTICE:为什么要选择0xff来标记?因为NAND Flash的擦除就是将相应块的位全部变为1,写操作时只能把芯片的每一位(bit)只能从1变为0,而不能从0变为1,0xFF这个值就是表示擦除成功是好块。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读