CN108762669A - 提升掉电时数据写入速度的方法、装置及计算机设备 - Google Patents

提升掉电时数据写入速度的方法、装置及计算机设备 Download PDF

Info

Publication number
CN108762669A
CN108762669A CN201810479638.6A CN201810479638A CN108762669A CN 108762669 A CN108762669 A CN 108762669A CN 201810479638 A CN201810479638 A CN 201810479638A CN 108762669 A CN108762669 A CN 108762669A
Authority
CN
China
Prior art keywords
request
reserved
unit
erasing
power down
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
Application number
CN201810479638.6A
Other languages
English (en)
Other versions
CN108762669B (zh
Inventor
李传业
冯元元
胡中中
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shenzhen Union Memory Information System Co Ltd
Original Assignee
Shenzhen Union Memory Information System Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Shenzhen Union Memory Information System Co Ltd filed Critical Shenzhen Union Memory Information System Co Ltd
Priority to CN201810479638.6A priority Critical patent/CN108762669B/zh
Publication of CN108762669A publication Critical patent/CN108762669A/zh
Application granted granted Critical
Publication of CN108762669B publication Critical patent/CN108762669B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0646Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
    • G06F3/0652Erasing, e.g. deleting, data cleaning, moving of data to a wastebasket
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)

Abstract

本发明涉及提升掉电时数据写入速度的方法、装置及计算机设备,其中,方法包括预留擦除单元,并设置预留的擦除单元处于擦除状态;判断系统是否出现异常掉电状态;若是,则处理NAND Flash的擦除状态;解析请求列队的请求类型,并根据请求类型进行请求处理;获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内。本发明通过预留擦除单元,并对擦除单元设置处于擦除状态,以进入接收数据写入,在系统出现异常掉电时,将需要回收的请求以及需要备份的数据存储在擦除单元内,减少对已写入且正确的数据的影响,提升用户数据写入速度,降低用户数据的丢失。

Description

