CN111625199A - 提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质 - Google Patents

提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质 Download PDF

Info

Publication number
CN111625199A
CN111625199A CN202010467759.6A CN202010467759A CN111625199A CN 111625199 A CN111625199 A CN 111625199A CN 202010467759 A CN202010467759 A CN 202010467759A CN 111625199 A CN111625199 A CN 111625199A
Authority
CN
China
Prior art keywords
data
host
command
written
unit
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
CN202010467759.6A
Other languages
English (en)
Other versions
CN111625199B (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 CN202010467759.6A priority Critical patent/CN111625199B/zh
Publication of CN111625199A publication Critical patent/CN111625199A/zh
Application granted granted Critical
Publication of CN111625199B publication Critical patent/CN111625199B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

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
    • G06F3/0619Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/08Error detection or correction by redundancy in data representation, e.g. by using checking codes
    • G06F11/10Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
    • G06F11/1076Parity data used in redundant arrays of independent storages, e.g. in RAID systems
    • G06F11/108Parity data distribution in semiconductor storages, e.g. in SSD
    • 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/0638Organizing or formatting or addressing of data
    • 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/0655Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
    • G06F3/0656Data buffering arrangements
    • 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/0683Plurality of storage devices
    • G06F3/0688Non-volatile semiconductor memory arrays
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Computer Security & Cryptography (AREA)
  • Quality & Reliability (AREA)
  • Memory System Of A Hierarchy Structure (AREA)

Abstract

本发明涉及提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质;其中,方法,包括:NVMe接收主机发出的命令;判断主机发出的命令是否为写命令;若是,NVMe将待写入数据从主机取出,对待写入数据增加校验位,将增加校验位后的待写入数据存储至DRAM,将写命令传递至FTL;更新映射表,将写命令传递至NFC;NFC从DRAM中取出待写入数据,对待写入数据进行校验;判断待写入数据校验是否通过;若通过,将待写入数据写入闪存中;若未通过,则进行错误处理。本发明通过对写入DRAM的数据加入校验位,当数据被读取时进行校验,校验通过才能继续操作,校验失败进行错误处理,有效提升了数据通路可靠性。

Description

提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存 储介质
技术领域
本发明涉及固态硬盘数据可靠性技术领域,更具体地说是指提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质。
背景技术
作为一种存储类型的固态硬盘,SSD(Solid State Disk,固态硬盘)的数据安全是非常重要的,SSD主要由主控、缓存、闪存模块组成,闪存掉电不易失,主要是作为数据存储的介质,而缓存掉电易失,主要服务与数据通路;固态硬盘的数据安全主要包括闪存数据保护、数据通路保护。
现有的数据从Host(主机)到Flash(闪存)会经过DRAM(Dynamic Random AccessMemory,动态随机存取存储器),而且FTL(Flash Translation Layer,闪存转换算法模块)映射表也会占据DRAM的大部分空间,相比SRAM(Static Random-Access Memory,静态随机存取存储器)而言,DRAM更容易因比特翻转而出错;因此,数据在传输过程中,极有可能因为DRAM的比特翻转,而发生错误,如果Host数据出错,则错误数据会被当成正确数据被存到Flash中,如果映射表发生错误,则数据的存取就会发生偏差,如果这些错误不能加以修正,就会影响固态硬盘的数据可靠性和完整性。
发明内容
本发明的目的在于克服现有技术的缺陷,提供提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质。
为实现上述目的,本发明采用以下技术方案:
提升固态硬盘数据通路可靠性的方法,包括以下步骤:
NVMe接收主机发出的命令;
判断主机发出的命令是否为写命令;
若为写命令,则NVMe将待写入数据从主机取出,并对待写入数据增加校验位,将增加校验位后的待写入数据存储至DRAM,同时将写命令传递至FTL;
FTL根据写命令更新映射表,并将写命令传递至NFC;
NFC从DRAM中取出待写入数据,并对待写入数据进行校验;
判断待写入数据校验是否通过;
若是通过,将待写入数据写入闪存中;
若未通过,则进行错误处理。
其进一步技术方案为:所述步骤“判断主机发出的命令是否为写命令”中,若不为写命令,则NVMe将主机发出的命令传递至FTL;
FTL根据命令查询映射表中的对应项,将映射结果更新至命令中,并将更新后的命令传递至NFC;
NFC将待读取数据从闪存中读出,并对待读取数据增加校验位,将增加校验位后的待读取数据存储至DRAM,同时将命令处理结果通过FTL传递至NVMe;
NVMe从DRAM中取出待读取数据,并对待读取数据进行校验;
判断待读取数据校验是否通过;
若是通过,将待读取数据搬移至主机缓存中;
若未通过,则进行错误处理。
其进一步技术方案为:所述NVMe通过PCIE接口将待写入数据从主机取出或将待读取数据搬移至主机缓存中。
其进一步技术方案为:所述错误处理包括以下步骤:
对主机发出的命令重新生成,并对重新生成的命令进行校验;
判断重新生成的命令校验是否通过;
若是通过,将返回执行步骤“判断主机发出的命令是否为写命令”;
若未通过,则传递给主机,设备出现了错误的提示,主机对设备进行复位。
提升固态硬盘数据通路可靠性的装置,包括:接收单元,第一判断单元,取出增加存储传递单元,更新传递单元,第一取出校验单元,第二判断单元,写入单元,及处理单元;
所述接收单元,用于NVMe接收主机发出的命令;
所述第一判断单元,用于判断主机发出的命令是否为写命令;
所述取出增加存储传递单元,用于NVMe将待写入数据从主机取出,并对待写入数据增加校验位,将增加校验位后的待写入数据存储至DRAM,同时将写命令传递至FTL;
所述更新传递单元,用于FTL根据写命令更新映射表,并将写命令传递至NFC;
所述第一取出校验单元,用于NFC从DRAM中取出待写入数据,并对待写入数据进行校验;
所述第二判断单元,用于判断待写入数据校验是否通过;
所述写入单元,用于将待写入数据写入闪存中;
所述处理单元,用于对主机发出的命令进行错误处理。
其进一步技术方案为:还包括:传递单元,查询更新传递单元,读出增加存储传递单元,第二取出校验单元,第三判断单元,及搬移单元;
所述传递单元,用于NVMe将主机发出的命令传递至FTL;
所述查询更新传递单元,用于FTL根据命令查询映射表中的对应项,将映射结果更新至命令中,并将更新后的命令传递至NFC;
所述读出增加存储传递单元,用于NFC将待读取数据从闪存中读出,并对待读取数据增加校验位,将增加校验位后的待读取数据存储至DRAM,同时将命令处理结果通过FTL传递至NVMe;
所述第二取出校验单元,用于NVMe从DRAM中取出待读取数据,并对待读取数据进行校验;
所述第三判断单元,用于判断待读取数据校验是否通过;
所述搬移单元,用于将待读取数据搬移至主机缓存中。
其进一步技术方案为:所述NVMe通过PCIE接口将待写入数据从主机取出或将待读取数据搬移至主机缓存中。
其进一步技术方案为:所述处理单元包括:生成校验模块,判断模块,返回模块,及传递复位模块;
所述生成校验模块,用于对主机发出的命令重新生成,并对重新生成的命令进行校验;
所述判断模块,用于判断重新生成的命令校验是否通过;
所述返回模块,用于返回执行判断主机发出的命令是否为写命令;
所述传递复位模块,用于传递给主机,设备出现了错误的提示,主机对设备进行复位。
一种计算机设备,所述计算机设备包括存储器及处理器,所述存储器上存储有计算机程序,所述处理器执行所述计算机程序时实现如上述所述的提升固态硬盘数据通路可靠性的方法。
一种存储介质,所述存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时可实现如上述所述的提升固态硬盘数据通路可靠性的方法。
本发明与现有技术相比的有益效果是:通过对写入DRAM的数据加入校验位,当数据被读取时进行校验,校验通过才能继续操作,校验失败进行错误处理,从而达到有效提升数据通路可靠性的目的,能够更好地满足需求。
下面结合附图和具体实施例对本发明作进一步描述。
附图说明
为了更清楚地说明本发明实施例技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为现有的SSD数据通路的应用示意图;
图2为本发明实施例提供的提升固态硬盘数据通路可靠性的方法的流程示意图一;
图3为本发明实施例提供的提升固态硬盘数据通路可靠性的方法的流程示意图二;
图4为本发明实施例提供的提升固态硬盘数据通路可靠性的方法的应用场景示意图;
图5为本发明实施例提供的提升固态硬盘数据通路可靠性的装置的示意性框图;
图6为本发明实施例提供的计算机设备的示意性框图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
应当理解,当在本说明书和所附权利要求书中使用时,术语“包括”和“包含”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在此本发明说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本发明。如在本发明说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
还应当进一步理解,在本发明说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
请参阅图1到图6所示的具体实施例,其中,请参阅图1所示的现有的SSD数据通路的应用示意图,SSD的主控主要由NVMe(Non-Volatile Memory express,非易失性内存主机控制器接口规范模块),FTL(Flash Translation Layer,闪存转换算法模块),NFC(NANDFlash Controlle,闪存控制模块)以及平台组成。PCIE(Peripheral CompentInterconnect Express,高速串行计算机扩展总线标准模块)为SSD的接口模块,DRAM(Dynamic Random Access Memory,动态随机存取存储器)为SSD的缓存。
Host(主机)与SSD的数据交互主要通过读写命令通路来完成的。
写通路过程大致如下:
NVMe将主机数据通过PCIE搬到DRAM中缓存,并将命令节点传给FTL;
FTL根据该节点更新映射表中的对应项,并通知NFC;
NFC再将主机数据从DRAM搬至Flash(闪存)。
读通路与写通路相反,即:
NVMe将命令节点传给FTL;
FTL根据该节点内容询映射表中的对应项,将映射结果更新至节点信息中,并通知NFC;
NFC根据节点的相关信息,将Host数据从Flash搬至DRAM中缓存;
NVMe再将数据从DRAM通过PCIE搬到Host的缓存中。
其中,上述操作不仅数据从Host到Flash会经过DRAM,而且FTL映射表也会占据DRAM的大部分空间,相比SRAM(Static Random-Access Memory,静态随机存取存储器)而言,DRAM更容易因比特翻转而出错,因此,数据在传输过程中,极有可能因为DRAM的比特翻转,而发生错误,如果Host数据出错,则错误数据会被当成正确数据被存到Flash中,如果映射表发生错误,则数据的存取就会发生偏差,如果这些错误不能加以修正,就会影响固态硬盘的数据可靠性和完整性。
请参阅图2至图4所示,本发明公开了一种提升固态硬盘数据通路可靠性的方法,包括以下步骤:
S1,NVMe接收主机发出的命令;
S2,判断主机发出的命令是否为写命令;
S3,若为写命令,则NVMe将待写入数据从主机取出,并对待写入数据增加校验位,将增加校验位后的待写入数据存储至DRAM,同时将写命令传递至FTL;
其中,在本实施例中,NVMe通过PCIE接口将待写入数据从主机取出,高带宽,支持大功率,传输速度快。
其中,NVMe对每笔从Host到DRAM的数据,即待写入数据,都会调用校验模块,在写入DRAM时加入校验比特,具体开销由校验算法决定。
进一步地,在本实施例中,校验算法为奇偶校验算法,汉明校验算法,MD5校验算法,异或校验算法,循环冗余校验算法的其中一种,根据实际需要进行选择,校验位为校验比特,其比特大小根据实际需要进行设定。
S4,FTL根据写命令更新映射表,并将写命令传递至NFC;
S5,NFC从DRAM中取出待写入数据,并对待写入数据进行校验;
其中,NFC从DRAM中取出待写入数据时,也会调用校验模块进行检错,使用同一校验算法对该笔数据重新进行校验,再跟DRAM中已有的校验比特进行对比。
S6,判断待写入数据校验是否通过;
S7,若是通过,将待写入数据写入闪存中;
S8,若未通过,则进行错误处理。
其中,所述步骤S2“判断主机发出的命令是否为写命令”中;
S9,若不为写命令,则NVMe将主机发出的命令传递至FTL;
S10,FTL根据命令查询映射表中的对应项,将映射结果更新至命令中,并将更新后的命令传递至NFC;
S11,NFC将待读取数据从闪存中读出,并对待读取数据增加校验位,将增加校验位后的待读取数据存储至DRAM,同时将命令处理结果通过FTL传递至NVMe;
S12,NVMe从DRAM中取出待读取数据,并对待读取数据进行校验;
S13,判断待读取数据校验是否通过;若未通过,则进入步骤S8,进行错误处理;
S14,若是通过,将待读取数据搬移至主机缓存中。
其中,所述NVMe通过PCIE接口将待读取数据搬移至主机缓存中,传输速度快且稳定。
其中,由于读写过程中,需要FTL为数据查找或更新相应的映射表,因此也需要利用校验模块,对FTL表加入相应的校验位,进行数据保护,当映射表中出现错误时,可以及时进行错误处理。
其中,如图3所示,所述步骤S8的错误处理包括以下步骤:
S81,对主机发出的命令重新生成,并对重新生成的命令进行校验;
S82,判断重新生成的命令校验是否通过;
S83,若是通过,将返回执行步骤S2“判断主机发出的命令是否为写命令”;
S84,若未通过,则传递给主机,设备出现了错误的提示,主机对设备进行复位。
其中,在步骤S84中,则通过填写NVMe的AER(Advanced Error Report)的相关寄存器来告知Host,设备出现了致命错误(FATAL ERROR);当Host检测到致命错误后,会复位设备,对NVMe控制器来说,该复位与上电复位效果相同,这种级别的错误处理会影响到Host的工作,需要Host重新初始化NVME设备,才能继续工作。
请参阅图4所示,本发明的应用场景,通过增加检验模块,对写入DRAM的数据加入校验位,当数据被读取时进行校验,校验通过才能继续操作,校验失败进行错误处理。
本发明对写入DRAM的数据加入校验位,当数据被读取时进行校验,校验通过才能继续操作,校验失败进行错误处理,从而达到有效提升数据通路可靠性的目的,能够更好地满足需求。
请参阅图5所示,本发明还公开了一种提升固态硬盘数据通路可靠性的装置,包括:接收单元10,第一判断单元20,取出增加存储传递单元30,更新传递单元40,第一取出校验单元50,第二判断单元60,写入单元70,及处理单元80;
所述接收单元10,用于NVMe接收主机发出的命令;
所述第一判断单元20,用于判断主机发出的命令是否为写命令;
所述取出增加存储传递单元30,用于NVMe将待写入数据从主机取出,并对待写入数据增加校验位,将增加校验位后的待写入数据存储至DRAM,同时将写命令传递至FTL;
所述更新传递单元40,用于FTL根据写命令更新映射表,并将写命令传递至NFC;
所述第一取出校验单元50,用于NFC从DRAM中取出待写入数据,并对待写入数据进行校验;
所述第二判断单元60,用于判断待写入数据校验是否通过;
所述写入单元70,用于将待写入数据写入闪存中;
所述处理单元80,用于对主机发出的命令进行错误处理。
其中,该装置还包括:传递单元90,查询更新传递单元100,读出增加存储传递单元110,第二取出校验单元120,第三判断单元130,及搬移单元140;
所述传递单元90,用于NVMe将主机发出的命令传递至FTL;
所述查询更新传递单元100,用于FTL根据命令查询映射表中的对应项,将映射结果更新至命令中,并将更新后的命令传递至NFC;
所述读出增加存储传递单元110,用于NFC将待读取数据从闪存中读出,并对待读取数据增加校验位,将增加校验位后的待读取数据存储至DRAM,同时将命令处理结果通过FTL传递至NVMe;
所述第二取出校验单元120,用于NVMe从DRAM中取出待读取数据,并对待读取数据进行校验;
所述第三判断单元130,用于判断待读取数据校验是否通过;
所述搬移单元140,用于将待读取数据搬移至主机缓存中。
其中,所述NVMe通过PCIE接口将待写入数据从主机取出或将待读取数据搬移至主机缓存中。
其中,所述处理单元80包括:生成校验模块81,判断模块82,返回模块83,及传递复位模块84;
所述生成校验模块81,用于对主机发出的命令重新生成,并对重新生成的命令进行校验;
所述判断模块82,用于判断重新生成的命令校验是否通过;
所述返回模块83,用于返回执行判断主机发出的命令是否为写命令;
所述传递复位模块84,用于传递给主机,设备出现了错误的提示,主机对设备进行复位。
需要说明的是,所属领域的技术人员可以清楚地了解到,上述提升固态硬盘数据通路可靠性的装置和各单元的具体实现过程,可以参考前述方法实施例中的相应描述,为了描述的方便和简洁,在此不再赘述。
上述提升固态硬盘数据通路可靠性的装置可以实现为一种计算机程序的形式,该计算机程序可以在如图6所示的计算机设备上运行。
请参阅图6,图6是本申请实施例提供的一种计算机设备的示意性框图;该计算机设备500可以是终端,也可以是服务器,其中,终端可以是智能手机、平板电脑、笔记本电脑、台式电脑、个人数字助理和穿戴式设备等具有通信功能的电子设备。服务器可以是独立的服务器,也可以是多个服务器组成的服务器集群。
参阅图6,该计算机设备500包括通过***总线501连接的处理器502、存储器和网络接口505,其中,存储器可以包括非易失性存储介质503和内存储器504。
该非易失性存储介质503可存储操作***5031和计算机程序5032。该计算机程序5032包括程序指令,该程序指令被执行时,可使得处理器502执行一种提升固态硬盘数据通路可靠性的方法。
该处理器502用于提供计算和控制能力,以支撑整个计算机设备500的运行。
该内存储器504为非易失性存储介质503中的计算机程序5032的运行提供环境,该计算机程序5032被处理器502执行时,可使得处理器502执行一种提升固态硬盘数据通路可靠性的方法。
该网络接口505用于与其它设备进行网络通信。本领域技术人员可以理解,图6中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的计算机设备500的限定,具体的计算机设备500可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
应当理解,在本申请实施例中,处理器502可以是中央处理单元(CentralProcessing Unit,CPU),该处理器502还可以是其他通用处理器、数字信号处理器(DigitalSignal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
本领域普通技术人员可以理解的是实现上述实施例的方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成。该计算机程序包括程序指令,计算机程序可存储于一存储介质中,该存储介质为计算机可读存储介质。该程序指令被该计算机***中的至少一个处理器执行,以实现上述方法的实施例的流程步骤。
因此,本发明还提供一种存储介质。该存储介质可以为计算机可读存储介质。该存储介质存储有计算机程序,其中计算机程序包括程序指令,所述程序指令当被处理器执行时可实现上述的提升固态硬盘数据通路可靠性的方法。
所述存储介质可以是U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)、磁碟或者光盘等各种可以存储程序代码的计算机可读存储介质。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
在本发明所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的。例如,各个单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。例如多个单元或组件可以结合或者可以集成到另一个***,或一些特征可以忽略,或不执行。
本发明实施例方法中的步骤可以根据实际需要进行顺序调整、合并和删减。本发明实施例装置中的单元可以根据实际需要进行合并、划分和删减。另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以是两个或两个以上单元集成在一个单元中。
该集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分,或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,终端,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。
上述仅以实施例来进一步说明本发明的技术内容,以便于读者更容易理解,但不代表本发明的实施方式仅限于此,任何依本发明所做的技术延伸或再创造,均受本发明的保护。本发明的保护范围以权利要求书为准。

Claims (10)

1.提升固态硬盘数据通路可靠性的方法,其特征在于,包括以下步骤:
NVMe接收主机发出的命令;
判断主机发出的命令是否为写命令;
若为写命令,则NVMe将待写入数据从主机取出,并对待写入数据增加校验位,将增加校验位后的待写入数据存储至DRAM,同时将写命令传递至FTL;
FTL根据写命令更新映射表,并将写命令传递至NFC;
NFC从DRAM中取出待写入数据,并对待写入数据进行校验;
判断待写入数据校验是否通过;
若是通过,将待写入数据写入闪存中;
若未通过,则进行错误处理。
2.根据权利要求1所述的提升固态硬盘数据通路可靠性的方法,其特征在于,所述步骤“判断主机发出的命令是否为写命令”中,若不为写命令,则NVMe将主机发出的命令传递至FTL;
FTL根据命令查询映射表中的对应项,将映射结果更新至命令中,并将更新后的命令传递至NFC;
NFC将待读取数据从闪存中读出,并对待读取数据增加校验位,将增加校验位后的待读取数据存储至DRAM,同时将命令处理结果通过FTL传递至NVMe;
NVMe从DRAM中取出待读取数据,并对待读取数据进行校验;
判断待读取数据校验是否通过;
若是通过,将待读取数据搬移至主机缓存中;
若未通过,则进行错误处理。
3.根据权利要求2所述的提升固态硬盘数据通路可靠性的方法,其特征在于,所述NVMe通过PCIE接口将待写入数据从主机取出或将待读取数据搬移至主机缓存中。
4.根据权利要求3所述的提升固态硬盘数据通路可靠性的方法,其特征在于,所述错误处理包括以下步骤:
对主机发出的命令重新生成,并对重新生成的命令进行校验;
判断重新生成的命令校验是否通过;
若是通过,将返回执行步骤“判断主机发出的命令是否为写命令”;
若未通过,则传递给主机,设备出现了错误的提示,主机对设备进行复位。
5.提升固态硬盘数据通路可靠性的装置,其特征在于,包括:接收单元,第一判断单元,取出增加存储传递单元,更新传递单元,第一取出校验单元,第二判断单元,写入单元,及处理单元;
所述接收单元,用于NVMe接收主机发出的命令;
所述第一判断单元,用于判断主机发出的命令是否为写命令;
所述取出增加存储传递单元,用于NVMe将待写入数据从主机取出,并对待写入数据增加校验位,将增加校验位后的待写入数据存储至DRAM,同时将写命令传递至FTL;
所述更新传递单元,用于FTL根据写命令更新映射表,并将写命令传递至NFC;
所述第一取出校验单元,用于NFC从DRAM中取出待写入数据,并对待写入数据进行校验;
所述第二判断单元,用于判断待写入数据校验是否通过;
所述写入单元,用于将待写入数据写入闪存中;
所述处理单元,用于对主机发出的命令进行错误处理。
6.根据权利要求5所述的提升固态硬盘数据通路可靠性的装置,其特征在于,还包括:传递单元,查询更新传递单元,读出增加存储传递单元,第二取出校验单元,第三判断单元,及搬移单元;
所述传递单元,用于NVMe将主机发出的命令传递至FTL;
所述查询更新传递单元,用于FTL根据命令查询映射表中的对应项,将映射结果更新至命令中,并将更新后的命令传递至NFC;
所述读出增加存储传递单元,用于NFC将待读取数据从闪存中读出,并对待读取数据增加校验位,将增加校验位后的待读取数据存储至DRAM,同时将命令处理结果通过FTL传递至NVMe;
所述第二取出校验单元,用于NVMe从DRAM中取出待读取数据,并对待读取数据进行校验;
所述第三判断单元,用于判断待读取数据校验是否通过;
所述搬移单元,用于将待读取数据搬移至主机缓存中。
7.根据权利要求6所述的提升固态硬盘数据通路可靠性的装置,其特征在于,所述NVMe通过PCIE接口将待写入数据从主机取出或将待读取数据搬移至主机缓存中。
8.根据权利要求7所述的提升固态硬盘数据通路可靠性的装置,其特征在于,所述处理单元包括:生成校验模块,判断模块,返回模块,及传递复位模块;
所述生成校验模块,用于对主机发出的命令重新生成,并对重新生成的命令进行校验;
所述判断模块,用于判断重新生成的命令校验是否通过;
所述返回模块,用于返回执行判断主机发出的命令是否为写命令;
所述传递复位模块,用于传递给主机,设备出现了错误的提示,主机对设备进行复位。
9.一种计算机设备,其特征在于,所述计算机设备包括存储器及处理器,所述存储器上存储有计算机程序,所述处理器执行所述计算机程序时实现如权利要求1-4中任一项所述的提升固态硬盘数据通路可靠性的方法。
10.一种存储介质,其特征在于,所述存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时可实现如权利要求1-4中任一项所述的提升固态硬盘数据通路可靠性的方法。
CN202010467759.6A 2020-05-28 2020-05-28 提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质 Active CN111625199B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010467759.6A CN111625199B (zh) 2020-05-28 2020-05-28 提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010467759.6A CN111625199B (zh) 2020-05-28 2020-05-28 提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质

Publications (2)

Publication Number Publication Date
CN111625199A true CN111625199A (zh) 2020-09-04
CN111625199B CN111625199B (zh) 2023-07-04

Family

ID=72272646

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010467759.6A Active CN111625199B (zh) 2020-05-28 2020-05-28 提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质

Country Status (1)

Country Link
CN (1) CN111625199B (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113110891A (zh) * 2021-04-21 2021-07-13 深圳忆联信息***有限公司 固态硬盘的固件加载方法、装置、计算机设备及存储介质
CN114461145A (zh) * 2022-01-19 2022-05-10 合肥大唐存储科技有限公司 一种扩容固态硬盘及其扩容、数据写入和数据读取方法
CN115129509A (zh) * 2022-06-30 2022-09-30 苏州浪潮智能科技有限公司 一种数据传输方法、装置、介质

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006318303A (ja) * 2005-05-13 2006-11-24 Tdk Corp メモリコントローラ、フラッシュメモリシステム及びフラッシュメモリの制御方法
US20120030435A1 (en) * 2009-02-05 2012-02-02 Indilinx Co., Ltd. Memory device, memory management device, and memory management method
CN107992436A (zh) * 2016-10-26 2018-05-04 杭州华为数字技术有限公司 一种NVMe数据读写方法及NVMe设备
CN108959117A (zh) * 2018-06-22 2018-12-07 深圳忆联信息***有限公司 H2d写操作加速方法、装置、计算机设备及存储介质
CN109634826A (zh) * 2018-12-12 2019-04-16 深圳忆联信息***有限公司 控制器极限性能分析方法、装置、计算机设备及存储介质
CN109726138A (zh) * 2017-10-31 2019-05-07 慧荣科技股份有限公司 数据储存装置以及非挥发式存储器操作方法
CN109992444A (zh) * 2019-03-25 2019-07-09 深圳忆联信息***有限公司 一种基于硬件的端对端数据保护方法、装置、计算机设备及存储介质
CN110018787A (zh) * 2019-02-26 2019-07-16 深圳忆联信息***有限公司 基于ssd全***的固件读写方法、装置和计算机设备

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006318303A (ja) * 2005-05-13 2006-11-24 Tdk Corp メモリコントローラ、フラッシュメモリシステム及びフラッシュメモリの制御方法
US20120030435A1 (en) * 2009-02-05 2012-02-02 Indilinx Co., Ltd. Memory device, memory management device, and memory management method
CN107992436A (zh) * 2016-10-26 2018-05-04 杭州华为数字技术有限公司 一种NVMe数据读写方法及NVMe设备
CN109726138A (zh) * 2017-10-31 2019-05-07 慧荣科技股份有限公司 数据储存装置以及非挥发式存储器操作方法
CN108959117A (zh) * 2018-06-22 2018-12-07 深圳忆联信息***有限公司 H2d写操作加速方法、装置、计算机设备及存储介质
CN109634826A (zh) * 2018-12-12 2019-04-16 深圳忆联信息***有限公司 控制器极限性能分析方法、装置、计算机设备及存储介质
CN110018787A (zh) * 2019-02-26 2019-07-16 深圳忆联信息***有限公司 基于ssd全***的固件读写方法、装置和计算机设备
CN109992444A (zh) * 2019-03-25 2019-07-09 深圳忆联信息***有限公司 一种基于硬件的端对端数据保护方法、装置、计算机设备及存储介质

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113110891A (zh) * 2021-04-21 2021-07-13 深圳忆联信息***有限公司 固态硬盘的固件加载方法、装置、计算机设备及存储介质
CN113110891B (zh) * 2021-04-21 2022-03-29 深圳忆联信息***有限公司 固态硬盘的固件加载方法、装置、计算机设备及存储介质
CN114461145A (zh) * 2022-01-19 2022-05-10 合肥大唐存储科技有限公司 一种扩容固态硬盘及其扩容、数据写入和数据读取方法
CN115129509A (zh) * 2022-06-30 2022-09-30 苏州浪潮智能科技有限公司 一种数据传输方法、装置、介质
CN115129509B (zh) * 2022-06-30 2024-06-25 苏州浪潮智能科技有限公司 一种数据传输方法、装置、介质

Also Published As

Publication number Publication date
CN111625199B (zh) 2023-07-04

Similar Documents

Publication Publication Date Title
US9535782B2 (en) Method, apparatus and system for handling data error events with a memory controller
US6539503B1 (en) Method and apparatus for testing error detection
CN111625199B (zh) 提升固态硬盘数据通路可靠性的方法、装置、计算机设备及存储介质
US9904591B2 (en) Device, system and method to restrict access to data error information
US9921914B2 (en) Redundant array of independent disks (RAID) write hole solutions
US7587658B1 (en) ECC encoding for uncorrectable errors
US9065481B2 (en) Bad wordline/array detection in memory
CN103218271B (zh) 一种数据纠错方法及装置
US11314594B2 (en) Method, device and computer program product for recovering data
US9626242B2 (en) Memory device error history bit
CN111143111B (zh) Ssd映射表保护机制验证方法、装置、计算机设备及存储介质
US20110099461A1 (en) Data integrity units in nonvolatile memory
US8667325B2 (en) Method, apparatus and system for providing memory sparing information
WO2021088368A1 (zh) 一种存储器的修复方法及装置
US20230325276A1 (en) Error correction method and apparatus
US11182231B2 (en) Host system and computing system including the host system
US10740179B2 (en) Memory and method for operating the memory
CN112463019A (zh) 数据读取方法及装置
CN112579329A (zh) 快速处理uecc的方法及其存储设备
US20230315302A1 (en) Complete And Fast Protection Against CID Conflict
US11809742B2 (en) Recovery from HMB loss
JPS6041374B2 (ja) 1ビツト誤り訂正・2ビツト誤り検出方式
CN115904828A (zh) 一种内存检测方法及装置
CN115809011A (zh) 一种存储***中数据重构方法及装置
KR20240083513A (ko) 스토리지 장치 및 이의 동작 방법

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