CN110534151A - 实现写入前擦除的方法、装置、计算机设备及存储介质 - Google Patents
实现写入前擦除的方法、装置、计算机设备及存储介质 Download PDFInfo
- Publication number
- CN110534151A CN110534151A CN201810508531.XA CN201810508531A CN110534151A CN 110534151 A CN110534151 A CN 110534151A CN 201810508531 A CN201810508531 A CN 201810508531A CN 110534151 A CN110534151 A CN 110534151A
- Authority
- CN
- China
- Prior art keywords
- write
- unit
- erasing
- point
- writing
- 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.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/04—Detection or location of defective memory elements, e.g. cell constructio details, timing of test signals
- G11C29/08—Functional testing, e.g. testing during refresh, power-on self testing [POST] or distributed testing
- G11C29/12—Built-in arrangements for testing, e.g. built-in self testing [BIST] or interconnection details
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/70—Masking faults in memories by using spares or by reconfiguring
- G11C29/78—Masking faults in memories by using spares or by reconfiguring using programmable devices
Landscapes
- Techniques For Improving Reliability Of Storages (AREA)
- Read Only Memory (AREA)
Abstract
本发明涉及实现写入前擦除的方法、装置、计算机设备及存储介质,该方法包括在SMT时向NAND Flash中写入出厂坏块表和固件;记录写入点以及相关信息;根据记录的写入点以及相关信息进行数据的写前擦处理。本发明通过在SMT时向NAND Flash中写入出厂坏块表和固件,设置写入前擦除的前提要求,不进行全盘擦除操作;在写入数据时记录写入点,关机时根据写入点使用快速填充命令、数据搬移到SLC区域和填充仿造的数据的写前操作,在SSD使用过程中,通过时间阈值判断执行写前擦操作,实现保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NAND flash寿命缩减以及SSD使用寿命减少的现象发生。
Description
技术领域
本发明涉及固态硬盘,更具体地说是指实现写入前擦除的方法、装置、计算机设备及存储介质。
背景技术
由于NAND flash的固有特性,在写操作之前需要进行擦除,不能进行复写操作。而最新的Sandisk NAND flash更是要求只有需要写时才能进行擦除操作,不允许NAND flash的擦除单元长时间保持擦除状态,或者擦除单元中部分读写单元长期保持擦除状态,擦除单元长时间处于开放状态,现行的SSD实现策略都是在量产时进行全盘擦除,当SSD出厂后,到客户手中实际使用时,才进行写操作。这样势必造成SSD中的擦除单元长期处于擦除状态或者开放状态,严重影响SSD使用寿命。
现有写操作的方法为了保证多并行操作,利用多独立并行可操作单元的并行性能,使用每个独立并行可操作单元的写节点均匀分布的方法,这样做造成的影响是安全关机时每个独立并行可操作单元中被写擦除单元的写入点几乎相同,但是如果开放的擦除单元中写入点靠前,需要进行补仿造的数据,需要补仿造的页数量也很多,因为需要补仿造的页数量太多而不能在安全关机前完成补仿造的,而且会造成写放大增加。
现有SMT方案没有考虑NAND flash写前擦除的特性,在FT1中会进行全盘擦除操作,在BIST过程结束前也会进行一次全盘擦除操作,这样导致NAND flash从量产出厂开始到客户实际使用期间长期处于被擦除状态,这样会导致NAND flash寿命缩减,SSD使用寿命减少。现行的闪存地址转换层并不记录写入点,由于在写操作时都是从最低位的读写单元开始按顺序进行,未写过的读写单元读出的状态一定是空闲,所以现行闪存地址转换层在初始化时会通过二分法寻找写入点,如图1所示,Sandisk 3D TLC一共有256个word line,768个subpage读写单元,二分法查找写入点流程是L=0,M=wl_max/2=128,N=L+M=128,先读取wl128,如果是空闲,则L=N=128,M=M/2=64,N=L-M=64,读取wl64,否则N=L+M=192,读取wl192,以此类推,直至M=0,这时读取wl_N,如果是empty page读写单元,写入点就是wl_N-1,否则写入点是wl_N。现行FTL并没有考虑Sandisk 3D TLC颗粒写前擦的特性,所以在SSD读写过程和安全关机过程中不会考虑开放擦除单元和已被擦除的擦除单元问题,这样会导致SSD使用寿命减小。
因此,有必要设计一种新的方法,实现保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NAND flash寿命缩减以及SSD使用寿命减少的现象发生。
发明内容
本发明的目的在于克服现有技术的缺陷,提供实现写入前擦除的方法、装置、计算机设备及存储介质。
为实现上述目的,本发明采用以下技术方案:实现写入前擦除的方法,所述方法包括:
在SMT时向NAND Flash中写入出厂坏块表和固件;
记录写入点以及相关信息;
根据记录的写入点以及相关信息进行数据的写前擦处理。
其进一步技术方案为:在SMT时向NAND Flash中写入出厂坏块表和固件的步骤,包括以下具体步骤:
进行硬件自检,扫描出厂坏块,下载BIST程序,并向擦除单元0\1写入模式;
进行硬件自检,进行全盘读写擦测试,并对测试结果进行统计;
进行硬件自检,检查全盘读写擦测试结果,并上传至主机,检查擦除单元0\1中的模式、擦除Nor flash中的BIST程序,并向Nor flash写入BootLoader,向NAND flash写入固件。
其进一步技术方案为:记录写入点以及相关信息的步骤中,所述相关信息包括每个计划正在操作的擦除单元的标志以及最后一次操作的时间。
其进一步技术方案为:根据记录的写入点以及相关信息进行数据的写前擦处理的步骤,包括以下具体步骤:
根据记录的写入点以及相关信息判断擦除单元是否为刚结束擦除的单元;
若是,则使用快速填充命令对该单元进行随机数填充;
若否,则判断记录的写入点是否小于阈值;
若是,则将TLC区域中的数据搬移至SLC区域内;
擦除TLC擦除单元;
使用快速填充命令进行随机数填充TLC擦除单元;
若否,则对开放状态的TLC擦除单元填充仿造的数据。
其进一步技术方案为:在安全关机时根据记录的写入点以及相关信息进行数据的写前擦处理的步骤之后,还包括:
在SSD使用过程中,记录每次写操作完成时的时间;
使用中断方式,每隔一段时间获取擦除单元保持开放或处于已擦除状态的时间;
判断获取的时间是否超过设定的阈值;
若否,则返回所述使用中断方式,每隔一段时间获取擦除单元保持开放或处于已擦除状态的时间的步骤;
若是,则返回根据记录的写入点以及相关信息进行数据的写前擦处理的步骤。
其进一步技术方案为:所述判断获取的时间是否超过设定的阈值的步骤中,所述阈值Tth采用以下公式计算:其中,Tref表示擦除单元保持开放或处于已擦除状态的时间参考阈值,Twl表示考虑磨损均衡的参考时间阈值,max表示所有擦除单元中擦写次数最大值,min表示所有擦除单元中擦写次数最小值,kε是表示SSD系统响应能力的常数。
本发明还提供了实现写入前擦除的装置,包括写入单元、记录单元以及写前擦处理单元;
所述写入单元,用于在SMT时向NAND Flash中写入出厂坏块表和固件;
所述记录单元,用于记录写入点以及相关信息;
所述写前擦处理单元,用于根据记录的写入点以及相关信息进行数据的写前擦处理。
其进一步技术方案为:所述写入单元包括模式写入模块、测试模块以及擦除处理模块;
所述模式写入模块,用于进行硬件自检,扫描出厂坏块,下载BIST程序,并向擦除单元0\1写入模式;
所述测试模块,用于进行硬件自检,进行全盘读写擦测试,并对测试结果进行统计;
所述擦除处理模块,用于进行硬件自检,检查全盘读写擦测试结果,并上传至主机,检查擦除单元0\1中的模式、擦除Nor flash中的BIST程序,并向Nor flash写入BootLoader,向NAND flash写入固件。
本发明还提供了一种计算机设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述的实现写入前擦除的方法。
本发明还提供了一种存储介质,所述存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时使所述处理器执行上述的实现写入前擦除的方法。
本发明与现有技术相比的有益效果是:本发明的实现写入前擦除的方法,通过在SMT时向NAND Flash中写入出厂坏块表和固件,设置写入前擦除的前提要求,不进行全盘擦除操作;在写入数据时记录写入点,安全关机时根据写入点使用快速填充命令、数据搬移到SLC区域和填充仿造的数据的写前操作,在SSD使用过程中,通过时间阈值判断执行写前擦操作,实现保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NANDflash寿命缩减以及SSD使用寿命减少的现象发生。
下面结合附图和具体实施例对本发明作进一步描述。
附图说明
图1为现有技术的二分法查找写入点的示意流程图;
图2为本发明一具体实施例提供的实现写入前擦除的方法的示意流程图;
图3为图2具体实施例提供的在SMT时向NAND Flash中写入出厂坏块表和固件的示意流程图;
图4为图2具体实施例提供的根据记录的写入点以及相关信息进行数据的写前擦处理的示意流程图;
图5为图2具体实施例提供的高速缓冲存储器的写操作和高速缓冲存储器的读操作的原理框图;
图6为本发明另一具体实施例提供的实现写入前擦除的方法的示意流程图;
图7为本发明一具体实施例提供的实现写入前擦除的装置的示意性框图;
图8为图7具体实施例提供的写入单元的示意性框图;
图9为图7具体实施例提供的写前擦处理单元的示意性框图;
图10为本发明另一具体实施例提供的实现写入前擦除的装置的示意性框图;
图11是本申请一实施例提供的一种计算机设备的示意性框图。
具体实施方式
为了更充分理解本发明的技术内容,下面结合具体实施例对本发明的技术方案进一步介绍和说明,但不局限于此。
应当理解,当在本说明书和所附权利要求书中使用时,术语“包括”和“包含”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在此本申请说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本申请。如在本申请说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
还应当进一步理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如图2~11所示的具体实施例,本实施例提供的实现写入前擦除的方法、装置、计算机设备及存储介质,可以运用在SSD固态硬盘进行写操作之前、中途以及之后的处理过程中,实现保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NAND flash寿命缩减以及SSD使用寿命减少的现象发生。
请参阅图2,图2是一具体实施例提供的实现写入前擦除的方法的示意流程图,如图2所示,实现写入前擦除的方法包括步骤S101至步骤S103:
S101、在SMT时向NAND Flash中写入出厂坏块表和固件。
在本实施例中,SMT流程主要包括FT1\BIST\FT2三个阶段,每个环节完成的流程均不一致,但是在整个SMT过程中只向NAND flash中写入出厂坏块表和FW(固件)并保证擦除单元处于关闭状态,不做全盘擦除,保证没有擦除单元处于开放或已擦除的状态,满足写前擦要求,无论是开放还是已擦除的状态,都代表擦除单元已经做好写入准备了,导致NANDflash寿命缩减,SSD使用寿命减少,而对SMT的写入NAND Flash的内容进行限定,保证在SMT过程中不会出现开放的擦除单元。
S102、记录写入点以及相关信息。
在本实施例中,上述的相关信息包括每个计划正在操作的擦除单元的标志以及最后一次操作的时间。
具体地,利用写入点来判断需要进行写入前擦除的方式。优化FTL算法,使用擦除单元状态表记录每个计划正在操作的擦除单元的标志,每个擦除单元的写入点以及最后一次操作的时间。
S103、根据记录的写入点以及相关信息进行数据的写前擦处理。
在本实施例中,当PC端安全关机时,刚擦除的擦除单元使用快速填充命令进行随机数填充;写入点小于阈值时,将TLC区域中的数据搬移到SLC区域,擦除TLC擦除单元,再使用快速填充命令进行随机数填充;写入点大于阈值时,向开放状态的TLC擦除单元填充仿造的数据。
使用3D TLC NAND flash作为存储介质的SSD中都会开辟部分TLC区域和SLC区域,由于SLC擦除单元的回收周期比较高,且开放擦除单元和保持已擦除状态对SLC擦除单元的寿命影响可以忽略不计,就不考虑SLC擦除单元的写前擦策略,另外,在进行TLC区域写前擦策略时也会利用SLC擦除单元的特性,将部分数据暂时存入SLC擦除单元,以实现写入前擦除的方案。
请参阅图3,图3是在SMT时向NAND Flash中写入出厂坏块表和固件的示意流程图,如图3所示,S101、在SMT时向NAND Flash中写入出厂坏块表和固件的步骤,包括步骤S1011至S1013:
S1011、进行硬件自检,扫描出厂坏块,下载BIST程序,并向擦除单元0\1写入模式;
S1012、进行硬件自检,进行全盘读写擦测试,并对测试结果进行统计;
S1013、进行硬件自检,检查全盘读写擦测试结果,并上传至主机,检查擦除单元0\1中的模式、擦除Nor flash中的BIST程序,并向Nor flash写入BootLoader,向NAND flash写入固件。
其中,FT1时进行硬件自检,扫描出厂坏块,下载BIST程序,并向擦除单元0\1写入模式;BIST时进行硬件自检,进行全盘读写擦测试,并对测试结果进行统计;FT2时进行硬件自检,检查全盘读写擦测试结果,并上传至主机,检查擦除单元0\1中的模式、擦除Norflash中的BIST程序,并向Nor flash写入BootLoader,向NAND flash写入固件。在整个SMT过程中只向NAND flash中写入出厂坏块表和FW(固件)并保证擦除单元关闭,不做全盘擦除,保证没有擦除单元处于开放或者已擦除状态,满足写前擦要求。
请参阅图4,图4是根据记录的写入点以及相关信息进行数据的写前擦处理的示意流程图,如图4所示,S103、根据记录的写入点以及相关信息进行数据的写前擦处理的步骤,包括步骤S1031至S1037:
S1031、根据记录的写入点以及相关信息判断擦除单元是否为刚结束擦除的单元;
S1032、若是,则使用快速填充命令对该单元进行随机数填充;
S1033、若否,则判断记录的写入点是否小于阈值;
S1034、若是,则将TLC区域中的数据搬移至SLC区域内;
S1035、擦除TLC擦除单元;
S1036、使用快速填充命令进行随机数填充TLC擦除单元。
S1037、若否,则对开放状态的TLC擦除单元填充仿造的数据。
如果一个擦除单元长时间没有操作,在擦除单元剩余读写单元中填入仿造的数据,保证擦除单元处于关闭状态;为防止PC安全关机时造成SSD中大量擦除单元保持开放状态或已擦除状态,在关机时间间隔内向开放擦除单元写入仿造的数据。
在本实施例中,FTL在每次写操作完成时都会记录写入点wl_n,用于在安全关机时进行写前擦策略的选择,也就是上述的S102步骤至S103步骤;写前擦策略如下:
如果安全关机时擦除单元刚好擦除过,就使用快速填充数据的命令(06h-addr-30h)向擦除单元中填入随机数,由于快速填充时间在5ms左右,可以满足安全关机的时间要求;如果安全关机时擦除单元中填充了少量数据,写入点wl_n小于阈值wl_th,则将TLC擦除单元中的数据读出填入SLC擦除单,既避免了填充的数据被擦除,又可以进行写入前擦除的方案,保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加;如果安全关机时擦除单元中填充了大量数据,写入点wl_n大于等于阈值wl_th,则直接向TLC擦除单元中的空闲的读写单元填入仿造的数据,保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NAND flash寿命缩减以及SSD使用寿命减少的现象发生。
阈值wl_th用于判断是否向SLC擦除单元迁移数据,在数据迁移过程中使用高速缓冲存储器的写操作和高速缓冲存储器的读操作代替正常的写操作和正常的读操作,提高数据迁移速度,高速缓冲存储器的写操作和高速缓冲存储器的读操作的原理如图5所示。Sandisk 3D TLC的TLC高速缓冲存储器的读操作时间Ttlc_r为60us,TLC高速缓冲存储器的写操作时间Ttlc_w为678us,SLC高速缓冲存储器的写操作操作时间Tslc_w为215us,当向SLC擦除单元迁移数据的时间和填充TLC擦除单元剩余空闲的读写单元时间相等时就达到临界值,即wl_th*(Ttlc_r+Tslc_w)=(wl_max-wl_th)*Ttlc_w;其中,wl_max为TLC擦除单元中最大的字行数,解该公式可得出阈值wl_th为182。
请参阅图6,图6是另一具体实施例提供的实现写入前擦除的方法的示意流程图,如图6所示,实现写入前擦除的方法包括S201至S206:
S201、在SMT时向NAND Flash中写入出厂坏块表和固件;
S202、记录写入点以及相关信息;
S203、根据记录的写入点以及相关信息进行数据的写前擦处理;
S204、在SSD使用过程中,记录每次写操作完成时的时间;
S205、使用中断方式,每隔一段时间获取擦除单元保持开放或处于已擦除状态的时间;
S206、判断获取的时间是否超过设定的阈值;
若否,则返回S205步骤;
若是,则返回S203步骤。
在SSD正常使用过程中通过时间阈值来实现写前擦保护策略,在安全关机时使用三种写前擦保护策略,在SSD量产和正常使用中实现不出现unclose block擦除单元,保证NAND flash颗粒寿命足够长,保证SSD使用寿命足够长。
具体地,对于上述的S201、S202、S203步骤,与S101步骤、S102步骤以及S103步骤一致,可以参考前述实施例S101步骤、S102步骤以及S103步骤中的对应过程,在此不再赘述。
对于上述的S203步骤至S205步骤而言,在SSD使用过程中也会存在擦除单元长时间保持开放或者已擦除状态的可能性,所以在每次写操作完成时都记录时间Tw,使用中断的方式,每秒都检查擦除单元保持或者已擦除状态时间长度是否超过阈值Tth,若超过了,则需要进行写前擦操作,如果阈值Tth设定过小会导致频繁触发写前擦策略,无效页增多,NAND Flash磨损不均衡;若阈值Tth设定过大会导致擦除单元长时间保持开放或者已擦除状态,则NAND Flash使用寿命简短。若当前的状态时安全关机状态,则只需要执行S201步骤至S203步骤,这与上述的实施例一致,若当前的状态是SSD使用过程,则需要执行S201步骤至S206步骤。
综合考虑了块磨损和擦除单元保持开放或已擦除状态时间,在本实施例中,上述的阈值Tth采用以下公式计算:
其中,Tref表示擦除单元保持开放或处于已擦除状态的时间参考阈值,Twl表示考虑磨损均衡的参考时间阈值,max表示所有擦除单元中擦写次数最大值,min表示所有擦除单元中擦写次数最小值,kε是表示SSD系统响应能力的常数。
kε越小,系统平均响应时间越短,磨损越不均衡,当max和min相等时,磨损均衡,a为0,不需要考虑磨损均衡因素;否则同时考虑磨损均衡和写前擦策略,因此,在本实施例中,最优选地,a=0,既实现写前擦目标回收快效率,且保证块磨损均衡。
上述的实现写入前擦除的方法,通过在SMT时向NAND Flash中写入出厂坏块表和固件,设置写入前擦除的前提要求,不进行全盘擦除操作;在写入数据时记录写入点,安全关机时根据写入点使用快速填充命令、数据搬移到SLC区域和填充仿造的数据的写前操作,在SSD使用过程中,通过时间阈值判断执行写前擦操作,实现保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NAND flash寿命缩减以及SSD使用寿命减少的现象发生。
请参阅图7,图7是一具体实施例提供的实现写入前擦除的装置的示意性框图,如图7所示,实现写入前擦除的装置,其包括写入单元101、记录单元102以及写前擦处理单元103。
写入单元101,用于在SMT时向NAND Flash中写入出厂坏块表和固件。
记录单元102,用于记录写入点以及相关信息。
写前擦处理单元103,用于根据记录的写入点以及相关信息进行数据的写前擦处理。
请参阅图8,上述的写入单元101包括模式写入模块1011、测试模块1012以及擦除处理模块1013。
模式写入模块1011,用于进行硬件自检,扫描出厂坏块,下载BIST程序,并向擦除单元0\1写入模式。
测试模块1012,用于进行硬件自检,进行全盘读写擦测试,并对测试结果进行统计。
擦除处理模块1013,用于进行硬件自检,检查全盘读写擦测试结果,并上传至主机,检查擦除单元0\1中的模式、擦除Nor flash中的BIST程序,并向Nor flash写入BootLoader,向NAND flash写入固件。
请参阅图9,上述的写前擦处理单元103包括状态判断模块1031、快速填充模块1032、写入点判断模块1033、搬移模块1034、擦除模块1035、随机填充模块1036以及仿造填充模块1037。
状态判断模块1031,用于根据记录的写入点以及相关信息判断擦除单元是否为刚结束擦除的单元。
快速填充模块1032,用于若是,则使用快速填充命令对该单元进行随机数填充。
写入点判断模块1033,用于若否,则判断记录的写入点是否小于阈值。
搬移模块1034,用于若是,则将TLC区域中的数据搬移至SLC区域内。
擦除模块1035,用于擦除TLC擦除单元。
随机填充模块1036,用于使用快速填充命令进行随机数填充TLC擦除单元。
仿造填充模块1037,用于若否,则对开放状态的TLC擦除单元填充仿造的数据。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,上述描述的实现写入前擦除的装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
另外,请参阅图10,上述的实现写入前擦除的装置包括写入单元201、记录单元202、写前擦处理单元203、时间记录单元204、时间获取单元205以及时间阈值判断单元206。
写入单元201,用于在SMT时向NAND Flash中写入出厂坏块表和固件。
记录单元202,用于记录写入点以及相关信息。
写前擦处理单元203,用于根据记录的写入点以及相关信息进行数据的写前擦处理。
时间记录单元204,在SSD使用过程中,记录每次写操作完成时的时间。
时间获取单元205,使用中断方式,每隔一段时间获取擦除单元保持开放或处于已擦除状态的时间。
时间阈值判断单元206,判断获取的时间是否超过设定的阈值。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,上述描述的实现写入前擦除的装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
上述实现写入前擦除的装置可以实现为一种计算机程序的形式,计算机程序可以在如图11所示的计算机设备上运行。
上述的实现写入前擦除的装置,通过在SMT时向NAND Flash中写入出厂坏块表和固件,设置写入前擦除的前提要求,不进行全盘擦除操作;在写入数据时记录写入点,安全关机时根据写入点使用快速填充命令、数据搬移到SLC区域和填充仿造的数据的写前操作,在SSD使用过程中,通过时间阈值判断执行写前擦操作,实现保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NAND flash寿命缩减以及SSD使用寿命减少的现象发生。
请参阅图8,图8是本申请实施例提供的一种计算机设备的示意性框图。该计算机设备700设备可以是终端或服务器。
参照图8,该计算机设备700包括通过系统总线710连接的处理器720、存储器和网络接口750,其中,存储器可以包括非易失性存储介质730和内存储器740。
该非易失性存储介质730可存储操作系统731和计算机程序732。该计算机程序732被执行时,可使得处理器720执行任意一种实现写入前擦除方法。
该处理器720用于提供计算和控制能力,支撑整个计算机设备700的运行。
该内存储器740为非易失性存储介质730中的计算机程序732的运行提供环境,该计算机程序732被处理器720执行时,可使得处理器720执行任意一种实现写入前擦除方法。
该网络接口750用于进行网络通信,如发送分配的任务等。本领域技术人员可以理解,图8中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的计算机设备700的限定,具体的计算机设备700可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。其中,所述处理器720用于运行存储在存储器中的程序代码,以实现以下步骤:
在SMT时向NAND Flash中写入出厂坏块表和固件;
记录写入点以及相关信息;
根据记录的写入点以及相关信息进行数据的写前擦处理。
在一实施例中,所述在安全关机时根据记录的写入点以及相关信息进行数据的写前擦处理的步骤之后,还包括:在SSD使用过程中,记录每次写操作完成时的时间;使用中断方式,每隔一段时间获取擦除单元保持开放或处于已擦除状态的时间;判断获取的时间是否超过设定的阈值;若否,则返回所述使用中断方式,每隔一段时间获取擦除单元保持开放或处于已擦除状态的时间的步骤;以及若是,则返回根据记录的写入点以及相关信息进行数据的写前擦处理。
在一实施例中,所述判断获取的时间是否超过设定的阈值中,所述阈值Tth采用以下公式计算:其中,Tref表示擦除单元保持开放或处于已擦除状态的时间参考阈值,Twl表示考虑磨损均衡的参考时间阈值,max表示所有擦除单元中擦写次数最大值,min表示所有擦除单元中擦写次数最小值,kε是表示SSD系统响应能力的常数。
在一实施例中,所述在SMT时向NAND Flash中写入出厂坏块表和固件,包括进行硬件自检,扫描出厂坏块,下载BIST程序,并向擦除单元0\1写入模式;进行硬件自检,进行全盘读写擦测试,并对测试结果进行统计;以及进行硬件自检,检查全盘读写擦测试结果,并上传至主机,检查擦除单元0\1中的模式、擦除Nor flash中的BIST程序,并向Nor flash写入BootLoader,向NAND flash写入固件。
在一实施例中,所述根据记录的写入点以及相关信息进行数据的写前擦处理,包括:根据记录的写入点以及相关信息判断擦除单元是否为刚结束擦除的单元;若是,则使用快速填充命令对该单元进行随机数填充;若否,则判断记录的写入点是否小于阈值;若是,则将TLC区域中的数据搬移至SLC区域内;擦除TLC擦除单元;使用快速填充命令进行随机数填充TLC擦除单元;以及若否,则对开放状态的TLC擦除单元填充仿造的数据。
在一实施例中,所述记录写入点以及相关信息中,所述相关信息包括每个计划正在操作的擦除单元的标志以及最后一次操作的时间。
应当理解,在本申请实施例中,处理器720可以是中央处理单元(CentralProcessing Unit,CPU),该处理器720还可以是其他通用处理器、数字信号处理器(DigitalSignal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
本领域技术人员可以理解,图8中示出的计算机设备700结构并不构成对计算机设备700的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
上述的计算机设备,通过在SMT时向NAND Flash中写入出厂坏块表和固件,设置写入前擦除的前提要求,不进行全盘擦除操作;在写入数据时记录写入点,安全关机时根据写入点使用快速填充命令、数据搬移到SLC区域和填充仿造的数据的写前操作,在SSD使用过程中,通过时间阈值判断执行写前擦操作,实现保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NAND flash寿命缩减以及SSD使用寿命减少的现象发生。
另外,还提供了一种存储介质,所述存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时使所述处理器执行前述的实现写入前擦除的方法。
上述的存储介质,通过在SMT时向NAND Flash中写入出厂坏块表和固件,设置写入前擦除的前提要求,不进行全盘擦除操作;在写入数据时记录写入点,安全关机时根据写入点使用快速填充命令、数据搬移到SLC区域和填充仿造的数据的写前操作,在SSD使用过程中,通过时间阈值判断执行写前擦操作,实现保证SSD的擦除单元不会长时间保持擦除状态,避免造成写放大增加和NAND flash寿命缩减以及SSD使用寿命减少的现象发生。
上述仅以实施例来进一步说明本发明的技术内容,以便于读者更容易理解,但不代表本发明的实施方式仅限于此,任何依本发明所做的技术延伸或再创造,均受本发明的保护。本发明的保护范围以权利要求书为准。
Claims (10)
1.实现写入前擦除的方法,其特征在于,所述方法包括:
在SMT时向NAND Flash中写入出厂坏块表和固件;
记录写入点以及相关信息;
根据记录的写入点以及相关信息进行数据的写前擦处理。
2.根据权利要求1所述的实现写入前擦除的方法,其特征在于,在SMT时向NAND Flash中写入出厂坏块表和固件的步骤,包括以下具体步骤:
进行硬件自检,扫描出厂坏块,下载BIST程序,并向擦除单元0\1写入模式;
进行硬件自检,进行全盘读写擦测试,并对测试结果进行统计;
进行硬件自检,检查全盘读写擦测试结果,并上传至主机,检查擦除单元0\1中的模式、擦除Nor flash中的BIST程序,并向Nor flash写入BootLoader,向NAND flash写入固件。
3.根据权利要求所1述的实现写入前擦除的方法,其特征在于,记录写入点以及相关信息的步骤中,所述相关信息包括每个计划正在操作的擦除单元的标志以及最后一次操作的时间。
4.根据权利要求1至3任一项所述的实现写入前擦除的方法,其特征在于,根据记录的写入点以及相关信息进行数据的写前擦处理的步骤,包括以下具体步骤:
根据记录的写入点以及相关信息判断擦除单元是否为刚结束擦除的单元;
若是,则使用快速填充命令对该单元进行随机数填充;
若否,则判断记录的写入点是否小于阈值;
若是,则将TLC区域中的数据搬移至SLC区域内;
擦除TLC擦除单元;
使用快速填充命令进行随机数填充TLC擦除单元;
若否,则对开放状态的TLC擦除单元填充仿造的数据。
5.根据权利要求1所述的实现写入前擦除的方法,其特征在于,在安全关机时根据记录的写入点以及相关信息进行数据的写前擦处理的步骤之后,还包括:
在SSD使用过程中,记录每次写操作完成时的时间;
使用中断方式,每隔一段时间获取擦除单元保持开放或处于已擦除状态的时间;
判断获取的时间是否超过设定的阈值;
若否,则返回所述使用中断方式,每隔一段时间获取擦除单元保持开放或处于已擦除状态的时间的步骤;
若是,则返回根据记录的写入点以及相关信息进行数据的写前擦处理的步骤。
6.根据权利要求5所述的实现写入前擦除的方法,其特征在于,所述判断获取的时间是否超过设定的阈值的步骤中,所述阈值Tth采用以下公式计算:其中,Tref表示擦除单元保持开放或处于已擦除状态的时间参考阈值,Twl表示考虑磨损均衡的参考时间阈值,max表示所有擦除单元中擦写次数最大值,min表示所有擦除单元中擦写次数最小值,kε是表示SSD系统响应能力的常数。
7.实现写入前擦除的装置,其特征在于,包括写入单元、记录单元以及写前擦处理单元;
所述写入单元,用于在SMT时向NAND Flash中写入出厂坏块表和固件;
所述记录单元,用于记录写入点以及相关信息;
所述写前擦处理单元,用于根据记录的写入点以及相关信息进行数据的写前擦处理。
8.根据权利要求7所述的实现写入前擦除的装置,其特征在于,所述写入单元包括模式写入模块、测试模块以及擦除处理模块;
所述模式写入模块,用于进行硬件自检,扫描出厂坏块,下载BIST程序,并向擦除单元0\1写入模式;
所述测试模块,用于进行硬件自检,进行全盘读写擦测试,并对测试结果进行统计;
所述擦除处理模块,用于进行硬件自检,检查全盘读写擦测试结果,并上传至主机,检查擦除单元0\1中的模式、擦除Nor flash中的BIST程序,并向Nor flash写入BootLoader,向NAND flash写入固件。
9.一种计算机设备,其特征在于,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如权利要求1至6中任意一项所述的实现写入前擦除的方法。
10.一种存储介质,其特征在于,所述存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时使所述处理器执行如权利要求1至6任意一项所述的实现写入前擦除的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810508531.XA CN110534151B (zh) | 2018-05-24 | 2018-05-24 | 实现写入前擦除的方法、装置、计算机设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810508531.XA CN110534151B (zh) | 2018-05-24 | 2018-05-24 | 实现写入前擦除的方法、装置、计算机设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110534151A true CN110534151A (zh) | 2019-12-03 |
CN110534151B CN110534151B (zh) | 2021-06-08 |
Family
ID=68657143
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810508531.XA Active CN110534151B (zh) | 2018-05-24 | 2018-05-24 | 实现写入前擦除的方法、装置、计算机设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110534151B (zh) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112908390A (zh) * | 2021-02-02 | 2021-06-04 | 深圳市显控科技股份有限公司 | 数据存储方法、装置、电子设备及存储介质 |
CN113421606A (zh) * | 2021-07-08 | 2021-09-21 | 成都盛芯微科技有限公司 | flash检测方法及其检测系统 |
CN113885899A (zh) * | 2021-10-25 | 2022-01-04 | 苏州浪潮智能科技有限公司 | 一种固态硬盘固件烧录方法、装置、设备和存储介质 |
CN114063906A (zh) * | 2021-10-15 | 2022-02-18 | 北京得瑞领新科技有限公司 | Nand闪存中物理块的管理方法、装置及ssd设备 |
CN116880782A (zh) * | 2023-09-08 | 2023-10-13 | 合肥康芯威存储技术有限公司 | 一种内嵌式存储器及其测试方法 |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1833229A (zh) * | 2003-08-06 | 2006-09-13 | 松下电器产业株式会社 | 半导体存储卡、存取装置和存取方法 |
CN102122531A (zh) * | 2011-01-27 | 2011-07-13 | 浪潮电子信息产业股份有限公司 | 一种提高大容量固态硬盘使用稳定性的方法 |
US8255619B2 (en) * | 2007-12-20 | 2012-08-28 | Unity Semiconductor Corporation | Memory device with vertically embedded non flash non volatile memory for emulation of NAND flash memory |
CN103198166A (zh) * | 2013-04-16 | 2013-07-10 | 电子科技大学 | 一种井下大容量随钻声波测井数据实时存储装置 |
CN104657295A (zh) * | 2013-11-21 | 2015-05-27 | 三星电子株式会社 | 用于控制非易失性存储器的写速度的系统和方法 |
CN104951404A (zh) * | 2014-03-26 | 2015-09-30 | 三星电子株式会社 | 操作存储器系统的非易失性存储器的方法 |
US9620227B1 (en) * | 2016-01-08 | 2017-04-11 | Western Digital Technologies, Inc. | Characterizing and operating a non-volatile memory device |
US20170123673A1 (en) * | 2010-02-10 | 2017-05-04 | Kabushiki Kaisha Toshiba | Memory system |
CN107506138A (zh) * | 2017-08-11 | 2017-12-22 | 东莞记忆存储科技有限公司 | 一种固态硬盘提升寿命的方法 |
-
2018
- 2018-05-24 CN CN201810508531.XA patent/CN110534151B/zh active Active
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1833229A (zh) * | 2003-08-06 | 2006-09-13 | 松下电器产业株式会社 | 半导体存储卡、存取装置和存取方法 |
US8255619B2 (en) * | 2007-12-20 | 2012-08-28 | Unity Semiconductor Corporation | Memory device with vertically embedded non flash non volatile memory for emulation of NAND flash memory |
US20170123673A1 (en) * | 2010-02-10 | 2017-05-04 | Kabushiki Kaisha Toshiba | Memory system |
CN102122531A (zh) * | 2011-01-27 | 2011-07-13 | 浪潮电子信息产业股份有限公司 | 一种提高大容量固态硬盘使用稳定性的方法 |
CN103198166A (zh) * | 2013-04-16 | 2013-07-10 | 电子科技大学 | 一种井下大容量随钻声波测井数据实时存储装置 |
CN104657295A (zh) * | 2013-11-21 | 2015-05-27 | 三星电子株式会社 | 用于控制非易失性存储器的写速度的系统和方法 |
CN104951404A (zh) * | 2014-03-26 | 2015-09-30 | 三星电子株式会社 | 操作存储器系统的非易失性存储器的方法 |
US9620227B1 (en) * | 2016-01-08 | 2017-04-11 | Western Digital Technologies, Inc. | Characterizing and operating a non-volatile memory device |
CN107506138A (zh) * | 2017-08-11 | 2017-12-22 | 东莞记忆存储科技有限公司 | 一种固态硬盘提升寿命的方法 |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112908390A (zh) * | 2021-02-02 | 2021-06-04 | 深圳市显控科技股份有限公司 | 数据存储方法、装置、电子设备及存储介质 |
CN113421606A (zh) * | 2021-07-08 | 2021-09-21 | 成都盛芯微科技有限公司 | flash检测方法及其检测系统 |
CN114063906A (zh) * | 2021-10-15 | 2022-02-18 | 北京得瑞领新科技有限公司 | Nand闪存中物理块的管理方法、装置及ssd设备 |
CN113885899A (zh) * | 2021-10-25 | 2022-01-04 | 苏州浪潮智能科技有限公司 | 一种固态硬盘固件烧录方法、装置、设备和存储介质 |
CN113885899B (zh) * | 2021-10-25 | 2024-01-12 | 苏州浪潮智能科技有限公司 | 一种固态硬盘固件烧录方法、装置、设备和存储介质 |
CN116880782A (zh) * | 2023-09-08 | 2023-10-13 | 合肥康芯威存储技术有限公司 | 一种内嵌式存储器及其测试方法 |
CN116880782B (zh) * | 2023-09-08 | 2023-12-05 | 合肥康芯威存储技术有限公司 | 一种内嵌式存储器及其测试方法 |
Also Published As
Publication number | Publication date |
---|---|
CN110534151B (zh) | 2021-06-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110534151A (zh) | 实现写入前擦除的方法、装置、计算机设备及存储介质 | |
US8180953B2 (en) | Data accessing method for flash memory, and storage system and controller system thereof | |
CN102063384B (zh) | 一种java卡利用缓存对编程只读存储器进行读写操作的方法 | |
US20120246397A1 (en) | Storage device management device and method for managing storage device | |
CN106294229A (zh) | 串行接口存储器中的同时读取与写入存储器操作 | |
CN113094003B (zh) | 数据处理方法、数据存储装置及电子设备 | |
CN106557432B (zh) | 缓冲存储器管理方法、存储器控制电路单元及存储装置 | |
EP2294579A2 (en) | Nand memory | |
US20150234598A1 (en) | Memory device and host device | |
CN110673789A (zh) | 固态硬盘的元数据存储管理方法、装置、设备及存储介质 | |
CN109753234A (zh) | 存储器系统及非易失性存储器的控制方法 | |
CN109815160A (zh) | 最后写入页搜索 | |
CN102306503A (zh) | 一种假容量存储器的检测方法及系统 | |
CN106469126A (zh) | 处理io请求的方法及其存储控制器 | |
US11138104B2 (en) | Selection of mass storage device streams for garbage collection based on logical saturation | |
CN109542667A (zh) | 一种提高nand闪存数据可靠性的方法及装置 | |
CN111625197A (zh) | 存储器控制方法、存储器存储装置及存储器控制器 | |
CN109656479B (zh) | 一种构建存储器命令序列的方法及装置 | |
CN107544912A (zh) | 一种日志记录方法、加载方法及其装置 | |
US9501397B2 (en) | Data writing method, memory controller, and memory storage apparatus | |
CN105630406B (zh) | 利用mram作为编辑缓存区的存储系统及编辑缓存方法 | |
CN112230849A (zh) | 存储器控制方法、存储器存储装置及存储器控制器 | |
CN111488118B (zh) | 管理闪存模块的方法及相关的闪存控制器与电子装置 | |
US11397676B2 (en) | Computer program product and method and apparatus for managing garbage collection process | |
CN111176573B (zh) | 数据读写方法、装置、存储介质及电子设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |