CN106776110A - 一种用于固态存储读策略的控制方法 - Google Patents
一种用于固态存储读策略的控制方法 Download PDFInfo
- Publication number
- CN106776110A CN106776110A CN201611247494.9A CN201611247494A CN106776110A CN 106776110 A CN106776110 A CN 106776110A CN 201611247494 A CN201611247494 A CN 201611247494A CN 106776110 A CN106776110 A CN 106776110A
- Authority
- CN
- China
- Prior art keywords
- raid
- data
- solid
- control method
- state storage
- 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.)
- Pending
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
- G06F11/1076—Parity data used in redundant arrays of independent storages, e.g. in RAID systems
Abstract
本发明公开了一种用于固态存储读策略的控制方法,其特征在于:在固态存储设备中加入RAID的算法控制器,当数据经过控制器发向NAND介质时,会产生RAID code保存在NAND介质中,在数据产生UNECC时,固件不对数据进行重复读取,不进行ECC侦错尝试,而是直接通过硬件启动RAID模块,根据进行RAID算法的用户数据和RAID code将出错数据进行恢复。它是一种高效的读策略的控制方法,通过固件和硬件结合的方式,可以快速解决NAND数据UNECC的问题。
Description
技术领域
本发明涉及电子技术领域,尤其涉及一种用于固态存储读策略的控制方法。
背景技术
目前,NAND flash由于其大容量,低价格而广泛应用于固态存储领域,但是,又由于NAND介质的一些操作特点,例如基于block的擦除,按物理page写入,按物理page读出数据,在这些特点之上引入了block擦除,page写入以及page读取的latency等问题。
同时,NAND由于其工艺的原因,随着介质使用寿命的增加,在数据读取时,会存在出现一定的错误概率,并且擦除和写入次数越多,读数据出错的概率越大。因此,为了解决NAND介质读出错的问题,使用过程中引入了ECC,即错误纠正码。所谓错误纠正码是在数据写入NAND的过程中,NAND控制器会在数据的后面加入一部分ECC码,当用户数据出错时,控制器的纠错模块会根据ECC码对数据就行纠错。一款固态存储的设计,其ECC纠错能力在其设计之初,其纠错能力即根据ECC码最多可以纠正多少bit的用户数据,就已经确定。随着NAND介质擦除和写入次数的增加,介质会变得更容易出错,即BER会增大,直到会出现用户错误过多,ECC码不能纠正用户错误的情况,即UNECC。当NAND介质出现UNECC时,目前固态存储业内广泛的用法是重复进行多次的读操作,看数据能否经过ECC把数据成功纠正。当经过多次尝试仍然不能纠正,才进入其他的处理流程或者放弃数据向主机返回UNECC。
发明内容
本发明的目的在于克服上述现有技术的不足之处,而提供一种用于固态存储读策略的控制方法。它是一种高效的读策略的控制方法,通过固件和硬件结合的方式,可以快速解决NAND数据UNECC的问题。
为了实现上述目的,本发明提供了一种用于固态存储读策略的控制方法,其特征在于:在固态存储设备中加入RAID的算法控制器,当数据经过控制器发向NAND介质时,会产生RAID code保存在NAND介质中,在数据产生UNECC时,固件不对数据进行重复读取,不进行ECC侦错尝试,而是直接通过硬件启动RAID模块,根据进行RAID算法的用户数据和RAIDcode将出错数据进行恢复。
在上述技术方案的基础上,所述RAID的算法控制器采用RAID5模式。
在上述技术方案的基础上,所述RAID的算法控制器通过异或运算产生RAID数据。
在上述技术方案的基础上,所述RAID的算法控制器通过同一条带的其他用户数据和RAID数据进行反异或运算,算出位于出错通路的写入的用户数据,然后再直接将正确用户数据传递给用户。
本发明具有的优点如下:本发明是一种高效的读策略的控制方法,通过固件和硬件结合的方式,可以快速解决NAND数据UNECC的问题。在固态存储设备中加入RAID的算法控制器,当数据产生UNECC时,固件不对数据进行重复读取,不进行ECC侦错尝试,而是直接通过硬件启动RAID模块,根据进行RAID算法的用户数据和RAID code将出错数据进行恢复。本发明的控制方法简单高效,可以大幅延长固态存储设备的使用寿命。
附图说明
图1为本发明的数据写入示意图。
图2为本发明的数据恢复示意图。
具体实施方式
下面结合附图详细说明本发明的实施情况,但它并不构成对本发明的限定,仅做举例而已。同时通过说明,本发明的优点将变得更加清楚和容易理解。
如图1、图2所示,一种用于固态存储读策略的控制方法,其特征在于:在固态存储设备中加入RAID的算法控制器,当数据经过控制器发向NAND介质时,会产生RAID code保存在NAND介质中,在数据产生UNECC时,固件不对数据进行重复读取,不进行ECC侦错尝试,而是直接通过硬件启动RAID模块,根据进行RAID算法的用户数据和RAID code将出错数据进行恢复。进一步地,RAID的算法控制器采用RAID5模式。RAID的算法控制器通过异或运算产生RAID数据。
如图1所示,同一条带用户数据经过RAID的算法控制器,将通过异或运算产生RAID数据,因此在数据通路中除了正常的用户数据,还会增加一部分RAID数据,一起写入NANDflash介质中。
如图2所示,每一通路的用户数据在读操作过程中出现不可纠正错误,RAID的算法控制器可以直接通过同一条带的其他用户数据和RAID数据进行反异或运算,算出位于出错通路的写入的用户数据,然后再直接将正确用户数据传递给用户。
以上所述仅为本发明的较佳实施例,并不用以限制本发明,凡在本发明精神和原则之内所做的任何修改、等同替换和改进等,均包含在本发明的保护范围之内。
Claims (4)
1.一种用于固态存储读策略的控制方法,其特征在于:在固态存储设备中加入RAID的算法控制器,当数据经过控制器发向NAND介质时,会产生RAID code保存在NAND介质中,在数据产生UNECC时,固件不对数据进行重复读取,不进行ECC侦错尝试,而是直接通过硬件启动RAID模块,根据进行RAID算法的用户数据和RAID code将出错数据进行恢复。
2.根据权利要求1所述的一种用于固态存储读策略的控制方法,其特征在于:所述RAID的算法控制器采用RAID5模式。
3.根据权利要求1或2所述的一种用于固态存储读策略的控制方法,其特征在于:所述RAID的算法控制器通过异或运算产生RAID数据。
4.根据权利要求3所述的一种用于固态存储读策略的控制方法,其特征在于:所述RAID的算法控制器通过同一条带的其他用户数据和RAID数据进行反异或运算,算出位于出错通路的写入的用户数据,然后再直接将正确用户数据传递给用户。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201611247494.9A CN106776110A (zh) | 2016-12-29 | 2016-12-29 | 一种用于固态存储读策略的控制方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201611247494.9A CN106776110A (zh) | 2016-12-29 | 2016-12-29 | 一种用于固态存储读策略的控制方法 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN106776110A true CN106776110A (zh) | 2017-05-31 |
Family
ID=58929250
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201611247494.9A Pending CN106776110A (zh) | 2016-12-29 | 2016-12-29 | 一种用于固态存储读策略的控制方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106776110A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108121509A (zh) * | 2017-12-19 | 2018-06-05 | 深圳忆联信息系统有限公司 | 一种提高ssd读操作时raid效率的方法及ssd |
CN109284201A (zh) * | 2018-09-17 | 2019-01-29 | 至誉科技(武汉)有限公司 | 温度均衡数据恢复方法以及系统、存储介质 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN201237907Y (zh) * | 2008-08-11 | 2009-05-13 | 湖南源科创新科技股份有限公司 | 单盘结构的固态raid系统 |
CN101504625A (zh) * | 2009-03-04 | 2009-08-12 | 成都市华为赛门铁克科技有限公司 | 实现独立磁盘冗余阵列的方法、固态硬盘和电子设备 |
CN102023815A (zh) * | 2009-09-15 | 2011-04-20 | 格雷戈里·伯德 | 在固态存储器中实现raid |
CN102915212A (zh) * | 2012-09-19 | 2013-02-06 | 记忆科技(深圳)有限公司 | 一种固态硬盘的raid实现方法、固态硬盘及电子设备 |
CN103729148A (zh) * | 2013-12-30 | 2014-04-16 | 华澜微电子有限公司 | 一种具有raid功能的固态硬盘 |
CN104156174A (zh) * | 2014-07-31 | 2014-11-19 | 记忆科技(深圳)有限公司 | 基于条带的固态硬盘raid实现方法及装置 |
US20160246678A1 (en) * | 2015-02-20 | 2016-08-25 | International Business Machines Corporation | Raid array systems and operations using mapping information |
CN205594612U (zh) * | 2015-03-27 | 2016-09-21 | 张维加 | 一种用于缓存和计算用途的便携式raid5设备 |
-
2016
- 2016-12-29 CN CN201611247494.9A patent/CN106776110A/zh active Pending
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN201237907Y (zh) * | 2008-08-11 | 2009-05-13 | 湖南源科创新科技股份有限公司 | 单盘结构的固态raid系统 |
CN101504625A (zh) * | 2009-03-04 | 2009-08-12 | 成都市华为赛门铁克科技有限公司 | 实现独立磁盘冗余阵列的方法、固态硬盘和电子设备 |
CN102023815A (zh) * | 2009-09-15 | 2011-04-20 | 格雷戈里·伯德 | 在固态存储器中实现raid |
CN102915212A (zh) * | 2012-09-19 | 2013-02-06 | 记忆科技(深圳)有限公司 | 一种固态硬盘的raid实现方法、固态硬盘及电子设备 |
CN103729148A (zh) * | 2013-12-30 | 2014-04-16 | 华澜微电子有限公司 | 一种具有raid功能的固态硬盘 |
CN104156174A (zh) * | 2014-07-31 | 2014-11-19 | 记忆科技(深圳)有限公司 | 基于条带的固态硬盘raid实现方法及装置 |
US20160246678A1 (en) * | 2015-02-20 | 2016-08-25 | International Business Machines Corporation | Raid array systems and operations using mapping information |
CN205594612U (zh) * | 2015-03-27 | 2016-09-21 | 张维加 | 一种用于缓存和计算用途的便携式raid5设备 |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108121509A (zh) * | 2017-12-19 | 2018-06-05 | 深圳忆联信息系统有限公司 | 一种提高ssd读操作时raid效率的方法及ssd |
CN108121509B (zh) * | 2017-12-19 | 2020-10-16 | 深圳忆联信息系统有限公司 | 一种提高ssd读操作时raid效率的方法及ssd |
CN109284201A (zh) * | 2018-09-17 | 2019-01-29 | 至誉科技(武汉)有限公司 | 温度均衡数据恢复方法以及系统、存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10180875B2 (en) | Pool-level solid state drive error correction | |
EP3358569B1 (en) | Flash memory error correction method and device thereof | |
CN102023815B (zh) | 在固态存储器中实现raid | |
CN101256842B (zh) | 纠错码控制器和包括该纠错码控制器的存储器系统 | |
US9037946B2 (en) | Detecting effect of corrupting event on preloaded data in non-volatile memory | |
US8327230B2 (en) | Data structure for flash memory and data reading/writing method thereof | |
US20190252035A1 (en) | Decoding method, memory storage device and memory control circuit unit | |
TWI594254B (zh) | 讀取快閃記憶體中區塊之資料的方法及相關的記憶裝置 | |
KR100645058B1 (ko) | 데이터 신뢰성을 향상시킬 수 있는 메모리 관리 기법 | |
CN101889267B (zh) | 存储器阵列中的差错校正 | |
US8055983B2 (en) | Data writing method for flash memory and error correction encoding/decoding method thereof | |
TWI527040B (zh) | 資料寫入方法、記憶體儲存裝置與記憶體控制器 | |
US20110161573A1 (en) | Device identifiers for nonvolatile memory modules | |
CN104932951B (zh) | 一种nand闪存出现ecc无法纠错时的数据恢复方法 | |
US11010065B2 (en) | Read retry method for solid state storage device | |
TW201447562A (zh) | 基於可用記憶體空間選擇冗餘儲存組態 | |
CN105808371A (zh) | 数据备份与恢复方法、控制芯片及存储装置 | |
CN103631670B (zh) | 存储器储存装置、存储器控制器与数据处理方法 | |
CN102110028A (zh) | 一种nand闪存及其数据的校验方法和装置 | |
CN101373640A (zh) | 闪存装置以及错误校正方法 | |
CN103594120A (zh) | 以读代写的存储器纠错方法 | |
CN106297883A (zh) | 解码方法、存储器存储装置及存储器控制电路单元 | |
CN101339525A (zh) | 一种对数据进行错误检测的方法、系统和设备 | |
CN101634938A (zh) | 固态硬盘的数据迁移方法、数据迁移装置及固态硬盘 | |
CN105304142A (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 | ||
CB02 | Change of applicant information | ||
CB02 | Change of applicant information |
Address after: 430070 Hubei city of Wuhan province Wuhan East Lake New Technology Development Zone Road No. two high Guan Nan Industrial Park No. 2 building 2-3 floor West Applicant after: To reputation technology (Wuhan) Co., Ltd. Address before: 430223 Hubei city of Wuhan province Wuhan East Lake New Technology Development Zone Road No. two high Guan Nan Industrial Park No. 2 building 2-3 floor West Applicant before: Memoright Technology (Wuhan) Co., Ltd. |
|
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20170531 |