报价
HOME
报价
正文内容
如何跳过NAND启动 新增NAND写入算法:跳过坏块并重建坏块表
发布时间 : 2024-10-06
作者 : 小编
访问数量 : 23
扫码分享至微信

新增NAND写入算法:跳过坏块并重建坏块表

宝剑锋从磨砺出,梅花香自苦寒来;

博观而约取,厚积而薄发。

有心的小伙伴可能在最新的软件版本里会看到,写入NAND时增加了一个新的算法:跳过坏块并重建坏块表

以海信5079板,MSD6A801芯片方案为例,先给大家演示RT809H写入NAND新算法。

先找一片坏块较多的Nand芯片,按方向放入RT809H编程器,锁好锁紧座。

点智能识别,选择NAND Falsh,稍等会自动识别到相同ID的芯片型号。

识别出两个芯片型号,选择跟芯片型号一致的K9K8G08U0D@TSOP48。

我们先点一下坏块检测,看看此芯片的坏块分布(坏块检测会破坏NAND芯片内数据,谨慎使用)。

检测到23个坏块,严格来说,基本算是残次品。

点设置,出现三个选项,硬拷贝;跳过坏块并重组数据;跳过坏块并重建坏块表。此板请选择“跳过坏块并重建坏块表 ”。

点写入,选择备份文件,开始自动写入。

可以看到界面上已经显示算法为“跳过坏块并重建坏块表”。

开始写入,耐心等待。。。

写入完成,接下来对写入后的NAND芯片进行验证,先把NAND芯片装回电视板卡。

连接上串口,同时监控打印信息。

通电,看到正常进入系统。同时监控显示画面,直到启动完成。

操作遥控,各项功能正常!

由于NAND使用领域的多样性和NAND自身的特殊性,坏块管理都不尽相同,就拿电视主板来说,我们通过大量板卡测试,和大量时间做了深入研究,发现不同的电视厂家,使用的坏块管理算法都不同,我们特此汇总了三种不同的算法,经过测试已经解决了目前在中国能够见到的电视主板NAND写入问题

NAND_AUTO读写芯片时,符合ONFI标准的芯片,读写成功率较高,比如海力士、镁光、ST、华邦等,而三星、东芝等厂商未加入此标准化组织,所以有可能参数识别错误导致读写后不能用,请提交NAND_AUTO读取得到的ID给我们,添加对应的芯片型号即可解决问题

国外用户如果遇到NAND读写问题,请提供好的板卡给我们测试。

没有哪种算法可以解决所有NAND复制问题,只能是遇到问题再研究新算法来解决问题。iFix爱修一直致力于为维修行业解决难题。

最近发现大家都在问一个比较实际的问题:RT809H以后会不会想其他编程器厂家一样,相同封装、不同型号的NAND芯片,使用不同的转接座?转接座的写入次数是多少?

这里是正式回答:RT809H编程器写入所有TSOP48封装的NAND芯片,只需要TSOP48通用座就可以了,永远不会限制写入次数!

视频演示,腾讯视频网址: https://v.qq.com/x/page/h0737szc7xu.html

学习课程已更新,欢迎大家进入学习。

入口:公众号首页-精选-案例直播;

目前课程观看已使用专属APP,

支持苹果、安卓手机以及电脑,

微信授权登录即可,

详见微信及QQ通知。

从Nand特性谈其烧录关键点

为什么烧录Nand Flash经常失败?为什么烧录成功了,一部分Nand芯片贴板之后系统却运行不起来?…,等等,问了那么多为什么,那我反问一个问题:你了解Nand Flash的特性及其烧录关键点吗?

一、Nand flash的特性

1、位翻转

在 NAND 闪存是通过对存储单元(Cell)进行充电来完成数据存储的,存储单元的阈值电压就对应着数据值。当读取的时候,通过将它的阈值电压与参考点对比来获得其数据值。对SLC 而言,就只有两种状态和一个参考点。而对于2-Bits 的MLC 而言,它有4 种状态和三个参考点。TLC就更多状态和参考点。当读出的数据值与编程时数据值对应的阈值电压不相匹配时,表明数据发生了位翻转,就带来了可靠性问题。导致位翻转的最常见原因是“编程干扰”导致的阈值电压漂移。

2、存储结构

