不管WL算法如何高明,在使用中都会碰到一个头痛的问题,那就是坏块,所以一个SSD必须要有坏块管理机制。何谓坏块?一个闪存块里包含有不稳定的地址,不能保证读/写/擦时数据的准确性。

       坏块分出厂坏块和使用过程中出现的坏块,SSD有坏块表来管理坏块。出厂坏块在上面会有标记,所以很容易就能被识别,而使用中出现的坏块就要靠主控的能力了。一般来说,越到闪存生命的后期(P/E数开始接近理论最大值),坏块就会开始大量出现。

一般来说闪存出厂都包含坏块,不过厂商有个最小有效块值(NvB-minimum number of valid blocks),以Intel的34nm MLC L63B来说,1个die(裸晶,详细解释见备注)上4,096个块里至少要有3,936个块是好的。从这上面可以知道,虽然出厂的闪存可能有坏块,但是厂商保证在正常的生命周期里,好块数量不会低于3936个块。而且每个die的第一个块地址(00h)在出厂时是必须保证完好的。(ECC后,这个块必须有效,ECC相关知识后面会有介绍)。闪存出厂前都会被执行擦除操作,厂商会在出货前会把坏块标记出来(厂商会在坏块的第一个页的SA区打上标记,SA区知识将在后面ECC部分介绍)这样坏块管理软件就能靠监测SA区标记来制作坏块表。由于在使用中会产生坏块,所以SSD的主控在每次写入/擦除/复制等操作后都要检查块的状态。对颗粒的ECC要求也要达到厂商的标准以上(主控强不强,看ECC能力也是一个参考)。坏块管理算法是必须的,坏块并不会影响好块的性能。

坏块的标记和管理: 刚出厂的颗粒内部已经被完全擦除过(全盘区块数据为FFh),坏块在出厂时也被标记上了。以MLC来说,颗粒内任何块里最后页的SA区首个字节数据非FFh的话,那就是坏块。

主控必须在每次擦除前读取一下坏块信息,因为坏块信息是可以被擦除的并且不能在擦除后恢复,所以建议不要去擦除原始的坏块信息。在读取闪存内所有的SA区域后,坏块表就被建立。纯靠自己的坏块识别方法而不使用原厂提供的SA区域坏块信息创建的坏块表是不严谨的做法,因为在原厂测试中,坏块可能是在某些特定环境下才会出现,所以有可能在自行的检测中被遗漏掉。

当坏块表创建后,主控会把坏块表保存在某个好的块里,每次重启后,主控会从那个块里把表调用进缓存(RAM)里。坏块表中定义的地址是不能被访问的,所以当系统想去访问这个块的地址时,FTL会重新把它映射到好的块地址上去。

块的替换: 在闪存的生命周期中,坏块会逐渐增多。闪存设备上有个状态寄存器,它的作用就是检测操作是否正确完成。当进行写入或擦除操作,状态寄存器检测到错误时,即可判定当前的块为坏块。

鉴于闪存的写入是以页为单位操作的,操作时可能影响到整个块里其它页的数据,所以当状态寄存器发现写入出现错误时,坏块管理程序就能够用好的块替换这个坏块,重新在新的好块里写入这个数据,并把检测到的坏块里其余的有效页数据全部复制到新的块里去,标记老的块为坏块,更新坏块表里的地址,把原本坏块的地址重新映射到新的好块里。(坏块管理流程见下图)

备注:Die在集成电路上的表现是一小堆可以实现特定功能的半导体材料。通常集成电路是从电子硅晶圆(EGS)或其它半导体材料(例如砷化镓)通过光刻工艺批量生产。晶圆被切割成许多小片,每一片包括一个完整的电路。这些小片就叫做Die。

转载地址:http://www.liangchanba.com/article-859-1.html