提升掉电时数据写入速度的方法、装置及计算机设备
技术领域
本发明涉及SSD固态硬盘,更具体地说是指提升掉电时数据写入速度的方法、装置及计算机设备。
背景技术
固态硬盘在实际应用场景中,会发生异常掉电情况。掉电时,固态硬盘系统中可能有缓冲的数据没有写入NAND Flash中;掉电时,NAND Flash端可能正在执行写操作,该写操作的数据不但丢失,还会因为NAND Flash的特性导致写入点附近的数据被破坏。
掉电时,对正在执行的擦除操作会在仲裁后决定是取消还是继续执行;针对后续的写入操作,可能因为没有预留擦除单元而需要做垃圾回收处理,启动擦除操作,耗时较多;掉电时,现有技术在NFC端会对请求做区分处理,优先响应写请求和写请求相关的读请求以及擦除请求,写请求可以是TLC模式写入或者SLC模式写入,写入的区域是正常的用户区域。因为写入的区域是正常的用户区域,存在没有合适的Block写入的情况,导致需要进行垃圾回收,启动Erase操作,耗时较多;以TLC模式写入,因为TLC模式的tPROG较大,导致在备电时间内写入的数据量有限;TLC颗粒存在共享读写单元的现象,后写入数据可能导致先前写入的数据状态改变,造成数据丢失,即不安全的写入。如图1所示,Nand Flash的内部组成如下:其中,DIE代表可独立并发操作的单元;Block代表擦除单元;Page代表读写单元。DIE下的操作是串行化的,即对同一个DIE发起多个操作,必须等前面一个操作完成之后才能执行后面一个操作。同一个擦除单元内的读写单元必须按顺序进行写操作。由于NandFlash的内部构造,当前读写单元的写操作异常可能会对其他已经安全写入数据的读写单元造成影响,以TLC为例,读写单元M和读写单元N及读写单元(N+1)组成共享读写单元,共享NAND单元,且N>M+1,一般N>>M;读写单元M可以单独使用程序,读写单元N和读写单元(N+1)需同时使用程序,且读写单元N/N+1使用程序时会修改共享的NAND Cell的状态,从而影响读写单元M的状态。使用程序完成后,读写单元M/N/(N+1)数据正确,但如果读写单元N/N+1在使用程序时掉电导致写入不成功,不仅读写单元N/N+1的数据错误,读写单元M的数据也被破坏。
目前常见的解决此类问题的方法是固态硬盘硬件设计时引入电容备电。掉电时通过电容短暂的供电能力支撑NAND Flash操作的完成,但是由于掉电点不可控,掉电时刻请求比较多的情况下,依然存在未完成的写操作导致安全写入的数据被破坏的可能性。
因此,有必要设计一种新的数据写入方法,实现保证异常掉电时数据写入的安全可靠,降低用户数据丢失的风险。
发明内容
本发明的目的在于克服现有技术的缺陷,提供提升掉电时数据写入速度的方法、装置及计算机设备。
为实现上述目的,本发明采用以下技术方案:提升掉电时数据写入速度的方法,所述方法包括:
预留擦除单元,并设置预留的擦除单元处于擦除状态;
判断系统是否出现异常掉电状态;
若是,则处理NAND Flash的擦除状态;
解析请求列队的请求类型,并根据请求类型进行请求处理;
获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内。
其进一步技术方案为:预留擦除单元,并设置预留的擦除单元处于擦除状态的步骤,包括以下具体步骤:
预留擦除单元;
将预留的擦除单元分配于不同的CH或者可独立并发操作的单元上;
在颗粒允许的情况下设置预留的擦除单元处于擦除状态。
其进一步技术方案为:判断系统是否出现异常掉电状态的步骤之前,还包括:
获取上次掉电期间需要写入预留的擦除单元内的数据,纳入垃圾回收管理。
其进一步技术方案为:处理NAND Flash的擦除状态的步骤,包括以下具体步骤:
判断系统当前是否在执行擦除操作;
若否,则进入解析请求列队的请求类型,并根据请求类型进行请求处理的步骤;
若是,则判断需要是否终止擦除操作;
若是,则终止擦除操作;
若否,则进入解析请求列队的请求类型,并根据请求类型进行请求处理的步骤。
其进一步技术方案为:解析请求列队的请求类型,并根据请求类型进行请求处理的步骤,包括以下具体步骤:
获取请求列队中的下一个请求;
解析下一个请求的类型;
判断下一个请求是否需要执行;
若否,则对请求标记丢弃状态,并回收请求,返回所述获取请求列队中的下一个请求的步骤;
若是,则判断当前的操作是否可安全执行请求;
若是,则进入获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内的步骤;
若否,则对请求标记丢弃状态,并回收请求,返回所述获取请求列队中的下一个请求的步骤。
本发明还提供了提升掉电时数据写入速度的装置,包括预留单元、掉电判断单元、状态处理单元、请求处理单元以及存储单元;
所述预留单元,用于预留擦除单元,并设置预留的擦除单元处于擦除状态;
所述掉电判断单元,用于判断系统是否出现异常掉电状态;
所述状态处理单元,用于若是,则处理NAND Flash的擦除状态;
所述请求处理单元,用于解析请求列队的请求类型,并根据请求类型进行请求处理;
所述存储单元,用于获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内。
其进一步技术方案为:所述预留单元包括擦拭单元预留模块、分配模块以及设置模块;
所述擦拭单元预留模块,用于预留擦除单元;
所述分配模块,用于将预留的擦除单元分配于不同的CH或者可独立并发操作的单元上;
所述设置模块,用于在颗粒允许的情况下设置预留的擦除单元处于擦除状态。
其进一步技术方案为:所述装置还包括数据获取单元;
所述数据获取单元,用于获取上次掉电期间需要写入预留的擦除单元内的数据,纳入垃圾回收管理。
其进一步技术方案为:所述状态处理单元包括操作判断模块、终止判断模块以及终止模块;
所述操作判断模块,用于判断系统当前是否在执行擦除操作;
所述终止判断模块,用于若是,则判断需要是否终止擦除操作;
所述终止模块,用于若是,则终止擦除操作。
本发明还提供了一种计算机设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述的提升掉电时数据写入速度的方法。
本发明与现有技术相比的有益效果是:本发明的提升掉电时数据写入速度的方法,通过预留擦除单元,并对擦除单元设置处于擦除状态,以进入接收数据写入,在系统出现异常掉电时,将需要回收的请求以及需要备份的数据存储在擦除单元内,减少对已写入且正确的数据的影响,提升用户数据写入速度,降低用户数据的丢失。
下面结合附图和具体实施例对本发明作进一步描述。
附图说明
图1为现有技术中的NAND Flash的示意性框图;
图2为本发明一具体实施例提供的提升掉电时数据写入速度的方法的流程图;
图3为图2中预留擦除单元并设置预留的擦除单元处于擦除状态的流程图;
图4为图2中处理NAND Flash的擦除状态的流程图;
图5为图2中解析请求列队的请求类型并根据请求类型进行请求处理的流程图;
图6为本发明一具体实施例提供的提升掉电时数据写入速度的装置的结构框图;
图7为图6具体实施例中预留单元的结构框图;
图8为图6具体实施例中状态处理单元的结构框图;
图9为本发明一具体实施例提供的一种计算机设备的结构框图。
具体实施方式
为了更充分理解本发明的技术内容,下面结合具体实施例对本发明的技术方案进一步介绍和说明,但不局限于此。
应当理解,当在本说明书和所附权利要求书中使用时,术语“包括”和“包含”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在此本申请说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本申请。如在本申请说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
还应当进一步理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如图2~9所示的具体实施例,本实施例提供的提升掉电时数据写入速度的方法、装置及计算机设备,可以运用在SSD系统掉电时处理数据写入的过程中,还可以用于其他固态存储硬盘掉电过程中,实现保证异常掉电时数据写入的安全可靠,降低用户数据丢失的风险。
如图2所示,本实施例提供了提升掉电时数据写入速度的方法,该方法包括步骤S101~步骤S107。
S101、预留擦除单元,并设置预留的擦除单元处于擦除状态。
具体地,固件系统要预留一部分擦除单元,用于掉电时的紧急写入;因电容备点时间短,在颗粒允许的情况下保证预留擦除单元处于擦除状态。在掉电时以pSLC方式快速写入数据,避免数据丢失。
另外,优选地,固件系统设计时,会带有写入Cache功能,以保证写性能。异常掉电时间点,写入Cache中可能有比较多的用户数据。借助预留的擦除单元,在掉电时以pSLC方式将需要写入的数据写入NAND Flash中,最大程度上降低未完成写操作导致写入数据被破坏的可能性,同时最大程度上降低写入Cache中数据丢失的可能性。
于其他实施例,若已预留了擦除单元,则直接进入S102步骤。
S102、获取上次掉电期间需要写入预留的擦除单元内的数据,纳入垃圾回收管理。
在系统上电时,固件要查看上次掉电期间是否有需要写入预留擦除单元内的数据,将需要写入预留擦除单元内的数据纳入正常的垃圾回收管理,对于垃圾回收管理的数据和回收的请求,FTL会下发请求将这些回收的数据和请求写入到预留的擦除单元内,提升写入速度,保证异常掉电时,数据写入的安全可靠。
以TLC为例,读写单元M和读写单元N及读写单元(N+1)组成共享读写单元,共享NAND单元,且N>M+1,一般N>>M;读写单元M可以单独使用程序,读写单元N和读写单元(N+1)需同时使用程序,且读写单元N/N+1使用程序时会修改共享的NAND Cell的状态,从而影响读写单元M的状态。使用程序完成后,读写单元M/N/(N+1)数据正确,但如果读写单元N/N+1在使用程序时掉电导致写入不成功,FTL会下发请求将读写单元N/N+1的数据以及写入请求写入预留的擦除单元内,避免异常掉电时,造成对读写单元M/N/(N+1)数据的影响。
S103、判断系统是否出现异常掉电状态。
当出现非正常掉电的情况是,系统会获取到异常掉电通知,从而可判断系统是否出现异常掉电的状态。
S104、若是,则处理NAND Flash的擦除状态。
如果Nand Flash端已经处于擦除操作状态,发起通知Nand Flash终止擦除操作的命令,也就是停止各个物理位置的数据写入后在下一次写之前将整个擦除单元的擦除的操作。
S105、解析请求列队的请求类型,并根据请求类型进行请求处理。
在本实施例中,请求列队内会包含有对若干个擦除单元进行数据写入的请求以及擦除等各类型的请求,当某一个写入请求在执行或者即将执行时,遇到掉电的情况,需要判断该请求是否需要执行写入,让需要执行写入的请求且在可安全执行的情况下继续执行,而不需要执行的请求或需要执行却无法安全执行的请求进行回收操作,此处的可安全执行的情况包括电容备电时间允许请求写入的情况。该需要执行写入的请求且在可安全执行的情况下内包括有必须处理的请求,如PD_WRITE类型请求及FTL Read请求等,其中PD_WRITE类型请求为写入预留的擦除单元内的请求,FTL Read请求是读取需要回收的请求以及需要备份的数据的请求。
S106、获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内。
固件系统设计时会带有Write Cache功能,以保证写性能。异常掉电时间点,WriteCache中可能有比较多的用户数据。FTL在收到掉电通知后,检查固件系统中是否有需要备份数据。如果有需要备份数据,则后续下发PD_WRITE请求写入预留的擦除单元内;对回收的请求,如果标记为丢弃且为需要备份数据,也需下发PD_WRITE请求写入预留的擦除单元内。
若系统未出现异常掉电,则S107、将数据写入擦除单元内,并返回S103步骤。
具体地,请参阅图3,上述的S101步骤,预留擦除单元,并设置预留的擦除单元处于擦除状态的步骤,包括以下具体步骤:
S1011、预留擦除单元;
S1012、将预留的擦除单元分配于不同的CH或者可独立并发操作的单元上;
S1013、在颗粒允许的情况下设置预留的擦除单元处于擦除状态。
在系统正常运行期间,保证预留的擦除单元能够容纳固件系统中缓存的用户数据。预留擦除单元要分配在不同的CH/DIE上,以保证写入的并发性,也就是可以同时在不同的CH或者可独立并发操作的单元(DIE)上写入需要备份的数据和需要回收的请求,提升写入的速度。
具体地,请参阅图4,上述的S104步骤,处理NAND Flash的擦除状态的步骤,包括以下具体步骤:
S1041、判断系统当前是否在执行擦除操作;
若否,则进入S105步骤;
S1042、若是,则判断需要是否终止擦除操作;
S1043、若是,则终止擦除操作;
若否,则进入S105步骤。
如果Nand Flash端已经处于擦除操作状态,发起通知Nand Flash终止擦除操作的命令。
另外,请参阅图5,上述的S105步骤,解析请求列队的请求类型,并根据请求类型进行请求处理的步骤,包括以下具体步骤:
S1051、获取请求列队中的下一个请求;
S1052、解析下一个请求的类型;
S1053、判断下一个请求是否需要执行;
S1054、若否,则对请求标记丢弃状态,并回收请求,返回S1051步骤;
S1055、若是,则判断当前的操作是否可安全执行请求;
若是,则进入S106步骤;
若否,则返回S1054步骤。
解析请求队列中的请求类型,区分出必须处理的请求,必须处理请求放行,否则标记丢弃状态返回给FTL,必须处理的请求包括PD_WRITE类型请求,及FTL Read请求。
把SSD系统的用户数据写入使用预留的SLC擦除单元,提升写入速度,保证异常掉电时,数据写入的安全可靠,用户数据丢失的风险大大降低。
上述的提升掉电时数据写入速度的方法,通过预留擦除单元,并对擦除单元设置处于擦除状态,以进入接收数据写入,在系统出现异常掉电时,将需要回收的请求以及需要备份的数据存储在擦除单元内,减少对已写入且正确的数据的影响,提升用户数据写入速度,降低用户数据的丢失。
请参阅图6,图6是本申请实施例提供的提升掉电时数据写入速度的装置的示意性框图。如图6所示,该装置包括预留单元1、掉电判断单元3、状态处理单元4、请求处理单元5以及存储单元6。
预留单元1,用于预留擦除单元,并设置预留的擦除单元处于擦除状态。
掉电判断单元3,用于判断系统是否出现异常掉电状态。
状态处理单元4,用于若是,则处理NAND Flash的擦除状态。
请求处理单元5,用于解析请求列队的请求类型,并根据请求类型进行请求处理。
存储单元6,用于获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内。
请参阅图7,具体地,上述的预留单元1包括擦拭单元预留模块11、分配模块12以及设置模块13。
擦拭单元预留模块11,用于预留擦除单元。
分配模块12,用于将预留的擦除单元分配于不同的CH或者可独立并发操作的单元上。
设置模块13,用于在颗粒允许的情况下设置预留的擦除单元处于擦除状态。
请参照图6,上述的装置还包括数据获取单元2。
数据获取单元2,用于获取上次掉电期间需要写入预留的擦除单元内的数据,纳入垃圾回收管理。
请参照图8,相应地,上述的状态处理单元4包括操作判断模块41、终止判断模块42以及终止模块43。
操作判断模块41,用于判断系统当前是否在执行擦除操作。
终止判断模块42,用于若是,则判断需要是否终止擦除操作。
终止模块43,用于若是,则终止擦除操作。
另外,上述的请求处理单元5还包括请求获取模块、解析模块、执行判断模块、丢弃模块以及安全判断模块。
请求获取模块,用于获取请求列队中的下一个请求。
解析模块,用于解析下一个请求的类型。
执行判断模块,用于判断下一个请求是否需要执行。
丢弃模块,用于若否,则对请求标记丢弃状态,并回收请求。
安全判断模块,用于若是,则判断当前的操作是否可安全执行请求。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,上述描述的提升掉电时数据写入速度装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
上述的提升掉电时数据写入速度的装置可以实现为一种计算机程序的形式,计算机程序可以在如图9所示的计算机设备上运行。
上述的提升掉电时数据写入速度的装置,通过预留擦除单元,并对擦除单元设置处于擦除状态,以进入接收数据写入,在系统出现异常掉电时,将需要回收的请求以及需要备份的数据存储在擦除单元内,减少对已写入且正确的数据的影响,提升用户数据写入速度,降低用户数据的丢失。
请参阅图9,图9是本申请实施例提供的一种计算机设备的示意性框图。该计算机设备700设备可以是终端或服务器。
参照图9,该计算机设备700包括通过系统总线710连接的处理器720、存储器和网络接口750,其中,存储器可以包括非易失性存储介质730和内存储器740。
该非易失性存储介质730可存储操作系统731和计算机程序732。该计算机程序732被执行时,可使得处理器720执行任意一种提升掉电时数据写入速度的方法。
该处理器720用于提供计算和控制能力,支撑整个计算机设备700的运行。
该内存储器740为非易失性存储介质730中的计算机程序732的运行提供环境,该计算机程序732被处理器720执行时,可使得处理器720执行任意一种提升掉电时数据写入速度的方法。
该网络接口750用于进行网络通信,如发送分配的任务等。本领域技术人员可以理解,图9中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的计算机设备700的限定,具体的计算机设备700可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。其中,所述处理器720用于运行存储在存储器中的程序代码,以实现以下步骤:
预留擦除单元,并设置预留的擦除单元处于擦除状态;
判断系统是否出现异常掉电状态;
若是,则处理NAND Flash的擦除状态;
解析请求列队的请求类型,并根据请求类型进行请求处理;
获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内。
在一实施例中,所述处理器720用于判断系统是否出现异常掉电状态之前,还实现以下步骤:
获取上次掉电期间需要写入预留的擦除单元内的数据,纳入垃圾回收管理。
其中,所述预留擦除单元,并设置预留的擦除单元处于擦除状态,包括:
预留擦除单元;以及将预留的擦除单元分配于不同的CH或者可独立并发操作的单元上;以及在颗粒允许的情况下设置预留的擦除单元处于擦除状态。
所述处理NAND Flash的擦除状态,包括:
判断系统当前是否在执行擦除操作;以及若否,则进入解析请求列队的请求类型,并根据请求类型进行请求处理;以及若是,则判断需要是否终止擦除操作;以及若是,则终止擦除操作;以及若否,则进入解析请求列队的请求类型,并根据请求类型进行请求处理的步骤。
另外,所述解析请求列队的请求类型,并根据请求类型进行请求处理,包括:获取请求列队中的下一个请求;以及解析下一个请求的类型;以及判断下一个请求是否需要执行;以及若否,则对请求标记丢弃状态,并回收请求,返回所述获取请求列队中的下一个请求的步骤;以及若是,则判断当前的操作是否可安全执行请求;以及若是,则进入获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内的步骤;以及若否,则对请求标记丢弃状态,并回收请求,返回所述获取请求列队中的下一个请求的步骤。
应当理解,在本申请实施例中,处理器720可以是中央处理单元(CentralProcessing Unit,CPU),该处理器720还可以是其他通用处理器、数字信号处理器(DigitalSignal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
本领域技术人员可以理解,图9中示出的计算机设备700结构并不构成对计算机设备700的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
上述的一种计算机设备,通过预留擦除单元,并对擦除单元设置处于擦除状态,以进入接收数据写入,在系统出现异常掉电时,将需要回收的请求以及需要备份的数据存储在擦除单元内,减少对已写入且正确的数据的影响,提升用户数据写入速度,降低用户数据的丢失。
上述仅以实施例来进一步说明本发明的技术内容,以便于读者更容易理解,但不代表本发明的实施方式仅限于此,任何依本发明所做的技术延伸或再创造,均受本发明的保护。本发明的保护范围以权利要求书为准。

Claims (10)

1.提升掉电时数据写入速度的方法,其特征在于,所述方法包括:
预留擦除单元,并设置预留的擦除单元处于擦除状态;
判断系统是否出现异常掉电状态;
若是,则处理NAND Flash的擦除状态;
解析请求列队的请求类型,并根据请求类型进行请求处理;
获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内。
2.根据权利要求1所述的提升掉电时数据写入速度的方法,其特征在于,预留擦除单元,并设置预留的擦除单元处于擦除状态的步骤,包括以下具体步骤:
预留擦除单元;
将预留的擦除单元分配于不同的CH或者可独立并发操作的单元上;
在颗粒允许的情况下设置预留的擦除单元处于擦除状态。
3.根据权利要求1所述的提升掉电时数据写入速度的方法,其特征在于,判断系统是否出现异常掉电状态的步骤之前,还包括:
获取上次掉电期间需要写入预留的擦除单元内的数据,纳入垃圾回收管理。
4.根据权利要求1至3任一项所述的提升掉电时数据写入速度的方法,其特征在于,处理NAND Flash的擦除状态的步骤,包括以下具体步骤:
判断系统当前是否在执行擦除操作;
若否,则进入解析请求列队的请求类型,并根据请求类型进行请求处理的步骤;
若是,则判断需要是否终止擦除操作;
若是,则终止擦除操作;
若否,则进入解析请求列队的请求类型,并根据请求类型进行请求处理的步骤。
5.根据权利要求4所述的提升掉电时数据写入速度的方法,其特征在于,解析请求列队的请求类型,并根据请求类型进行请求处理的步骤,包括以下具体步骤:
获取请求列队中的下一个请求;
解析下一个请求的类型;
判断下一个请求是否需要执行;
若否,则对请求标记丢弃状态,并回收请求,返回所述获取请求列队中的下一个请求的步骤;
若是,则判断当前的操作是否可安全执行请求;
若是,则进入获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内的步骤;
若否,则对请求标记丢弃状态,并回收请求,返回所述获取请求列队中的下一个请求的步骤。
6.提升掉电时数据写入速度的装置,其特征在于,包括预留单元、掉电判断单元、状态处理单元、请求处理单元以及存储单元;
所述预留单元,用于预留擦除单元,并设置预留的擦除单元处于擦除状态;
所述掉电判断单元,用于判断系统是否出现异常掉电状态;
所述状态处理单元,用于若是,则处理NAND Flash的擦除状态;
所述请求处理单元,用于解析请求列队的请求类型,并根据请求类型进行请求处理;
所述存储单元,用于获取需要备份的数据以及需要回收的请求,存储于预留的擦除单元内。
7.根据权利要求6所述的提升掉电时数据写入速度的装置,其特征在于,所述预留单元包括擦拭单元预留模块、分配模块以及设置模块;
所述擦拭单元预留模块,用于预留擦除单元;
所述分配模块,用于将预留的擦除单元分配于不同的CH或者可独立并发操作的单元上;
所述设置模块,用于在颗粒允许的情况下设置预留的擦除单元处于擦除状态。
8.根据权利要求7所述的提升掉电时数据写入速度的装置,其特征在于,所述装置还包括数据获取单元;
所述数据获取单元,用于获取上次掉电期间需要写入预留的擦除单元内的数据,纳入垃圾回收管理。
9.根据权利要求8所述的提升掉电时数据写入速度的装置,其特征在于,所述状态处理单元包括操作判断模块、终止判断模块以及终止模块;
所述操作判断模块,用于判断系统当前是否在执行擦除操作;
所述终止判断模块,用于若是,则判断需要是否终止擦除操作;
所述终止模块,用于若是,则终止擦除操作。
10.一种计算机设备,其特征在于,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如权利要求1至5中任意一项所述的提升掉电时数据写入速度的方法。
CN201810479638.6A 2018-05-18 2018-05-18 提升掉电时数据写入速度的方法、装置及计算机设备 Active CN108762669B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810479638.6A CN108762669B (zh) 2018-05-18 2018-05-18 提升掉电时数据写入速度的方法、装置及计算机设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810479638.6A CN108762669B (zh) 2018-05-18 2018-05-18 提升掉电时数据写入速度的方法、装置及计算机设备

Publications (2)

Publication Number Publication Date
CN108762669A true CN108762669A (zh) 2018-11-06
CN108762669B CN108762669B (zh) 2021-03-05

Family

ID=64007276

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810479638.6A Active CN108762669B (zh) 2018-05-18 2018-05-18 提升掉电时数据写入速度的方法、装置及计算机设备

Country Status (1)

Country Link
CN (1) CN108762669B (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112947848A (zh) * 2019-12-11 2021-06-11 慧荣科技股份有限公司 分层异构储存的数据中心
TWI741296B (zh) * 2019-05-21 2021-10-01 慧榮科技股份有限公司 瞬間斷電回復處理方法及裝置以及電腦程式產品
US11803330B2 (en) 2019-05-21 2023-10-31 Silicon Motion, Inc. Method and apparatus and computer-readable storage medium for handling sudden power off recovery
TWI820473B (zh) * 2019-05-21 2023-11-01 慧榮科技股份有限公司 瞬間斷電回復處理方法及裝置以及電腦程式產品

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040202024A1 (en) * 2003-04-08 2004-10-14 Renesas Technology Corp. Memory card
CN101819509A (zh) * 2010-04-19 2010-09-01 清华大学深圳研究生院 一种固态硬盘读写方法
CN102004706A (zh) * 2009-09-01 2011-04-06 联芯科技有限公司 一种基于ftl的闪存擦写掉电保护方法
CN103631677A (zh) * 2013-11-27 2014-03-12 上海电器科学研究院 一种plc设备数据掉电保持的方法
CN105138432A (zh) * 2015-08-31 2015-12-09 深圳市瑞耐斯技术有限公司 一种异常断电时固态硬盘数据快速备份的方法及系统
CN107329912A (zh) * 2017-07-04 2017-11-07 济南浪潮高新科技投资发展有限公司 一种nand flash阵列的掉电处理方法
CN108009101A (zh) * 2017-11-30 2018-05-08 郑州云海信息技术有限公司 一种固态硬盘异常掉电处理方法、系统、介质及设备

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040202024A1 (en) * 2003-04-08 2004-10-14 Renesas Technology Corp. Memory card
CN102004706A (zh) * 2009-09-01 2011-04-06 联芯科技有限公司 一种基于ftl的闪存擦写掉电保护方法
CN101819509A (zh) * 2010-04-19 2010-09-01 清华大学深圳研究生院 一种固态硬盘读写方法
CN103631677A (zh) * 2013-11-27 2014-03-12 上海电器科学研究院 一种plc设备数据掉电保持的方法
CN105138432A (zh) * 2015-08-31 2015-12-09 深圳市瑞耐斯技术有限公司 一种异常断电时固态硬盘数据快速备份的方法及系统
CN107329912A (zh) * 2017-07-04 2017-11-07 济南浪潮高新科技投资发展有限公司 一种nand flash阵列的掉电处理方法
CN108009101A (zh) * 2017-11-30 2018-05-08 郑州云海信息技术有限公司 一种固态硬盘异常掉电处理方法、系统、介质及设备

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
SHUHEI TANAKAMARU ET AL.: "Performance and reliability of NAND flash/SCM hybrid SSD during write/erase cycling", 《IEEE XPLORE》 *
杨凯 等: "一种降低DRAM系统刷新功耗的混合主存设计", 《复旦学报(自然科学版)》 *

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TWI741296B (zh) * 2019-05-21 2021-10-01 慧榮科技股份有限公司 瞬間斷電回復處理方法及裝置以及電腦程式產品
US11803330B2 (en) 2019-05-21 2023-10-31 Silicon Motion, Inc. Method and apparatus and computer-readable storage medium for handling sudden power off recovery
TWI820473B (zh) * 2019-05-21 2023-11-01 慧榮科技股份有限公司 瞬間斷電回復處理方法及裝置以及電腦程式產品
CN112947848A (zh) * 2019-12-11 2021-06-11 慧荣科技股份有限公司 分层异构储存的数据中心
CN112947848B (zh) * 2019-12-11 2023-11-07 慧荣科技股份有限公司 分层异构储存的数据中心

Also Published As

Publication number Publication date
CN108762669B (zh) 2021-03-05

Similar Documents

Publication Publication Date Title
CN108762669A (zh) 提升掉电时数据写入速度的方法、装置及计算机设备
CN103970688B (zh) 缩短数据存储系统中写入等待时间的方法和系统
CN103218274B (zh) 一种预防故障累加的方法和固态硬盘
US8392649B2 (en) Memory storage device, controller, and method for responding to host write commands triggering data movement
CN102135927B (zh) 一种基于nand flash的系统引导方法和装置
US10324645B2 (en) Data storage device and data storage method thereof
US20100287217A1 (en) Host control of background garbage collection in a data storage device
EP2249243A1 (en) Backup method, disc array device, and controller
CN104641313A (zh) 管理和撤销通过总线接口分配的功率
CN102301345A (zh) 混合存储设备
CN101918913A (zh) 自动精简配置存储设备上的存储收回
CN108710583A (zh) Ssd写缓存区的管理方法、装置、计算机设备及介质
CN110968524B (zh) 数据存储控制方法、装置、存储介质及电子装置
CN109062825A (zh) 一种固态硬盘异常掉电的保护方法及装置
TW201235832A (en) Drive assisted system checkpointing
CN106844108A (zh) 一种数据存储方法、服务器以及存储系统
CN106293497B (zh) 瓦记录感知文件系统中垃圾数据的回收方法和装置
CN110275800A (zh) Ssd数据物理备份方法、装置、计算机设备及存储介质
CN108008917A (zh) 存储设备及控制其链接状态的方法
CN108874574A (zh) 一种垃圾回收处理方法及相关装置
CN102486757B (zh) 存储器储存装置及其存储器控制器与回应主机指令的方法
CN111176559B (zh) 数据写入方法及装置、双活系统
CN109542491A (zh) 后台固件更新
CN106776142B (zh) 一种数据存储方法以及数据存储装置
CN103064762B (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