Nand 闪存由多个Block组成,每一个Block又由多个Page组成,Page的大小一般为512+16Bytes 、2K+64Bytes以及4096+128Bytes,Page是读取和编程的基本单位,而擦除的基本单位是Block。

NAND Flash的页,包含主区(Main Area)和备用区(Spare Area)两个域,“主区”也常称作数据区,备用区是保留区域,一般用来标记坏块(bad block)和存放ECC的值,当然有些文件系统使用备用区记录擦除次数、文件组织数据等。

图1.1 为页大小为2048+64的闪存存储结构

3、坏块及ECC

位翻转的发生是随机的,且比特误码的数量会随着擦写次数的增加而增加。但是只要比特误码的数量在ECC 能够纠正的范围内,数据的完整性就始终有保障。在有些点,每页的比特误码有可能很接近ECC 所能纠正的极限,NAND 的控制系统必须严防比特误码超过可纠错的范围,否则,就可能造成数据丢失或者系统无法正常工作。因此,这些块必须要标记为坏块。坏块永远不应该再用来存储数据。由于坏块的产生是不可避免的,NAND 制造商在对裸片测试时会选择对某些块进行坏块标记,而不是放弃整个裸片,所以大多数NAND 在出厂时就已经存在标记为坏块的块。如果一个NAND 的块被标记为坏块,那么NAND 的容量就永久性的减小了。

二、Nand系统裸片量产烧录的关键点

由于Nand flash芯片的特性,以其作为存储介质时必须对这些特性进行恰当处理,这样系统才能正常运行。系统设定各分区数据在Nand芯片的存储布局,并且在存储驱动层对Nand进行位纠错、坏块管理等处理,这些信息需要系统/驱动工程师明确。

研发阶段或小批量生产阶段,常采用在板烧录的方式,原理是将boot通过串口下载到内存跑起来,由boot从SD卡或网络将内核镜像、文件系统镜像等数据烧录到Nand flash芯片。

为了提高生产效率或别的方面考虑,会使用烧录器对Nand flash裸片进行量产烧录,由于烧录器厂家并不知道存储驱动层对Nand各种特性的处理方式,所以不加正确配置就进行烧录的话,往往出现以下情况:1. 烧录失败,经常是校验通不过;2. 烧录通过,但是部分芯片贴板之后系统运行不起来,或者运行起来某些模块出现一些错误与异常。这些大多不是烧录器本身的问题,而是裸片烧录Nand系统时几个重要的关键点没有处理好,或者说没有和目标系统相关处理一致。这些关键点包括:

1) 坏块处理策略

2) 分区(Partition)

3) 纠错码(Error Correction Codes,ECC)

当然,影响烧录的还有其他因素,比如备用区的使用情况、未用好快的格式化以及动态元数据等,但我们这里只讨论上面几个比较普遍的因素。

1、坏块处理策略

坏块一般是根据芯片的坏块标记位置进行识别的,而坏块处理策略定义了在遇到坏块时算法应该如何处理。策略算法负责将本来应该写到坏块的内容写到其它可选的好块中。最常用的坏块处理策略是跳过坏块,其他典型的还有带BBT的跳过坏块及预留块区等。

跳过坏块的处理策略是最基本最常用的坏块替换策略。当烧录中遇到坏块时,算法简单地跳过坏块,而将数据写入下一个好块。它会造成物理数据和逻辑数据的位置偏移,这通常需要分区来解决这个问题。

2、分区(Partition)

采用类跳过坏块的处理策略的Nand系统,常常会把存储区分成若干个不同的物理区域,这就是我们说的分区,概念上很像电脑硬盘的分区。使用分区使得你有能力确保你的数据可以存到预先指定的物理块区内,即便在这之前发现了一些坏块。这对一些底层软件组件比如启动引导程序和某些必须很容易定位的文件系统驱动程序来说,是非常有帮助的。

当使用跳过坏块的替换策略时,坏块会导致数据顺移到下一个好块。如果设置了分区,就可以指导烧录器确定数据的边界,确保数据文件不会侵占邻近的分区。

图2.2.1就是典型的嵌入式Linux系统的分区情况。

图2.2.1 典型的嵌入式Linux系统分区情况

3、纠错码(Error Correction Codes,ECC)

