CN113515232B - 提升ssd低命令深度读性能方法、装置、计算机设备及存储介质 - Google Patents
提升ssd低命令深度读性能方法、装置、计算机设备及存储介质 Download PDFInfo
- Publication number
- CN113515232B CN113515232B CN202110453091.4A CN202110453091A CN113515232B CN 113515232 B CN113515232 B CN 113515232B CN 202110453091 A CN202110453091 A CN 202110453091A CN 113515232 B CN113515232 B CN 113515232B
- Authority
- CN
- China
- Prior art keywords
- read
- request
- host
- data corresponding
- nand
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 26
- 230000005540 biological transmission Effects 0.000 claims description 23
- 238000004590 computer program Methods 0.000 claims description 16
- 238000004458 analytical method Methods 0.000 claims description 14
- 238000010586 diagram Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 3
- 238000012545 processing Methods 0.000 description 3
- 239000007787 solid Substances 0.000 description 3
- 238000004891 communication Methods 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 235000019800 disodium phosphate Nutrition 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 239000002245 particle Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/061—Improving I/O performance
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/0647—Migration mechanisms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/065—Replication mechanisms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0656—Data buffering arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0679—Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
-
- Y—GENERAL 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
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE 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/00—Energy efficient computing, e.g. low power processors, power management or thermal management
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)
- Memory System Of A Hierarchy Structure (AREA)
Abstract
本发明涉及提升SSD低命令深度读性能方法、装置、计算机设备及存储介质,该方法,包括:获取第一个读命令;解析第一个读命令,将读请求发送给NAND;将数据移动至数据页中;将数据传输给主机;获取第二个读命令;解析第二个读命令,发送两笔读请求给NAND;将对应第一笔读请求的数据移动至数据页中,将对应第二笔读请求的数据移动至缓存页中;将数据传输给主机;获取新读命令;解析新读命令,发送两笔读请求给NAND;将对应第二笔读请求的数据从缓存页中拷贝至数据页中,将对应第三笔读请求的数据移动至数据页中,将对应第四笔读请求的数据移动至缓存页中;将数据传输给主机。本发明提升了SSD的低命令深度顺序读性能。
Description
技术领域
本发明涉及提升SSD低命令深度读性能技术领域,尤其是指提升SSD低命令深度读性能方法、装置、计算机设备及存储介质。
背景技术
SSD固态硬盘作为一种新型存储介质,其采用NAND颗粒作为数据存储,相比于传统HDD,其最大优势在于拥有很高的顺序读性能,通常主机端需要同时发送超过8个读命令给SSD,这样才能跑出最好性能,但是对于小于这个深度的顺序读请求,SSD的读效率偏低,因此无法满足需求。
发明内容
本发明的目的在于克服现有技术的不足,提供提升SSD低命令深度读性能方法、装置、计算机设备及存储介质。
为了解决上述技术问题,本发明采用如下技术方案:
提升SSD低命令深度读性能方法,包括以下步骤:
获取主机下发的第一个读命令;
解析第一个读命令,获得读请求,并将读请求发送给NAND;
NAND将对应读请求的数据移动至数据页中;
将对应读请求的数据从数据页中传输给主机;
获取主机下发的第二个读命令;
解析第二个读命令,若第二个读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第一笔读请求和第二笔读请求;
NAND将对应第一笔读请求的数据移动至数据页中,同时将对应第二笔读请求的数据移动至缓存页中;
将对应第一笔读请求的数据从数据页中传输给主机;
获取主机下发的新读命令;
解析新读命令,若新读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第三笔读请求和第四笔读请求;
NAND将对应第二笔读请求的数据从缓存页中拷贝至数据页中,然后将对应第三笔读请求的数据移动至数据页中,同时将对应第四笔读请求的数据移动至缓存页中;
将对应第二笔读请求的数据和对应第三笔读请求的数据从数据页中传输给主机,然后返回执行步骤“获取主机下发的新读命令”。
其进一步技术方案为:所述获取主机下发的第一个读命令步骤中,通过片上系统获取主机下发的第一个读命令。
其进一步技术方案为:所述解析第一个读命令,获得读请求,并将读请求发送给NAND步骤中,通过片上系统解析第一个读命令,获得读请求,并将读请求发送给NAND。
其进一步技术方案为:所述将对应读请求的数据从数据页中传输给主机步骤中,通过片上系统将对应读请求的数据从数据页中传输给主机。
提升SSD低命令深度读性能装置,包括:第一获取单元,第一解析发送单元,第一移动单元,第一传输单元,第二获取单元,第二解析发送单元,第二移动单元,第二传输单元,第三获取单元,第三解析发送单元,拷贝移动单元,及传输返回单元;
所述第一获取单元,用于获取主机下发的第一个读命令;
所述第一解析发送单元,用于解析第一个读命令,获得读请求,并将读请求发送给NAND;
所述第一移动单元,用于NAND将对应读请求的数据移动至数据页中;
所述第一传输单元,用于将对应读请求的数据从数据页中传输给主机;
所述第二获取单元,用于获取主机下发的第二个读命令;
所述第二解析发送单元,用于析第二个读命令,若第二个读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第一笔读请求和第二笔读请求;
所述第二移动单元,用于NAND将对应第一笔读请求的数据移动至数据页中,同时将对应第二笔读请求的数据移动至缓存页中;
所述第二传输单元,用于将对应第一笔读请求的数据从数据页中传输给主机;
所述第三获取单元,用于获取主机下发的新读命令;
所述第三解析发送单元,用于解析新读命令,若新读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第三笔读请求和第四笔读请求;
所述拷贝移动单元,用于NAND将对应第二笔读请求的数据从缓存页中拷贝至数据页中,然后将对应第三笔读请求的数据移动至数据页中,同时将对应第四笔读请求的数据移动至缓存页中;
所述传输返回单元,用于将对应第二笔读请求的数据和对应第三笔读请求的数据从数据页中传输给主机,然后返回执行获取主机下发的新读命令。
其进一步技术方案为:所述第一获取单元中,通过片上系统获取主机下发的第一个读命令。
其进一步技术方案为:所述第一解析发送单元中,通过片上系统解析第一个读命令,获得读请求,并将读请求发送给NAND。
其进一步技术方案为:所述第一传输单元中,通过片上系统将对应读请求的数据从数据页中传输给主机。
一种计算机设备,所述计算机设备包括存储器及处理器,所述存储器上存储有计算机程序,所述处理器执行所述计算机程序时实现如上述所述的提升SSD低命令深度读性能方法。
一种存储介质,所述存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时可实现如上述所述的提升SSD低命令深度读性能方法。
本发明与现有技术相比的有益效果是:针对NAND的读延迟,提前将主机下一笔要读取的数据预移动到NAND的缓存页中,减少实时从NAND读取数据的读延迟,当下一笔主机命令到来时,直接从缓存页拷贝到数据页中,然后读取传输给主机,提升了SSD的低命令深度顺序读性能。
下面结合附图和具体实施例对本发明作进一步描述。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的提升SSD低命令深度读性能方法的流程示意图;
图2为本发明实施例提供的提升SSD低命令深度读性能装置的示意性框图;
图3为本发明实施例提供的计算机设备的示意性框图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
应当理解,当在本说明书和所附权利要求书中使用时,术语“包括”和“包含”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在此本发明说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本发明。如在本发明说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
还应当进一步理解,在本发明说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
请参阅图1到图3所示的具体实施例,其中,现有的主机低命令深度的读命令,包括以下步骤:
主机通过PCIe Bus(总线)发送命令给SOC(片上系统);
SOC解析命令,然后发送读命令给NAND;
NAND收到命令后进行需要一个tR(读)的时间,将数据放到Data Page(数据页)中;
NAND的数据准备好后,通知SOC,然后SOC把Data Page中数据通过PCIeBus发送给主机;
当数据传输完成,命令完成,然后主机发送下一个顺序读命令。
从上面步骤可以看出,低命令深度顺序读的性能计算公式:性能=Read_Cmd_size/(tR+tXFer),由于tXFer(数据传输)是固定的时间,那么命令的完成时间主要取决于NAND的数据准备时间tR,而tR的长短决定了读性能的高低。
请参阅图1所示,本发明公开了一种提升SSD低命令深度读性能方法,包括以下步骤:
S1,获取主机下发的第一个读命令;
其中,在S1步骤中,通过片上系统获取主机下发的第一个读命令。
S2,解析第一个读命令,获得读请求,并将读请求发送给NAND;
其中,在S2步骤中,通过片上系统解析第一个读命令,获得读请求,并将读请求发送给NAND。
S3,NAND将对应读请求的数据移动至数据页中;
其中,在NAND将对应读请求的数据移动至数据页中后,向片上系统反馈信号。
S4,将对应读请求的数据从数据页中传输给主机;
其中,在S4步骤中,通过片上系统将对应读请求的数据从数据页中传输给主机。
S5,获取主机下发的第二个读命令;
其中,通过片上系统获取主机下发的第二个读命令。
S6,解析第二个读命令,若第二个读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第一笔读请求和第二笔读请求;
其中,通过片上系统解析第二个读命令,然后发送两笔读请求给NAND,第一笔读请求是主机当前待完成的数据,第二笔读请求是主机下一笔将要读取的数据。
S7,NAND将对应第一笔读请求的数据移动至数据页中,同时将对应第二笔读请求的数据移动至缓存页中;
其中,当NAND将对应第一笔读请求的数据移动至数据页中后,向片上系统反馈信号。
S8,将对应第一笔读请求的数据从数据页中传输给主机;
其中,通过片上系统将对应第一笔读请求的数据从数据页中传输给主机。
S9,获取主机下发的新读命令;
其中,通过片上系统获取主机下发的新读命令。
S10,解析新读命令,若新读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第三笔读请求和第四笔读请求;
其中,通过片上系统解析新读命令,然后发送两笔读请求给NAND,第三笔读请求是主机当前待完成的数据,第四笔读请求是主机下一笔将要读取的数据。
S11,NAND将对应第二笔读请求的数据从缓存页中拷贝至数据页中,然后将对应第三笔读请求的数据移动至数据页中,同时将对应第四笔读请求的数据移动至缓存页中;
其中,此过程中减少了读命令的准备读时间,所以读命令的性能得到提升。
S12,将对应第二笔读请求的数据和对应第三笔读请求的数据从数据页中传输给主机,然后返回执行步骤S9,循环重复步骤S9-S12,如此继续下去,那么主机的读性能接近,读命令长度/tXFer。
本发明针对NAND的读延迟,提前将主机下一笔要读取的数据预移动到NAND的缓存页中,减少实时从NAND读取数据的读延迟,当下一笔主机命令到来时,直接从缓存页拷贝到数据页中,然后读取传输给主机,提升了SSD的低命令深度顺序读性能。
请参阅图2所示,本发明还公开了一种提升SSD低命令深度读性能装置,包括:第一获取单元10,第一解析发送单元20,第一移动单元30,第一传输单元40,第二获取单元50,第二解析发送单元60,第二移动单元70,第二传输单元80,第三获取单元90,第三解析发送单元100,拷贝移动单元110,及传输返回单元120;
所述第一获取单元10,用于获取主机下发的第一个读命令;
所述第一解析发送单元20,用于解析第一个读命令,获得读请求,并将读请求发送给NAND;
所述第一移动单元30,用于NAND将对应读请求的数据移动至数据页中;
所述第一传输单元40,用于将对应读请求的数据从数据页中传输给主机;
所述第二获取单元50,用于获取主机下发的第二个读命令;
所述第二解析发送单元60,用于析第二个读命令,若第二个读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第一笔读请求和第二笔读请求;
所述第二移动单元70,用于NAND将对应第一笔读请求的数据移动至数据页中,同时将对应第二笔读请求的数据移动至缓存页中;
所述第二传输单元80,用于将对应第一笔读请求的数据从数据页中传输给主机;
所述第三获取单元90,用于获取主机下发的新读命令;
所述第三解析发送单元100,用于解析新读命令,若新读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第三笔读请求和第四笔读请求;
所述拷贝移动单元110,用于NAND将对应第二笔读请求的数据从缓存页中拷贝至数据页中,然后将对应第三笔读请求的数据移动至数据页中,同时将对应第四笔读请求的数据移动至缓存页中;
所述传输返回单元120,用于将对应第二笔读请求的数据和对应第三笔读请求的数据从数据页中传输给主机,然后返回执行获取主机下发的新读命令。
其中,所述第一获取单元10中,通过片上系统获取主机下发的第一个读命令。
其中,所述第一解析发送单元20中,通过片上系统解析第一个读命令,获得读请求,并将读请求发送给NAND。
其中,所述第一传输单元40中,通过片上系统将对应读请求的数据从数据页中传输给主机。
需要说明的是,所属领域的技术人员可以清楚地了解到,上述提升SSD低命令深度读性能装置和各单元的具体实现过程,可以参考前述方法实施例中的相应描述,为了描述的方便和简洁,在此不再赘述。
上述提升SSD低命令深度读性能装置可以实现为一种计算机程序的形式,该计算机程序可以在如图3所示的计算机设备上运行。
请参阅图3,图3是本申请实施例提供的一种计算机设备的示意性框图;该计算机设备500可以是终端,也可以是服务器,其中,终端可以是智能手机、平板电脑、笔记本电脑、台式电脑、个人数字助理和穿戴式设备等具有通信功能的电子设备。服务器可以是独立的服务器,也可以是多个服务器组成的服务器集群。
参阅图3,该计算机设备500包括通过系统总线501连接的处理器502、存储器和网络接口505,其中,存储器可以包括非易失性存储介质503和内存储器504。
该非易失性存储介质503可存储操作系统5031和计算机程序5032。该计算机程序5032包括程序指令,该程序指令被执行时,可使得处理器502执行一种提升SSD低命令深度读性能方法。
该处理器502用于提供计算和控制能力,以支撑整个计算机设备500的运行。
该内存储器504为非易失性存储介质503中的计算机程序5032的运行提供环境,该计算机程序5032被处理器502执行时,可使得处理器502执行一种提升SSD低命令深度读性能方法。
该网络接口505用于与其它设备进行网络通信。本领域技术人员可以理解,图3中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的计算机设备500的限定,具体的计算机设备500可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
应当理解,在本申请实施例中,处理器502可以是中央处理单元(CentralProcessing Unit,CPU),该处理器502还可以是其他通用处理器、数字信号处理器(DigitalSignal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
本领域普通技术人员可以理解的是实现上述实施例的方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成。该计算机程序包括程序指令,计算机程序可存储于一存储介质中,该存储介质为计算机可读存储介质。该程序指令被该计算机系统中的至少一个处理器执行,以实现上述方法的实施例的流程步骤。
因此,本发明还提供一种存储介质。该存储介质可以为计算机可读存储介质。该存储介质存储有计算机程序,其中计算机程序包括程序指令,所述程序指令当被处理器执行时可实现上述的提升SSD低命令深度读性能方法。
所述存储介质可以是U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)、磁碟或者光盘等各种可以存储程序代码的计算机可读存储介质。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
在本发明所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的。例如,各个单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。
本发明实施例方法中的步骤可以根据实际需要进行顺序调整、合并和删减。本发明实施例装置中的单元可以根据实际需要进行合并、划分和删减。另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以是两个或两个以上单元集成在一个单元中。
该集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分,或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,终端,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。
上述实施例为本发明较佳的实现方案,除此之外,本发明还可以其它方式实现,在不脱离本技术方案构思的前提下任何显而易见的替换均在本发明的保护范围之内。
Claims (6)
1.提升SSD低命令深度读性能方法,其特征在于,包括以下步骤:
获取主机下发的第一个读命令;
解析第一个读命令,获得读请求,并将读请求发送给NAND;
NAND将对应读请求的数据移动至数据页中;
将对应读请求的数据从数据页中传输给主机;
获取主机下发的第二个读命令;
解析第二个读命令,若第二个读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第一笔读请求和第二笔读请求;
NAND将对应第一笔读请求的数据移动至数据页中,同时将对应第二笔读请求的数据移动至缓存页中;
将对应第一笔读请求的数据从数据页中传输给主机;
获取主机下发的新读命令;
解析新读命令,若新读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第三笔读请求和第四笔读请求;
NAND将对应第二笔读请求的数据从缓存页中拷贝至数据页中,然后将对应第三笔读请求的数据移动至数据页中,同时将对应第四笔读请求的数据移动至缓存页中;
将对应第二笔读请求的数据和对应第三笔读请求的数据从数据页中传输给主机,然后返回执行步骤“获取主机下发的新读命令”;
所述获取主机下发的第一个读命令步骤中,通过片上系统获取主机下发的第一个读命令;
所述解析第一个读命令,获得读请求,并将读请求发送给NAND步骤中,通过片上系统解析第一个读命令,获得读请求,并将读请求发送给NAND;
其中,通过片上系统解析第二个读命令,然后发送两笔读请求给NAND,第一笔读请求是主机当前待完成的数据,第二笔读请求是主机下一笔将要读取的数据;当NAND将对应第一笔读请求的数据移动至数据页中后,向片上系统反馈信号。
2.根据权利要求1所述的提升SSD低命令深度读性能方法,其特征在于,所述将对应读请求的数据从数据页中传输给主机步骤中,通过片上系统将对应读请求的数据从数据页中传输给主机。
3.提升SSD低命令深度读性能装置,其特征在于,包括:第一获取单元,第一解析发送单元,第一移动单元,第一传输单元,第二获取单元,第二解析发送单元,第二移动单元,第二传输单元,第三获取单元,第三解析发送单元,拷贝移动单元,及传输返回单元;
所述第一获取单元,用于获取主机下发的第一个读命令;
所述第一解析发送单元,用于解析第一个读命令,获得读请求,并将读请求发送给NAND;
所述第一移动单元,用于NAND将对应读请求的数据移动至数据页中;
所述第一传输单元,用于将对应读请求的数据从数据页中传输给主机;
所述第二获取单元,用于获取主机下发的第二个读命令;
所述第二解析发送单元,用于析第二个读命令,若第二个读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第一笔读请求和第二笔读请求;
所述第二移动单元,用于NAND将对应第一笔读请求的数据移动至数据页中,同时将对应第二笔读请求的数据移动至缓存页中;
所述第二传输单元,用于将对应第一笔读请求的数据从数据页中传输给主机;
所述第三获取单元,用于获取主机下发的新读命令;
所述第三解析发送单元,用于解析新读命令,若新读命令为顺序读,则发送两笔读请求给NAND,其中,两笔读请求包括第三笔读请求和第四笔读请求;
所述拷贝移动单元,用于NAND将对应第二笔读请求的数据从缓存页中拷贝至数据页中,然后将对应第三笔读请求的数据移动至数据页中,同时将对应第四笔读请求的数据移动至缓存页中;
所述传输返回单元,用于将对应第二笔读请求的数据和对应第三笔读请求的数据从数据页中传输给主机,然后返回执行获取主机下发的新读命令;
所述第一获取单元中,通过片上系统获取主机下发的第一个读命令;
所述第一解析发送单元中,通过片上系统解析第一个读命令,获得读请求,并将读请求发送给NAND;
其中,通过片上系统解析第二个读命令,然后发送两笔读请求给NAND,第一笔读请求是主机当前待完成的数据,第二笔读请求是主机下一笔将要读取的数据;当NAND将对应第一笔读请求的数据移动至数据页中后,向片上系统反馈信号。
4.根据权利要求3所述的提升SSD低命令深度读性能装置,其特征在于,所述第一传输单元中,通过片上系统将对应读请求的数据从数据页中传输给主机。
5.一种计算机设备,其特征在于,所述计算机设备包括存储器及处理器,所述存储器上存储有计算机程序,所述处理器执行所述计算机程序时实现如权利要求1-2中任一项所述的提升SSD低命令深度读性能方法。
6.一种存储介质,其特征在于,所述存储介质存储有计算机程序,所述计算机程序包括程序指令,所述程序指令当被处理器执行时可实现如权利要求1-2中任一项所述的提升SSD低命令深度读性能方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110453091.4A CN113515232B (zh) | 2021-04-26 | 2021-04-26 | 提升ssd低命令深度读性能方法、装置、计算机设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110453091.4A CN113515232B (zh) | 2021-04-26 | 2021-04-26 | 提升ssd低命令深度读性能方法、装置、计算机设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113515232A CN113515232A (zh) | 2021-10-19 |
CN113515232B true CN113515232B (zh) | 2023-08-29 |
Family
ID=78063430
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110453091.4A Active CN113515232B (zh) | 2021-04-26 | 2021-04-26 | 提升ssd低命令深度读性能方法、装置、计算机设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113515232B (zh) |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2012027649A (ja) * | 2010-07-22 | 2012-02-09 | Toshiba Corp | データ記憶装置及びデータ読み出し方法 |
JP2013178787A (ja) * | 2013-03-28 | 2013-09-09 | Sandisk Il Ltd | フラッシュメモリ・デバイスおよび方法 |
CN107274923A (zh) * | 2017-05-24 | 2017-10-20 | 记忆科技(深圳)有限公司 | 一种提高固态硬盘中顺序读取流性能的方法及固态硬盘 |
CN109901797A (zh) * | 2019-02-25 | 2019-06-18 | 深圳忆联信息系统有限公司 | 数据预读方法、装置、计算机设备及存储介质 |
CN110825326A (zh) * | 2019-10-31 | 2020-02-21 | 深圳忆联信息系统有限公司 | 提升ssd随机读性能的方法、装置、计算机设备及存储介质 |
CN111324282A (zh) * | 2018-12-14 | 2020-06-23 | 北京兆易创新科技股份有限公司 | 一种存储器 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7644224B2 (en) * | 2005-11-15 | 2010-01-05 | Sandisk Il Ltd. | Flash memory device and method |
US8195878B2 (en) * | 2009-02-19 | 2012-06-05 | Pmc-Sierra, Inc. | Hard disk drive with attached solid state drive cache |
JP2012128815A (ja) * | 2010-12-17 | 2012-07-05 | Toshiba Corp | メモリシステム |
US9324450B2 (en) * | 2013-03-13 | 2016-04-26 | Winbond Electronics Corporation | NAND flash memory |
-
2021
- 2021-04-26 CN CN202110453091.4A patent/CN113515232B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2012027649A (ja) * | 2010-07-22 | 2012-02-09 | Toshiba Corp | データ記憶装置及びデータ読み出し方法 |
JP2013178787A (ja) * | 2013-03-28 | 2013-09-09 | Sandisk Il Ltd | フラッシュメモリ・デバイスおよび方法 |
CN107274923A (zh) * | 2017-05-24 | 2017-10-20 | 记忆科技(深圳)有限公司 | 一种提高固态硬盘中顺序读取流性能的方法及固态硬盘 |
CN111324282A (zh) * | 2018-12-14 | 2020-06-23 | 北京兆易创新科技股份有限公司 | 一种存储器 |
CN109901797A (zh) * | 2019-02-25 | 2019-06-18 | 深圳忆联信息系统有限公司 | 数据预读方法、装置、计算机设备及存储介质 |
CN110825326A (zh) * | 2019-10-31 | 2020-02-21 | 深圳忆联信息系统有限公司 | 提升ssd随机读性能的方法、装置、计算机设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN113515232A (zh) | 2021-10-19 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11307769B2 (en) | Data storage method, apparatus and storage medium | |
KR101672067B1 (ko) | 패턴 인식 프로세서의 버스 | |
US11775320B2 (en) | Overflow detection and correction in state machine engines | |
US9430395B2 (en) | Grouping and dispatching scans in cache | |
CN105635324A (zh) | 用于浏览器或服务器的大文件上传、续传方法和装置 | |
WO2010065331A1 (en) | Systems and methods for managing endian mode of a device | |
US10489546B1 (en) | Modular system on chip configuration system | |
US10067893B2 (en) | Acceleration framework with direct data transfer mechanism | |
US10331359B2 (en) | Memory subsystem with wrapped-to-continuous read | |
CN115934625B (zh) | 一种用于远程直接内存访问的敲门铃方法、设备及介质 | |
CN110851474A (zh) | 数据查询方法、数据库中间件、数据查询设备及存储介质 | |
CN114816263A (zh) | 存储访问方法及智能处理装置 | |
US10216634B2 (en) | Cache directory processing method for multi-core processor system, and directory controller | |
CN109347899B (zh) | 在分布式存储系统中写入日志数据的方法 | |
CN110955719B (zh) | 一种数据存取处理设备、系统和方法 | |
EP3465450A1 (en) | Improving throughput in openfabrics environments | |
WO2015172391A1 (zh) | 快速数据读写方法和装置 | |
CN113515232B (zh) | 提升ssd低命令深度读性能方法、装置、计算机设备及存储介质 | |
CN110825326A (zh) | 提升ssd随机读性能的方法、装置、计算机设备及存储介质 | |
CN116610262A (zh) | 降低ssd顺序读延时的方法、装置、设备及介质 | |
US20180349062A1 (en) | Method and apparatus for en route translation in solid state graphics systems | |
WO2022001133A1 (zh) | 一种提升软拷贝读性能的方法、系统、终端及存储介质 | |
CN114327281B (zh) | 用于ssd的tcg软硬件加速方法、装置、计算机设备及存储介质 | |
CN113031863A (zh) | Ssd命令相关性管理方法、装置、计算机设备及存储介质 | |
CN114237509B (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 | ||
TR01 | Transfer of patent right |
Effective date of registration: 20231201 Address after: Room 4-B703, No. 328 Xinghu Street, Suzhou Industrial Park, Suzhou Area, China (Jiangsu) Pilot Free Trade Zone, Suzhou City, Jiangsu Province, 215000 Patentee after: Suzhou Yilian Information System Co.,Ltd. Address before: D24 / f-02, dongjiaotou workshop, Shekou Houhai Avenue, Shekou street, Nanshan District, Shenzhen City, Guangdong Province Patentee before: SHENZHEN UNIONMEMORY INFORMATION SYSTEM Co.,Ltd. |
|
TR01 | Transfer of patent right |