SSD 之BBM坏块管理机制相关推荐

  1. Nand Flash基础知识与坏块管理机制的研究

    概述 Flash名称的由来,Flash的擦除操作是以block块为单位的,与此相对应的是其他很多存储设备,是以bit位为最小读取/写入的单位,Flash是一次性地擦除整个块:在发送一个擦除命令后,一次 ...

  2. linux挂载fc存储有超级坏块_Nand Flash基础知识与坏块管理机制的研究

    欢迎FPGA工程师加入官方微信技术群 点击蓝字关注我们FPGA之家-中国最好最大的FPGA纯工程师社群 概述 Flash名称的由来,Flash的擦除操作是以block块为单位的,与此相对应的是其他很多 ...

  3. BBM(Bad Block Management)坏块管理

    不管WL算法如何高明,在使用中都会碰到一个头痛的问题,那就是坏块,所以一个SSD必须要有坏块管理机制.何谓坏块?一个闪存块里包含有不稳定的地址,不能保证读/写/擦时数据的准确性.        坏块分 ...

  4. 固态硬盘的坏块管理,你知道和不知道的

    坏块是如何产生的,SSD又是通过什么样的手段来发现和管理坏块,厂商建议的坏块管理策略存在什么样的问题,什么样的管理方法会更优,格式化硬盘会不对导致坏块表丢失,SSD返修后产生哪些安全隐患,本文逐一进行 ...

  5. linux 内核 mtd读取,MTD坏块管理(二)-内核获取Nandflash的参数过程

    MTD坏块管理机制中,起着核心作用的数据结构是nand_chip,在此以TCC8900-Linux中MTD的坏块管理为例作一次介绍. MTD在Linux内核中同样以模块的形式被启用,TCC_MTD_I ...

  6. nand flash 的oob 及坏块管理

    转载出处:http://blog.csdn.net/liukun321/article/details/6598921#comments 0.NAND的操作管理方式      NAND FLASH的管 ...

  7. linux nand 坏块_Linux内核中NAND Flash坏块管理

    由于NAND Flash的现有工艺不能保证NAND的Memory Array在其生命周期中保持性能的可靠,因此在NAND芯片出厂的时候,厂家只能保证block 0不是坏块,对于其它block,则均有可 ...

  8. 坏块管理(Bad Block Management,BBM)

    看了很多坏块管理的文章,加上自己的理解,把整个坏块管理做了个总结. 坏块分类 1.出厂坏块 又叫初始坏块,厂商会给点最小有效块值(NVB,mininum number of valid blocks) ...

  9. linux nand 坏块_linux内核中对nand的坏块管理

    闲来无事,追踪了下linux内核中对nand的坏块管理代码.大致记录一下. 内核中对nand的坏块管理是在nand的驱动中实现的,一般情况下,我们在实现nand控制器的驱动时不用考虑坏块的管理,这些机 ...

最新文章

  1. 北京/上海/深圳内推 | 百度视觉技术团队招聘视觉/3D算法工程师
  2. 【linux草鞋应用编程系列】_4_ 应用程序多线程
  3. 爱奇艺发布2018年Q2财报:总营收62亿元同比大增51%,会员收入达25亿元
  4. java批量执行查询sql语句_详解MyBatis直接执行SQL查询及数据批量插入
  5. Facebook哭晕在厕所,调查显示用VR体验社交的用户仅为19%
  6. 工作305:对选择的数值清空
  7. HAProxy杂记(1)
  8. 最良心的 chrome 插件可以良心到什么程度?
  9. javascript 获取控件坐标
  10. bugkuCTF解题记录——5、web基础$_POST
  11. 如何在 Mac 上下载 macOS Monterey public beta 6?
  12. Thinkphp3.2+ 微信小程序图片上传
  13. 基于ssm java jsp的酒店管理系统 前后台
  14. 碳足迹PCF国内外标准和碳标签应用
  15. 下载3GPP协议的方法
  16. 优秀的UI设计师应该了解的图标设计规范!
  17. 房贷没放款前千万不要做的事
  18. 计算机专业要学英语口语,学习英语口语必须掌握两大法宝
  19. 外贸收款——国际主流收款方式
  20. 【计算机网络】第三部分 数据链路层(13) 有线局域网:以太网

热门文章

  1. matlab怎么画x 1,matlab画出y=1 (x 1)的函数曲线
  2. 计算机快捷键及word的几个常用技巧
  3. 【框架】pinyin4j中文汉字转化为拼音
  4. 【移动安全基础篇】——30、class.dex文件格式讲解
  5. 基于Python和Java混合编程实现的小学生数学口算题卡定制练习题
  6. BZOJ2547 CTSC2002玩具兵(最短路径+二分答案+最大流)
  7. 一招教你批量查询并设置极兔快递参数
  8. iOS8 Core Image In Swift:人脸检测以及马赛克
  9. iOS Face++人脸识别SDK的使用
  10. 微服务(Microservices)——Martin Flower【翻译】