CN114003431B - 一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置 - Google Patents
一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置 Download PDFInfo
- Publication number
- CN114003431B CN114003431B CN202111138726.8A CN202111138726A CN114003431B CN 114003431 B CN114003431 B CN 114003431B CN 202111138726 A CN202111138726 A CN 202111138726A CN 114003431 B CN114003431 B CN 114003431B
- Authority
- CN
- China
- Prior art keywords
- solid state
- data
- trim
- state disk
- nvme solid
- 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
- 239000007787 solid Substances 0.000 title claims abstract description 138
- 238000000034 method Methods 0.000 title claims abstract description 38
- 238000013524 data verification Methods 0.000 title claims abstract description 27
- 238000012795 verification Methods 0.000 claims description 26
- 230000007246 mechanism Effects 0.000 claims description 23
- 238000004088 simulation Methods 0.000 claims description 7
- 238000012360 testing method Methods 0.000 abstract description 13
- 238000004891 communication Methods 0.000 description 9
- 238000012545 processing Methods 0.000 description 6
- 230000000694 effects Effects 0.000 description 5
- 238000005516 engineering process Methods 0.000 description 4
- 230000008569 process Effects 0.000 description 4
- 230000009471 action Effects 0.000 description 3
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 230000006978 adaptation Effects 0.000 description 2
- 238000004422 calculation algorithm Methods 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000005192 partition Methods 0.000 description 2
- 230000003321 amplification Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 238000003199 nucleic acid amplification method Methods 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 238000010998 test method Methods 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
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/1008—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices
- G06F11/1068—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices in sector programmable memories, e.g. flash disk
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
- G06F7/58—Random or pseudo-random number generators
- G06F7/588—Random number generators, i.e. based on natural stochastic processes
-
- 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)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Quality & Reliability (AREA)
- Computational Mathematics (AREA)
- Mathematical Analysis (AREA)
- Mathematical Optimization (AREA)
- Pure & Applied Mathematics (AREA)
- Signal Processing For Digital Recording And Reproducing (AREA)
Abstract
本发明提出的一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置,所述方法包括:生成随机数,模拟待测Nvme固态硬盘的现实复杂度;初始化待测Nvme固态硬盘;向待测Nvme固态硬盘的全盘写入固定数据;设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景;验证待测Nvme固态硬盘Trim后的数据。本发明能够实现Nvme固态硬盘非4k对齐的Trim数据校验,提升Trim场景的测试覆盖度。
Description
技术领域
本发明涉及计算机技术领域,更具体的说是涉及一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置。
背景技术
固态硬盘(Solid State Drive,简称SSD)尤其是Nvme SSD已经成为互联网、金融、电子商务等行业大型IT系统的重要的关键的基础部件,承担起了存储、处理海量数据的任务。Trim技术是一种擦除SSD数据的技术,一方面可以减少SSD的写放大,提升SSD的性能;另一方面可以擦除SSD上的数据,把SSD的现有数据初始化成0,起到保护数据安全的作用。
现有的测试SSDTrim后的数据校验方法,一般都是以FTL Page页的单位大小即4k对齐的方式去验证的,4k对齐的情况下SSD的数据会被Trim成0。
但在实际应用中,无论是主机上层应用下发的读写命令还是Trim命令有不少是非4k对齐的。非4k对齐的情况,Trim不会改变原有数据。
可见,当前常见的数据校验方法只是验证了4k对齐的场景,无法有效的覆盖验证非4k对齐Trim的应用场景。
发明内容
针对以上问题,本发明的目的在于提供一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置,能够实现Nvme固态硬盘非4k对齐的Trim数据校验,提升Trim场景的测试覆盖度。
本发明为实现上述目的,通过以下技术方案实现:一种Nvme固态硬盘非4k对齐Trim数据校验方法,包括:生成随机数,模拟待测Nvme固态硬盘的现实复杂度;初始化待测Nvme固态硬盘;向待测Nvme固态硬盘的全盘写入固定数据;设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景;验证待测Nvme固态硬盘Trim后的数据。
进一步,所述生成随机数,模拟待测Nvme固态硬盘的现实复杂度包括:根据Nvme协议接口命令获取待测Nvme固态硬盘所有的逻辑区块数X;
用X除以16得到数Y;
利用预设工具生成一个小于Y的随机数Z。
进一步,所述初始化待测Nvme固态硬盘包括:
使用Nvme低级格式化命令把待测Nvme固态硬盘的逻辑区块大小设置为512B;使用Nvme低级格式化命令把待测Nvme固态硬盘的中的数据全部初始化为0。
进一步,所述向待测Nvme固态硬盘的全盘写入固定数据包括:
向待测Nvme固态硬盘的所有逻辑区块地址均写入固定数据0X12345678。
进一步,所述设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景具体包括:
设置Trim的范围参数为8*Z;
设置Trim的起始逻辑区块地址是8*Z-3;
使用设置完成的Trim的范围参数和Trim的起始逻辑区块地址执行NvmeTrim命令。
进一步,所述验证待测Nvme固态硬盘Trim后的数据包括:
读取待测Nvme固态硬盘的逻辑区块的数据;
若逻辑区块的数据为0,则逻辑区块实现了4k对齐,使用第一验证机制验证Trim后的数据;
若逻辑区块的数据为0X12345678,则逻辑区块未实现4k对齐,使用第二验证机制验证Trim后的数据。
进一步,所述第一验证机制包括:
使用读写工具,针对实现4k对齐的逻辑区块,验证起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据,如果读出的数据全部是0,则Trim后的数据正确。
进一步,所述第二验证机制包括:
使用读写工具,针对待测Nvme固态硬盘中实现4k对齐的逻辑区块之外的8个逻辑区块,若每一个逻辑区块起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据均为0X12345678,则Trim后的数据正确。
相应的,本发明还公开了一种Nvme固态硬盘非4k对齐Trim数据校验系统,包括:
模拟单元,用于生成随机数,模拟待测Nvme固态硬盘的现实复杂度;
硬盘初始化单元,用于初始化待测Nvme固态硬盘;
写数据单元,用于向待测Nvme固态硬盘的全盘写入固定数据;
设置单元,用于设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景;验证单元,用于验证待测Nvme固态硬盘Trim后的数据。
进一步,所述模拟单元具体用于:
根据Nvme协议接口命令获取待测Nvme固态硬盘所有的逻辑区块数X;
用X除以16得到数Y;
利用预设工具生成一个小于Y的随机数Z。
进一步,所述硬盘初始化单元具体用于:
使用Nvme低级格式化命令把待测Nvme固态硬盘的逻辑区块大小设置为512B;
使用Nvme低级格式化命令把待测Nvme固态硬盘的中的数据全部初始化为0。
进一步,所述写数据单元具体用于:向待测Nvme固态硬盘的所有逻辑区块地址均写入固定数据0X12345678。
进一步,所述设置单元具体用于:
设置Trim的范围参数为8*Z;
设置Trim的起始逻辑区块地址是8*Z-3;
使用设置完成的Trim的范围参数和Trim的起始逻辑区块地址执行NvmeTrim命令。
进一步,所述验证单元具体用于:
读取待测Nvme固态硬盘的逻辑区块的数据;
若逻辑区块的数据为0,则逻辑区块实现了4k对齐,使用第一验证机制验证Trim后的数据;
若逻辑区块的数据为0X12345678,则逻辑区块未实现4k对齐,使用第二验证机制验证Trim后的数据。
相应的,本发明公开了一种Nvme固态硬盘非4k对齐Trim数据校验装置,包括:
存储器,用于存储Nvme固态硬盘非4k对齐Trim数据校验程序;
处理器,用于执行所述Nvme固态硬盘非4k对齐Trim数据校验程序时实现如上文任一项所述Nvme固态硬盘非4k对齐Trim数据校验方法的步骤。
相应的,本发明公开了一种可读存储介质,所述可读存储介质上存储有Nvme固态硬盘非4k对齐Trim数据校验程序,所述Nvme固态硬盘非4k对齐Trim数据校验程序被处理器执行时实现如上文任一项所述Nvme固态硬盘非4k对齐Trim数据校验方法的步骤。
对比现有技术,本发明有益效果在于:本发明提供了一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统、装置及可读存储介质,能够提升Trim场景的测试覆盖度果,还可以转化成自动化脚本,提高测试效率。本发明适用性强,除了适用于起始地址非4k对齐,长度4k对齐的场景,还适用于起始地址4k对齐,长度非4k对齐的场景,以及起始地址及长度都是非4k对齐的场景。
由此可见,本发明与现有技术相比,具有突出的实质性特点和显著的进步,其实施的有益效果也是显而易见的。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
附图1是本发明具体实施方式的方法流程图。
附图2是本发明具体实施方式的系统结构图。
图中,1为模拟单元;2为硬盘初始化单元;3为写数据单元;4为设置单元;5为验证单元。
具体实施方式
本发明的核心是提供一种Nvme固态硬盘非4k对齐Trim数据校验方法,现有技术中,一般都是以FTL Page页的单位大小即4k对齐的方式去验证的,4k对齐的情况下SSD的数据会被Trim成0。但在实际应用中,无论是主机上层应用下发的读写命令还是Trim命令有不少是非4k对齐的。非4k对齐的情况,Trim不会改变原有数据。
而本发明提供的Nvme固态硬盘非4k对齐Trim数据校验方法,首先,生成随机数,模拟待测Nvme固态硬盘的现实复杂度。然后,初始化待测Nvme固态硬盘;向待测Nvme固态硬盘的全盘写入固定数据;并进行Trim命令参数设置,构造待测Nvme固态硬盘的非4k对齐场景。最后,验证待测Nvme固态硬盘Trim后的数据。由此可见,本发明构建了SSD非4k对齐Trim数据校验的流程及测试方法。
为了使本技术领域的人员更好地理解本发明方案,本发明的设计的技术用语进行如下说明:
4K对齐,指的是符合“4K扇区”定义格式化过的硬盘,并且按照“4K扇区”的规则写入数据。因为随着硬盘容量不断扩展,使得之前定义的每个扇区512字节不再是那么的合理,于是将每个扇区512字节改为每个扇区4096个字节,也就是现在常说的“4K扇区”。随着NTFS成为了标准的硬盘文件系统,其文件系统的默认分配单元大小也是4096字节,为了使簇与扇区相对应,,即使物理硬盘分区与计算机使用的逻辑分区对齐,保证硬盘读写效率,所以有了“4K对齐”概念。
Nvme,即NVM Express(NVMe),或称非易失性内存主机控制器接口规范(NonVolatile Memory Host Controller Interface Specification,缩写:NVMHCIS),是一个逻辑设备接口规范。它是与AHCI类似的、基于设备逻辑接口的总线传输协议规范(相当于通讯协议中的应用层),用于访问通过PCI Express(PCIe)总线附加的非易失性存储器介质(例如采用闪存的固态硬盘驱动器),虽然理论上不一定要求PCIe总线协议。
下面结合附图和具体实施方式对本发明作进一步的详细说明。显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
实施例一:
如图1所示,本实施例提供了一种Nvme固态硬盘非4k对齐Trim数据校验方法,包括如下步骤:
S1:生成随机数,模拟待测Nvme固态硬盘的现实复杂度。
首先,根据Nvme协议接口命令获取待测Nvme固态硬盘所有的逻辑区块数X;然后,用X除以16得到数Y;最后,利用预设工具生成一个小于Y的随机数Z。
S2:初始化待测Nvme固态硬盘。
本步骤具体为:使用Nvme低级格式化命令把待测Nvme固态硬盘的逻辑区块大小设置为512B;同时,使用Nvme低级格式化命令把待测Nvme固态硬盘的中的数据全部初始化为0。
S3:向待测Nvme固态硬盘的全盘写入固定数据。
本步骤具体为:向待测Nvme固态硬盘的所有逻辑区块地址均写入固定数据0X12345678。
S4:设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景。
首先,设置Trim的范围参数为8*Z;然后,设置Trim的起始逻辑区块地址是8*Z-3;最后,使用设置完成的Trim的范围参数和Trim的起始逻辑区块地址执行NvmeTrim命令。
S5:验证待测Nvme固态硬盘Trim后的数据。
因为步骤S3构造的Trim范围既包含4k对齐部分也包含4k非对齐部分,所以需要分两类进行验证。
4k对齐部分可以Trim成功,数据被初始化为0;只有起始地址及长度都4k对齐时,才算4k对齐;任一条件不满足均是非4k对齐。而4k非对齐部分Trim失败后,数据仍然是0X12345678。
具体来说:
首先,读取待测Nvme固态硬盘的逻辑区块的数据;若逻辑区块的数据为0,则逻辑区块实现了4k对齐,使用第一验证机制验证Trim后的数据;若逻辑区块的数据为0X12345678,则逻辑区块未实现4k对齐,使用第二验证机制验证Trim后的数据。
其中,第一验证机制包括:使用读写工具,针对实现4k对齐的逻辑区块,验证起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据,如果读出的数据全部是0,则Trim后的数据正确。也就是说读出此范围内的数据全部是0,说明4k对齐Trim后的数据正确;
其中,第二验证机制包括:使用读写工具,针对待测Nvme固态硬盘中实现4k对齐的逻辑区块之外的8个逻辑区块,若每一个逻辑区块起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据均为0X12345678,则Trim后的数据正确。第二验证机制针对非4k对齐部分,非4k对齐部分的验证范围为4k对齐范围之外的8个lba,读出此范围的数据若全部仍然是0X12345678,说明4k非对齐Trim的数据正确。
本实施例提供了一种Nvme固态硬盘非4k对齐Trim数据校验方法,能够提升Trim场景的测试覆盖度果,还可以转化成自动化脚本,提高测试效率。本方法适用性强,除了适用于起始地址非4k对齐,长度4k对齐的场景,还适用于起始地址4k对齐,长度非4k对齐的场景,以及起始地址及长度都是非4k对齐的场景。
实施例二:
基于实施例一,如图2所示,本发明还公开了一种Nvme固态硬盘非4k对齐Trim数据校验系统,包括:模拟单元1、硬盘初始化单元2、写数据单元3、设置单元4和验证单元5。
模拟单元1,用于生成随机数,模拟待测Nvme固态硬盘的现实复杂度。模拟单元1具体用于:根据Nvme协议接口命令获取待测Nvme固态硬盘所有的逻辑区块数X;用X除以16得到数Y;利用预设工具生成一个小于Y的随机数Z。
硬盘初始化单元2,用于初始化待测Nvme固态硬盘。硬盘初始化单元2具体用于:使用Nvme低级格式化命令把待测Nvme固态硬盘的逻辑区块大小设置为512B;使用Nvme低级格式化命令把待测Nvme固态硬盘的中的数据全部初始化为0。
写数据单元3,用于向待测Nvme固态硬盘的全盘写入固定数据。写数据单元3具体用于:向待测Nvme固态硬盘的所有逻辑区块地址均写入固定数据0X12345678。
设置单元4,用于设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景。设置单元4具体用于:设置Trim的范围参数为8*Z;设置Trim的起始逻辑区块地址是8*Z-3;使用设置完成的Trim的范围参数和Trim的起始逻辑区块地址执行NvmeTrim命令。
验证单元5,用于验证待测Nvme固态硬盘Trim后的数据。验证单元5具体用于:读取待测Nvme固态硬盘的逻辑区块的数据;若逻辑区块的数据为0,则逻辑区块实现了4k对齐,使用第一验证机制验证Trim后的数据;若逻辑区块的数据为0X12345678,则逻辑区块未实现4k对齐,使用第二验证机制验证Trim后的数据。
第一验证机制包括:使用读写工具,针对实现4k对齐的逻辑区块,验证起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据,如果读出的数据全部是0,则Trim后的数据正确。
第二验证机制包括:使用读写工具,针对待测Nvme固态硬盘中实现4k对齐的逻辑区块之外的8个逻辑区块,若每一个逻辑区块起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据均为0X12345678,则Trim后的数据正确。
本实施例提供了一种Nvme固态硬盘非4k对齐Trim数据校验系统,能够提升Trim场景的测试覆盖度果,还可以转化成自动化脚本,提高测试效率。本系统适用性强,除了适用于起始地址非4k对齐,长度4k对齐的场景,还适用于起始地址4k对齐,长度非4k对齐的场景,以及起始地址及长度都是非4k对齐的场景。
实施例三:
本实施例公开了一种Nvme固态硬盘非4k对齐Trim数据校验装置,包括处理器和存储器;其中,所述处理器执行所述存储器中保存的Nvme固态硬盘非4k对齐Trim数据校验程序时实现以下步骤:
1、生成随机数,模拟待测Nvme固态硬盘的现实复杂度。
2、初始化待测Nvme固态硬盘。
3、向待测Nvme固态硬盘的全盘写入固定数据。
4、设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景。
5、验证待测Nvme固态硬盘Trim后的数据。
进一步的,本实施例中的Nvme固态硬盘非4k对齐Trim数据校验装置,还可以包括:
输入接口,用于获取外界导入的Nvme固态硬盘非4k对齐Trim数据校验程序,并将获取到的Nvme固态硬盘非4k对齐Trim数据校验程序保存至所述存储器中,还可以用于获取外界终端设备传输的各种指令和参数,并传输至处理器中,以便处理器利用上述各种指令和参数展开相应的处理。本实施例中,所述输入接口具体可以包括但不限于USB接口、串行接口、语音输入接口、指纹输入接口、硬盘读取接口等。
输出接口,用于将处理器产生的各种数据输出至与其相连的终端设备,以便于与输出接口相连的其他终端设备能够获取到处理器产生的各种数据。本实施例中,所述输出接口具体可以包括但不限于USB接口、串行接口等。
通讯单元,用于在Nvme固态硬盘非4k对齐Trim数据校验装置和外部服务器之间建立远程通讯连接,以便于Nvme固态硬盘非4k对齐Trim数据校验装置能够将镜像文件挂载到外部服务器中。本实施例中,通讯单元具体可以包括但不限于基于无线通讯技术或有线通讯技术的远程通讯单元。
键盘,用于获取用户通过实时敲击键帽而输入的各种参数数据或指令。
显示器,用于运行服务器供电线路短路定位过程的相关信息进行实时显示。
鼠标,可以用于协助用户输入数据并简化用户的操作。
本实施例提供了一种Nvme固态硬盘非4k对齐Trim数据校验装置,能够提升Trim场景的测试覆盖度果,还可以转化成自动化脚本,提高测试效率。本装置用性强,除了适用于起始地址非4k对齐,长度4k对齐的场景,还适用于起始地址4k对齐,长度非4k对齐的场景,以及起始地址及长度都是非4k对齐的场景。
实施例四:
本实施例还公开了一种可读存储介质,这里所说的可读存储介质包括随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动硬盘、CD-ROM或技术领域内所公知的任意其他形式的存储介质。可读存储介质中存储有Nvme固态硬盘非4k对齐Trim数据校验程序,所述Nvme固态硬盘非4k对齐Trim数据校验程序被处理器执行时实现以下步骤:
1、生成随机数,模拟待测Nvme固态硬盘的现实复杂度。
2、初始化待测Nvme固态硬盘。
3、向待测Nvme固态硬盘的全盘写入固定数据。
4、设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景。
5、验证待测Nvme固态硬盘Trim后的数据。
综上所述,本发明能够实现Nvme固态硬盘非4k对齐的Trim数据校验,提升Trim场景的测试覆盖度。
本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似部分互相参见即可。对于实施例公开的方法而言,由于其与实施例公开的系统相对应,所以描述的比较简单,相关之处参见方法部分说明即可。
专业人员还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
在本发明所提供的几个实施例中,应该理解到,所揭露的系统、系统和方法,可以通过其它的方式实现。例如,以上所描述的系统实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,系统或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个模块单独物理存在,也可以两个或两个以上模块集成在一个单元中。
同理,在本发明各个实施例中的各处理单元可以集成在一个功能模块中,也可以是各个处理单元物理存在,也可以两个或两个以上处理单元集成在一个功能模块中。
结合本文中所公开的实施例描述的方法或算法的步骤可以直接用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上对本发明所提供的Nvme固态硬盘非4k对齐Trim数据校验方法、系统、装置及可读存储介质进行了详细介绍。本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想。应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以对本发明进行若干改进和修饰,这些改进和修饰也落入本发明权利要求的保护范围内。
Claims (5)
1.一种Nvme固态硬盘非4k对齐Trim数据校验方法,其特征在于,包括:
生成随机数,模拟待测Nvme固态硬盘的现实复杂度;
初始化待测Nvme固态硬盘;
向待测Nvme固态硬盘的全盘写入固定数据;
设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景;
验证待测Nvme固态硬盘Trim后的数据;
所述生成随机数,模拟待测Nvme固态硬盘的现实复杂度包括:
根据Nvme协议接口命令获取待测Nvme固态硬盘所有的逻辑区块数X;
用X除以16得到数Y;
利用预设工具生成一个小于Y的随机数Z;
所述设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景具体包括:
设置Trim的范围参数为8*Z;
设置Trim的起始逻辑区块地址是8*Z-3;
使用设置完成的Trim的范围参数和Trim的起始逻辑区块地址执行NvmeTrim命令;
所述验证待测Nvme固态硬盘Trim后的数据包括:
读取待测Nvme固态硬盘的逻辑区块的数据;
若逻辑区块的数据为0,则逻辑区块实现了4k对齐,使用第一验证机制验证Trim后的数据;
若逻辑区块的数据为0X12345678,则逻辑区块未实现4k对齐,使用第二验证机制验证Trim后的数据;
所述第一验证机制包括:
使用读写工具,针对实现4k对齐的逻辑区块,验证起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据,如果读出的数据全部是0,则Trim后的数据正确;
所述第二验证机制包括:
使用读写工具,针对待测Nvme固态硬盘中实现4k对齐的逻辑区块之外的8个逻辑区块,若每一个逻辑区块起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据均为0X12345678,则Trim后的数据正确。
2.根据权利要求1所述的Nvme固态硬盘非4k对齐Trim数据校验方法,其特征在于,所述初始化待测Nvme固态硬盘包括:
使用Nvme低级格式化命令把待测Nvme固态硬盘的逻辑区块大小设置为512B;
使用Nvme低级格式化命令把待测Nvme固态硬盘的中的数据全部初始化为0。
3.根据权利要求1所述的Nvme固态硬盘非4k对齐Trim数据校验方法,其特征在于,所述向待测Nvme固态硬盘的全盘写入固定数据包括:
向待测Nvme固态硬盘的所有逻辑区块地址均写入固定数据0X12345678。
4.一种Nvme固态硬盘非4k对齐Trim数据校验系统,其特征在于,包括:
模拟单元,用于生成随机数,模拟待测Nvme固态硬盘的现实复杂度;
硬盘初始化单元,用于初始化待测Nvme固态硬盘;
写数据单元,用于向待测Nvme固态硬盘的全盘写入固定数据;
设置单元,用于设置Trim命令参数,构造待测Nvme固态硬盘的非4k对齐场景;
验证单元,用于验证待测Nvme固态硬盘Trim后的数据;
所述模拟单元具体用于:
根据Nvme协议接口命令获取待测Nvme固态硬盘所有的逻辑区块数X;
用X除以16得到数Y;
利用预设工具生成一个小于Y的随机数Z;
所述设置单元具体用于:
设置Trim的范围参数为8*Z;
设置Trim的起始逻辑区块地址是8*Z-3;
使用设置完成的Trim的范围参数和Trim的起始逻辑区块地址执行NvmeTrim命令;
所述验证单元具体用于:
读取待测Nvme固态硬盘的逻辑区块的数据;
若逻辑区块的数据为0,则逻辑区块实现了4k对齐,使用第一验证机制验证Trim后的数据;
若逻辑区块的数据为0X12345678,则逻辑区块未实现4k对齐,使用第二验证机制验证Trim后的数据;
所述第一验证机制包括:
使用读写工具,针对实现4k对齐的逻辑区块,验证起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据,如果读出的数据全部是0,则Trim后的数据正确;
所述第二验证机制包括:
使用读写工具,针对待测Nvme固态硬盘中实现4k对齐的逻辑区块之外的8个逻辑区块,若每一个逻辑区块起始逻辑区块地址是8*Z,长度范围是8*Z-8的数据均为0X12345678,则Trim后的数据正确。
5.一种Nvme固态硬盘非4k对齐Trim数据校验装置,其特征在于,包括:
存储器,用于存储Nvme固态硬盘非4k对齐Trim数据校验程序;
处理器,用于执行所述Nvme固态硬盘非4k对齐Trim数据校验程序时实现如权利要求1至3任一项权利要求所述的Nvme固态硬盘非4k对齐Trim数据校验方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111138726.8A CN114003431B (zh) | 2021-09-27 | 2021-09-27 | 一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111138726.8A CN114003431B (zh) | 2021-09-27 | 2021-09-27 | 一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114003431A CN114003431A (zh) | 2022-02-01 |
CN114003431B true CN114003431B (zh) | 2024-01-12 |
Family
ID=79921758
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111138726.8A Active CN114003431B (zh) | 2021-09-27 | 2021-09-27 | 一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114003431B (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107274933A (zh) * | 2017-06-14 | 2017-10-20 | 湖南国科微电子股份有限公司 | 一种测试固态硬盘的方法及装置 |
CN110767258A (zh) * | 2019-10-22 | 2020-02-07 | 江苏芯盛智能科技有限公司 | 数据擦除命令测试方法和相关装置 |
CN111462805A (zh) * | 2020-03-11 | 2020-07-28 | 苏州浪潮智能科技有限公司 | 一种全面快速测试NVME SSD Trim功能的方法及装置 |
CN111737051A (zh) * | 2020-06-12 | 2020-10-02 | 苏州浪潮智能科技有限公司 | 一种SSD固态硬盘的trim数据校验测试方法、装置及系统 |
CN112631953A (zh) * | 2020-12-30 | 2021-04-09 | 湖南国科微电子股份有限公司 | 固态硬盘数据trim方法、装置、电子设备及存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11237202B2 (en) * | 2019-03-12 | 2022-02-01 | Advantest Corporation | Non-standard sector size system support for SSD testing |
-
2021
- 2021-09-27 CN CN202111138726.8A patent/CN114003431B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107274933A (zh) * | 2017-06-14 | 2017-10-20 | 湖南国科微电子股份有限公司 | 一种测试固态硬盘的方法及装置 |
CN110767258A (zh) * | 2019-10-22 | 2020-02-07 | 江苏芯盛智能科技有限公司 | 数据擦除命令测试方法和相关装置 |
CN111462805A (zh) * | 2020-03-11 | 2020-07-28 | 苏州浪潮智能科技有限公司 | 一种全面快速测试NVME SSD Trim功能的方法及装置 |
CN111737051A (zh) * | 2020-06-12 | 2020-10-02 | 苏州浪潮智能科技有限公司 | 一种SSD固态硬盘的trim数据校验测试方法、装置及系统 |
CN112631953A (zh) * | 2020-12-30 | 2021-04-09 | 湖南国科微电子股份有限公司 | 固态硬盘数据trim方法、装置、电子设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN114003431A (zh) | 2022-02-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7802155B2 (en) | Non-volatile memory device manufacturing process testing systems and methods thereof | |
US8954705B2 (en) | Memory space management method and memory controller and memory storage device and memory storage using the same | |
CN109445691B (zh) | 一种提高ftl算法开发和验证效率的方法及装置 | |
CN108133732A (zh) | 闪存芯片的性能测试方法、装置、设备及存储介质 | |
CN113778822B (zh) | 纠错能力测试方法、装置、可读存储介质及电子设备 | |
US20070091697A1 (en) | Device recoverable purge for flash storage device | |
US9858366B2 (en) | Simulator and simulating method for flash memory background | |
CN110765032A (zh) | 基于系统管理总线接口对i2c存储器进行读写的方法 | |
CN107678894B (zh) | 一种内存测试方法、装置及系统 | |
JP4180757B2 (ja) | シミュレーション装置 | |
CN111324414B (zh) | Nvm存储介质模拟器 | |
CN111737051A (zh) | 一种SSD固态硬盘的trim数据校验测试方法、装置及系统 | |
TW201447578A (zh) | 資料儲存裝置及其管理方法 | |
CN108897657B (zh) | 一种面向ssd仿真平台错误注入方法及相关装置 | |
KR20210025836A (ko) | 메모리 컨트롤러, 이를 포함하는 저장 장치 및 메모리 컨트롤러의 동작 방법 | |
CN114003431B (zh) | 一种Nvme固态硬盘非4k对齐Trim数据校验方法、系统及装置 | |
CN112802529A (zh) | 一种军工级Nand闪存的检测方法、装置、电子设备及存储介质 | |
TWI396090B (zh) | 快閃記憶裝置、資料儲存系統、以及傳送特殊命令至快閃記憶裝置之方法 | |
CN115509442A (zh) | 闪存颗粒调试方法、闪存颗粒调试设备和可读存储介质 | |
KR20210018570A (ko) | 컨트롤러, 컨트롤러의 동작 방법 및 이를 포함하는 저장 장치 | |
CN112347524B (zh) | 闪存编程方法、装置及电子设备 | |
CN110286995B (zh) | 一种数据读写方法和装置 | |
TWI633434B (zh) | 管理固態硬碟之方法、系統及電腦可讀取媒體 | |
CN112306954A (zh) | 一种文件系统的测试方法和装置 | |
CN112463633A (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 |