针对不同工艺、容量的NAND存储系统采用适当的ECC算法是应该的,要保证系统的可靠性,甚至是必须的。ECC纠错码一般存放在备用区中,对一整页或将页分成若干节的数据进行计算而得。数据烧录之前需要准备好ECC(硬件ECC除外),如果是纯数据则需要使用ECC算法来生成。Nand裸片量产中,知道ECC算法的纠错能力(纠错位数)是很重要的,因为要保证生产效率,烧录器如果采用ECC来进行校验数据是不实际的,而通过简单数据比对就可以知道数据的位翻转个数,如果翻转个数范围在ECC算法的纠错范围之内,则认为校验应该是通过的。

三、烧录定制

对于以上关键点或其它特殊部分,如果烧录器软件没有支持的相应的方案,需要联系原厂进行相关算法的定制,比如坏块处理方案、ECC方案等。

加入微信

更多内涵 你懂的

搜索微信公众号:电子产品世界

相关问答

苹果系统finder里的推出是什么意思?-ZOL问答

在启动(或登录)麦金塔电脑后,Finder是用户首先会接触到的程序,它也负责体现整...是64GB闪存吧,MacBookAir取消机械硬盘和光驱,仅配备NAND闪存芯片作为存储设备...

笔记本的闪存笔记本的闪存是什么意思闪存读取速度?

MacBookAir取消机械硬盘和光驱,仅配备NAND闪存芯片作为存储设备。这种设计方案大大减轻了MacBookAir的重量和体积,提高了开机速度。苹果新一代MacBookAir笔...

三星固态需要装驱动吗-ZOL问答

是Intel为超极本量身定做的新一代固态硬盘接口标准,其常规尺寸仅为42mm×22mm,单面布置NANDFlash颗粒的厚度为2.75mm,双面颗粒的厚度是3.85mm,对mSATA来说体积...

华为之前在推的超微型存储卡是什么套路?

这个问题分两个层面来回答。第一是当时发布的时候,第二是现在。先说说手机存储卡的背景。插卡手机的发展是远远早于智能机的,当手机开始多媒体化,还没进化到...

iPhonesr2是什么屏幕?

将同样采用刘海全面屏设计,搭载与iPhone11系列相同的A13仿生芯片,配备3GBLPDDR4X内存,提供64GB、128GB两种NANDFlash选项,并将取消3DTouch。此外,在配色...

谷歌的Titan M芯片到底是什么?你对这个芯片如何评价?

财产安全问题从古至今都是大家最为关心的问题,从古老的机关盒、牢固的保险箱,再到虚拟世界的各种安全卫士以及加密协议都,也都是为此而生。而为了防止被盗号,...

请问装固态硬盘是必须开achi么?-ZOL问答

开启NCQ后,SSD主控制器会根据数据的请求和NAND内部数据的分布,充分利用主控制器...5)固态硬盘并不是用来为windows启动提速的,更大的用处是增加游戏或者软件的执...

三星新一代最强M.2 SSD怎么样?

今日三星公司在北京率先于全球召开了新一代旗舰M.2SSD发布会,正式宣布970PRO、970EVO降临。虽然两者均采用最新的64层V-NAND,970PRO为MLC,而970EVO为TLC....

为什么三星的旗舰机上市,从来不用抢购,一直都是现货?

三星屏幕内存等手机关键部件都能自给自足,不会被别人卡脖子。而且也不会玩饥饿营销,国产的都被带坏了,我买note7就是因为有现货,后来召回买的华为美腿九。抢...

电脑同时有SSD和机械硬盘这两种硬盘时怎么在系统中辨别?-ZOL问答

这样搭配的好处就是可以用SSD做系统盘,加快电脑开机启动速度及运行速度。因为...固态硬盘NAND闪存芯片密度会越来越大,存储量越来越高,以后的价格也会越来越低...

 四百龙银  腾讯qq超市 
王经理: 180-0000-0000(微信同号)
10086@qq.com
北京海淀区西三旗街道国际大厦08A座
©2024  上海羊羽卓进出口贸易有限公司  版权所有.All Rights Reserved.  |  程序由Z-BlogPHP强力驱动
网站首页
电话咨询
微信号

QQ

在线咨询真诚为您提供专业解答服务

热线

188-0000-0000
专属服务热线

微信

二维码扫一扫微信交流
顶部