CN101710302B - 基于NandFlash存储介质的固件程序检测方法 - Google Patents
基于NandFlash存储介质的固件程序检测方法 Download PDFInfo
- Publication number
- CN101710302B CN101710302B CN2009101049315A CN200910104931A CN101710302B CN 101710302 B CN101710302 B CN 101710302B CN 2009101049315 A CN2009101049315 A CN 2009101049315A CN 200910104931 A CN200910104931 A CN 200910104931A CN 101710302 B CN101710302 B CN 101710302B
- Authority
- CN
- China
- Prior art keywords
- data
- sector
- read
- nandflash
- write
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
- 238000000034 method Methods 0.000 title claims abstract description 25
- 238000003860 storage Methods 0.000 title claims abstract description 12
- 238000004519 manufacturing process Methods 0.000 claims abstract description 5
- 238000012360 testing method Methods 0.000 abstract description 32
- 238000004458 analytical method Methods 0.000 abstract description 4
- 230000007547 defect Effects 0.000 abstract description 2
- 238000012827 research and development Methods 0.000 abstract description 2
- 238000004422 calculation algorithm Methods 0.000 description 10
- 238000011160 research Methods 0.000 description 10
- 238000013507 mapping Methods 0.000 description 5
- 230000002950 deficient Effects 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 238000013459 approach Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 230000007812 deficiency Effects 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000009977 dual effect Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 238000004321 preservation Methods 0.000 description 1
- 230000000576 supplementary effect Effects 0.000 description 1
- 238000010998 test method Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
Images
Landscapes
- Techniques For Improving Reliability Of Storages (AREA)
- Debugging And Monitoring (AREA)
Abstract
一种基于NandFlash存储介质的固件程序检测方法,用于在NandFlash存储器生产过程中对其固件程序检测,包括步骤:对新生产的基本NandFlash存储介质存储器以随机数进行全盘填充;在所述存储器逻辑读写范围内随机选择一个逻辑地址Addr,然后随机选择N个扇区作为操作长度;读取所选目标数据的前后M个扇区;从所述逻辑地址Addr起,写入N个扇区的随机数据;从所述逻辑地址Addr前M个扇区地址开始,连续读取所述N扇区及其前后各M扇区的数据,获取写入后当前目标设备逻辑地址上的数据;判定写入前后数据是否匹配,并将不匹配的数据文件进行保存。本发明的有益效果在于:解决测试时间长、没有针对性、无法生成测试脚本、无法复现错误、无法给研发人员分析问题所在提供有价值的参考信息等缺陷。
Description
技术领域
本发明涉及电数字数据处理,特别是涉及电数字数据处理中通过软件的测试或调试防止错误,尤其涉及基本Nand Flash作为存储介质的固件程序检测方法。
背景技术
Nand Flash即“与-非”闪存是一种非易失存储器,可以对称为块的存储器单元块进行擦写和再编程。任何Nand Flash器件的写入操作只能在空或已擦除的单元内进行,所以大多数情况下,在进行写入操作之前必须先执行擦除。参见图3,现有技术在固件程序Firmware管理数据的时候,当需要写入数据到块A中的某个位置时,则需要选择一个可用块B,将B擦除干净,然后分别把A的数据A1搬到B1,把需要写入的数据写入B2,把A3数据写入B3,再把逻辑映射表指向B块,从而完成一次写入。实际操作中,考虑到速度的优化,在地址连续写入的时候,或者跨区Zone轮流写入的时候,还有更复杂的闪存Flash管理流程。
目前,测试固件程序FW逻辑读写的方式都采用文件拷贝比较或者Burn In Test测试软件,其方式都是写入数据B2,然后读取B2,看是否匹配;这两种方式都有在Flash管理中需要频繁搬运数据的特点。但是存在这种现象:B2是搬对了,但是B1和B3在从A1、A3过来的时候搬错了,对于这些搬错的B1、B3,上述的拷贝比较工具并不能及时发现。甚至在后面的操作中,覆盖了B1或者B3,从而忽略了曾经发生的错误。
传统的测试方法是做文件拷贝后进行数据比较,或者用测试软件做全盘数据写入后进行读取匹配,这些方法都存在测试覆盖Firmware算法分支不全面,并且发生数据不匹配后无法辅助分析Firmware错误原因的缺陷。
Nand Flash领域中的开发难点主要包括坏块管理、损耗平衡、逻辑映射,其中验证逻辑映射算法的正确性是一件复杂的工作,具有调试难、覆盖算法分支难、问题重现难的特点,通常研发人员在编写程序完成后,都是交付测试部门的人员,通过文件拷贝进行逻辑算法正确性的验证。通过拷贝比较来发现逻辑映射算法不足之处主要有两个途径,一个是手工拷贝文件到存储器中,拷满后,通过文件比较工具File Compare进行数据比较,发现其中数据不匹配的情况,再反馈给研发人员;另外一种方法是使用随机数填充、比较软件进行测试,例如Burnin软件、wrtest软件等,自动进行随机写入和读取比较,从而发现写入和读取不匹配的情况。以上两种方法都有着明显的缺陷是:测试时间长,没有针对性,无法生成测试脚本,无法复现错误,无法给研发人员分析问题所在提供有价值的参考信息。
发明内容
本发明要解决的技术问题在于避免上述现有技术的不足而提出一种的基于NandFlash存储介质的固件程序检测方法,从而令现有技术中存在的测试时间长、没有针对性、无法生成测试脚本、,无法复现错误、无法给研发人员分析问题所在提供有价值的参考信息等缺陷得到解决。
本发明解决所述技术问题可以通过采用以下技术方案来实现,该方案是基于NandFlash存储介质的固件程序检测方法,包括步骤:
A.判定待测试的基本NandFlash的存储器是否为新生产的存储器,如是,即对所述存储器以随机数进行全盘填充;如否,则执行步骤B;
B.在所述存储器逻辑读写范围内随机选择一个逻辑扇区地址Addr,然后随机选择N个扇区作为操作长度;
C.读取步骤B中已选中地址Addr前面、从地址Addr-M到Addr扇区地址的M个扇区数据,再读取从地址Addr+N到Addr+N+M扇区地址的M个扇区数据,即读取所述扇区地址Addr到addr+N这段所选目标数据的前后M个扇区;
D.从所述逻辑扇区地址Addr起,写入N个扇区的随机数据;如果超过SCSI命令限制的一次64k的限制,则拆分后写入;
E.从所述逻辑扇区地址Addr-M开始,连续读取所述M+N+M个扇区的数据,获取步骤D写入操作后当前目标设备逻辑扇区地址上的数据;
F.将步骤C读取的数据和步骤D写入的数据、与步骤E读取的数据进行比较,判定写入前后数据是否匹配;如是,则执行步骤B;如否,则将所述两组数据分别存入两个文件中,再执行步骤B。
在步骤B中所述“随机选择N个扇区”,其中N可为1至255中任一整数。在步骤C中所述“M个扇区”中,其中M可为1至256中任一整数。
本发明采用的上述技术方法的有益效果在于:
1)测试时间短,具有针对性。本发明合理选择了单次测试的数据长度为1~255扇区,随机选择写入地址,能够尽量覆盖逻辑映射算法中的不同分支,如跨区Zone、跨块Block、连续读写,本发明的方法能够在尽量减少测试数据长度的前提下进行覆盖;
2)可以生成测试脚本。在测试过程中,将每次测试的写入地址、数据长度都保存到一个脚本文件中,如果读写数据不匹配,还会将两次的数据保存到磁盘中,供研发人员查看比较不匹配的原因,推测具体是由数据搬移错误还是漏搬引起。研发人员还可以通过重新执行引起错误的测试脚本,复现现象,从而给调试带来便利。
3)辅助研发人员分析原因。由于测试过程中,自动保存了测试脚本,研发人员可以查看测试脚本的写入地址和长度,根据NandFlash的参数,推测引起错误的原因,是因为执行到哪个算法分支后处理不当导致,从而提高了调试效率。
附图说明
图1是本发明基本NandFlash存储介质的固件程序检测方法实施流程图;
图2是所述方法实施时读取目标数据前后M个扇区的示意图;
图3是现有技术中块Block数据搬运示意图
具体实施方式
以下结合附图1、2所示实施作进一步详述。
本发明基本NandFlash存储介质的固件程序检测方法,包括步骤
A.判定待测试的基本NandFlash的存储器是否为新生产的存储器,如是,即对所述存储器以随机数进行全盘填充;如否,则执行步骤B;
B.在所述存储器逻辑读写范围内随机选择一个逻辑扇区地址Addr,然后随机选择N个扇区作为操作长度;
C.读取步骤B中已选中扇区地址Addr前面、从地址Addr-M到Addr扇区地址的M个扇区数据,再读取从地址Addr+N到Addr+N+M扇区地址的M个扇区数据,即读取所述扇区地址Addr到Addr+N这段目标数据的前后M个扇区;
D.从所述逻辑扇区地址Addr起,写入N个扇区的随机数据;如果超过SCSI命令限制的一次64k的限制,则拆分后写入;
E.从所述逻辑扇区地址Addr-M开始,连续读取M+N+M个扇区的数据,获取步骤D写入操作后当前目标设备逻辑扇区地址上的数据;
F.将步骤C读取的数据和步骤D写入的数据、与步骤E读取的数据进行比较,判定写入前后数据是否匹配;如是,则执行步骤B;如否,则将所述两组数据分别存入两个文件中:如图1所示,在本实施例中可将写入前M+N+M扇区的数据保存到日志文件“时间_地址_长度_写.dat”中,将写入操作后M+N+M扇区的数据保存到日志文件“时间_地址_长度_读.dat”中。再执行步骤B;
在步骤B中所述“随机选择N个扇区”,其中N可为1至255中任一整数。
在步骤C中所述“M个扇区”中,其中M可为1至256中任一整数。
由于算法对于不同参数配置的NandFlash可能存在差异,通常需要针对不同的NandFlash分别进行测试,如果采用拷贝比较的方法,由于NandFlash的写入速度比较慢,尽量减少测试的数据非常必要。根据NandFlash的特性,写入的数据长度为1~255个扇区,即可保证一定覆盖跨Zone、跨Block的算法分支,因为目前市面的NandFlash单个Block的容量没有超过255个扇区的,当随机测试的数据长度大于Block的容量时,就能覆盖跨Block的算法分支,在这种情况下,即使测试的数据长度大于255个扇区,也是没有什么意义了。随机产生的测试地址,加上随机产生的随机长度,能够覆盖一些边缘情况。
测试的数据很重要,合适的数据可以给研发工程师很多额外的辅助信息,用于分析遇到的数据不匹配原因。例如设定一个较小的测试容量范围,进行数据填充,填充的内容为数据区所在的扇区地址(意思就是说扇区0里面填充的数据都是0x00000000,扇区1里面填充的数据都是0x00000001),假设预填充了100个扇区的数据,那么,在进行写入操作之后,检测目标写入地址边缘的区域发现数据不匹配,说明在搬运关联区域的数据出错了,由于我们数据里面写入的是逻辑地址的值,通过查看出错的数据为哪个逻辑地址,即可猜测搬错的原因。
以往的拷贝匹配测试软件都是产生随机数,然后顺序写入或者随机写入测试存储器,没有任何的测试信息输出可供研发人员、测试人员参考,以致于出现不匹配的现象后无法重现问题而耽误调试进度。本发明的方法在测试过程中,对每一次随机产生的地址、测试长度都会进行保存,并且在读写发生不匹配的时候,可以将写入前后的数据保存到文件中,供研发人员分析。对于一些比较特殊的错误现象需要Firmware跟踪调试的,还可以通过重新执行保存的脚本命令,重现出现问题的步骤。
Claims (3)
1.一种基于NandFlash存储介质的固件程序检测方法,用于在NandFlash存储器生产过程中对其固件程序检测,其特征在于,包括步骤:
A.判定待测试的基本NandFlash的存储器是否为新生产的存储器,如是,即对所述存储器以随机数进行全盘填充;如否,则执行步骤B;
B.在所述存储器逻辑读写范围内随机选择一个逻辑扇区地址Addr,然后随机选择N个扇区作为操作长度;
C.读取步骤B中已选中扇区地址Addr前面、从地址Addr-M到Addr扇区地址的M个扇区数据,再读取从地址Addr+N到Addr+N+M扇区地址的M个扇区数据,即读取所述扇区地址Addr到Addr+N这段目标数据的前后M个扇区;
D.从所述逻辑扇区地址Addr起,写入N个扇区的随机数据;如果超过SCSI命令限制的一次64k的限制,则拆分后写入;
E.从所述逻辑扇区地址Addr-M开始,连续读取M+N+M个扇区的数据,获取步骤D写入操作后当前目标设备逻辑扇区地址上的数据;
F.将步骤C读取的数据和步骤D写入的数据、与步骤E读取的数据进行比较,判定写入前后数据是否匹配;如是,则执行步骤B;如否,则将所述两组数据分别存入两个文件中,再执行步骤B。
2.如权利要1所述基于NandFlash作为存储介质的固件程序检测方法,其特征在于:步骤B中所述“随机选择N个扇区”,其中N可为1至255中任一整数。
3.如权利要1所述基于NandFlash作为存储介质的固件程序检测方法,其特征在于:步骤C中所述“M个扇区”中,其中M可为1至256中任一整数。
Priority Applications (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| CN2009101049315A CN101710302B (zh) | 2009-01-09 | 2009-01-09 | 基于NandFlash存储介质的固件程序检测方法 |
Applications Claiming Priority (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| CN2009101049315A CN101710302B (zh) | 2009-01-09 | 2009-01-09 | 基于NandFlash存储介质的固件程序检测方法 |
Publications (2)
| Publication Number | Publication Date |
|---|---|
| CN101710302A CN101710302A (zh) | 2010-05-19 |
| CN101710302B true CN101710302B (zh) | 2011-08-17 |
Family
ID=42403094
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| CN2009101049315A Expired - Fee Related CN101710302B (zh) | 2009-01-09 | 2009-01-09 | 基于NandFlash存储介质的固件程序检测方法 |
Country Status (1)
| Country | Link |
|---|---|
| CN (1) | CN101710302B (zh) |
Families Citing this family (2)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| CN109388583B (zh) * | 2018-10-10 | 2024-01-12 | 深圳芯邦科技股份有限公司 | 一种参数检测的方法及相关设备 |
| CN111949426B (zh) * | 2019-05-16 | 2024-09-17 | 兆易创新科技集团股份有限公司 | 一种固件程序错误的检测方法、装置及存储设备 |
Citations (3)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| CN1248335A (zh) * | 1997-12-22 | 2000-03-22 | Tdk株式会社 | 闪速存储器系统 |
| CN1728284A (zh) * | 2004-07-26 | 2006-02-01 | 深圳市朗科科技有限公司 | 一种扫描闪存盘的闪存芯片的方法 |
| CN1737759A (zh) * | 2005-08-27 | 2006-02-22 | 海信集团有限公司 | 一种在Nand Flash存储器中直接建立只读文件系统的方法 |
-
2009
- 2009-01-09 CN CN2009101049315A patent/CN101710302B/zh not_active Expired - Fee Related
Patent Citations (3)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| CN1248335A (zh) * | 1997-12-22 | 2000-03-22 | Tdk株式会社 | 闪速存储器系统 |
| CN1728284A (zh) * | 2004-07-26 | 2006-02-01 | 深圳市朗科科技有限公司 | 一种扫描闪存盘的闪存芯片的方法 |
| CN1737759A (zh) * | 2005-08-27 | 2006-02-22 | 海信集团有限公司 | 一种在Nand Flash存储器中直接建立只读文件系统的方法 |
Non-Patent Citations (1)
| Title |
|---|
| 李奕.FLASH测试器的设计与实现.《中国优秀博硕士学位论文全文数据库(硕士)信息科技辑》.中国学术期刊(光盘版)电子杂志社,2006,(第6期),1-73. * |
Also Published As
| Publication number | Publication date |
|---|---|
| CN101710302A (zh) | 2010-05-19 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| CN104407951A (zh) | 一种自动化进行服务器整机测试的方法 | |
| TWI486957B (zh) | Nand快閃記憶體燒錄資料的處理、使用方法及裝置、運行系統 | |
| CN116884469B (zh) | 一种闪存性能的检测方法、装置、设备及介质 | |
| CN103136211A (zh) | 一种a2l文件的自动生成方法和装置 | |
| CN116612803B (zh) | 一种闪存的测试方法、系统、装置及存储介质 | |
| CN114664369A (zh) | 一种存储芯片测试方法及装置 | |
| CN110764960B (zh) | 一种固态硬盘固件测试方法 | |
| CN112216338A (zh) | 一种固态硬盘老化产生坏块的解析方法、装置 | |
| CN113157512B (zh) | 实现大容量ssd在小内存机器上进行数据校验测试的方法 | |
| CN101710302B (zh) | 基于NandFlash存储介质的固件程序检测方法 | |
| CN102486938A (zh) | 一种快速检测存储器的方法及装置 | |
| CN110444244A (zh) | 存储设备读错误纠错能力的测试装置 | |
| CN112069004B (zh) | 一种闪存芯片中块读取与页读取换算关系测试方法及系统 | |
| CN110109773A (zh) | 一种虚拟机磁盘一致性的检测方法及系统 | |
| CN114153670A (zh) | 一种随机测试方法、装置、设备及存储介质 | |
| CN111949426B (zh) | 一种固件程序错误的检测方法、装置及存储设备 | |
| CN107680632B (zh) | 一种固态硬盘的寿命测试方法及装置 | |
| CN102360568B (zh) | 一种并行异步存储器及其数据读取方法 | |
| CN118629484A (zh) | 一种固态硬盘性能测试方法及装置、设备、介质 | |
| US12164810B2 (en) | Generating command snapshots in memory devices | |
| KR101530587B1 (ko) | 고속 Fail Memory 데이터 취득 장치 및 그 방법 | |
| Shey et al. | Inferring trimming activity of solid-state drives based on energy consumption | |
| CN114528168B (zh) | 一种用于互感器二次多点接地测试系统 | |
| CN108563503A (zh) | 一种用于程序测试的数据流记录方法和数据流记录系统 | |
| CN116841463A (zh) | 存储设备的数据校验方法、装置、设备及存储介质 |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| C06 | Publication | ||
| PB01 | Publication | ||
| C10 | Entry into substantive examination | ||
| SE01 | Entry into force of request for substantive examination | ||
| C14 | Grant of patent or utility model | ||
| GR01 | Patent grant | ||
| CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20110817 Termination date: 20170109 |
|
| CF01 | Termination of patent right due to non-payment of annual fee |