CN113342697B - 闪存转换层仿真测试系统及方法 - Google Patents
闪存转换层仿真测试系统及方法 Download PDFInfo
- Publication number
- CN113342697B CN113342697B CN202110812619.2A CN202110812619A CN113342697B CN 113342697 B CN113342697 B CN 113342697B CN 202110812619 A CN202110812619 A CN 202110812619A CN 113342697 B CN113342697 B CN 113342697B
- Authority
- CN
- China
- Prior art keywords
- network block
- test information
- translation layer
- virtualized
- flash translation
- 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
- 238000012360 testing method Methods 0.000 title claims abstract description 133
- 238000013519 translation Methods 0.000 title claims abstract description 91
- 238000000034 method Methods 0.000 title claims abstract description 41
- 238000004088 simulation Methods 0.000 title claims abstract description 21
- 230000001133 acceleration Effects 0.000 claims abstract description 12
- 238000003860 storage Methods 0.000 claims description 26
- 238000006243 chemical reaction Methods 0.000 claims description 16
- 238000010998 test method Methods 0.000 claims description 3
- 238000013461 design Methods 0.000 abstract description 12
- 238000011161 development Methods 0.000 abstract description 10
- 238000001514 detection method Methods 0.000 abstract description 4
- 239000000306 component Substances 0.000 description 39
- 238000012545 processing Methods 0.000 description 21
- 238000010586 diagram Methods 0.000 description 18
- 230000006870 function Effects 0.000 description 15
- 238000005516 engineering process Methods 0.000 description 12
- 238000004891 communication Methods 0.000 description 11
- 238000004590 computer program Methods 0.000 description 11
- 239000007787 solid Substances 0.000 description 10
- 230000005540 biological transmission Effects 0.000 description 6
- 230000003287 optical effect Effects 0.000 description 5
- 238000013507 mapping Methods 0.000 description 4
- 230000008569 process Effects 0.000 description 4
- 230000005236 sound signal Effects 0.000 description 4
- 238000012795 verification Methods 0.000 description 4
- 238000004458 analytical method Methods 0.000 description 3
- 230000003993 interaction Effects 0.000 description 3
- 230000004044 response Effects 0.000 description 3
- 230000008859 change Effects 0.000 description 2
- 239000000835 fiber Substances 0.000 description 2
- 238000010295 mobile communication Methods 0.000 description 2
- 238000005457 optimization Methods 0.000 description 2
- 230000001902 propagating effect Effects 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- RYGMFSIKBFXOCR-UHFFFAOYSA-N Copper Chemical compound [Cu] RYGMFSIKBFXOCR-UHFFFAOYSA-N 0.000 description 1
- 230000002159 abnormal effect Effects 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000000295 complement effect Effects 0.000 description 1
- 229910052802 copper Inorganic materials 0.000 description 1
- 239000010949 copper Substances 0.000 description 1
- 239000008358 core component Substances 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 238000003384 imaging method Methods 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 229910044991 metal oxide Inorganic materials 0.000 description 1
- 150000004706 metal oxides Chemical class 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 239000002245 particle Substances 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/3668—Software testing
- G06F11/3672—Test management
- G06F11/3684—Test management for test design, e.g. generating new test cases
-
- 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/0662—Virtualisation aspects
- G06F3/0664—Virtualisation aspects at device level, e.g. emulation of a storage device or system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/3668—Software testing
- G06F11/3672—Test management
- G06F11/3688—Test management for test execution, e.g. scheduling of test suites
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- 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/0614—Improving the reliability of storage systems
- G06F3/0619—Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
-
- 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/0638—Organizing or formatting or addressing of data
- G06F3/064—Management of blocks
-
- 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/0659—Command handling arrangements, e.g. command buffers, queues, command scheduling
-
- 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/067—Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS]
-
- 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]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/10—Providing a specific technical effect
- G06F2212/1016—Performance improvement
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/10—Providing a specific technical effect
- G06F2212/1032—Reliability improvement, data loss prevention, degraded operation etc
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7201—Logical to physical mapping or translation of blocks or pages
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
Abstract
本公开涉及一种闪存转换层仿真测试系统及方法,所述系统包括网络块设备、虚拟化硬件加速器、闪存转换层模块及基于所述网络块设备的虚拟化闪存,网络块设备,用于接收并转发测试信息,测试信息包括读指令和/或写指令及待写入数据;虚拟化硬件加速器,用于分配测试信息到虚拟化硬件加速器的各个线程,并对所述闪存转换层模块进行虚拟硬件加速;闪存转换层模块,用于根据测试信息对虚拟化闪存进行操作,得到操作结果。通过以上系统,本公开实施例可以使得闪存转换层在所述系统上进行测试、设计、开发,从而定位关键路径并分析闪存转换性能,对FTL固件中空指针访问等特殊异常具有较好的探测能力,提升FTL设计稳定性及开发效率。
Description
技术领域
本公开涉及测试技术领域,尤其涉及一种闪存转换层仿真测试系统及方法。
背景技术
FTL(Flash Translation Layer,闪存转换层)算法是SSD(Solid State Disk,固态硬盘)固件的核心部分,为提高FTL算法的开发验证效率,首先需要具备验证环境。目前固件验证环境包括SSD主控(如嵌入式控制器)、NAND Flash颗粒、DDR、PCIE、DStream等器件,这些硬件产品普遍价格较高,而且部分为易损耗的(如NAND Flash读写、擦除操作次数有限),在使用过程中也存在启动时间长,稳定性差的问题,并且,在对FTL进行设计时,通常需要FTL软件做到软硬件配合设计,因此,相关技术通常是以嵌入式控制器自身为平台进行设计开发,这些因素会直接导致SSD固件的开发效率降低,开发成本增加。
发明内容
根据本公开的一方面,提供了一种闪存转换层仿真测试系统,所述系统包括网络块设备、虚拟化硬件加速器、闪存转换层模块及基于所述网络块设备的虚拟化闪存,其中,
所述网络块设备,用于接收并转发测试信息,所述测试信息包括读指令和/或写指令及待写入数据;
所述虚拟化硬件加速器,连接于所述网络块设备及所述闪存转换层模块,用于分配所述测试信息到所述虚拟化硬件加速器的各个线程,并对所述闪存转换层模块进行虚拟硬件加速;
所述闪存转换层模块,连接于所述虚拟化闪存及所述网络块设备,用于根据所述测试信息对所述虚拟化闪存进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器将读操作结果返回所述网络块设备,或,当所述测试信息包括写指令时,通过所述闪存转换层模块将写操作结果返回所述网络块设备。
在一种可能的实施方式中,所述网络块设备包括网络块设备客户端、网络块设备服务端,
所述网络块设备客户端用于接收测试请求,并解析所述测试请求得到所述测试信息;
所述网络块设备服务端,用于根据所述测试信息的类型将所述测试信息中的指令入队列转发到所述虚拟化硬件加速器、将待写入数据拷贝到所述虚拟化硬件加速器。
在一种可能的实施方式中,所述虚拟化硬件加速器、所述闪存转换层模块包括一个或多个线程。
在一种可能的实施方式中,当所述测试信息包括写指令及待写入数据时,所述闪存转换层模块还用于:
从所述虚拟化闪存申请存储空间;
进行逻辑地址到物理地址的转换;
根据得到的物理地址将所述待写入数据写入申请到的存储空间,并将写操作结果返回所述网络块设备。
在一种可能的实施方式中,当所述测试信息包括读指令时,所述闪存转换层模块还用于:
进行逻辑地址到物理地址的转换;
根据转换得到的物理地址从虚拟化闪存读取数据,将读操作结果返回所述虚拟化硬件加速器。
根据本公开的一方面,提供了一种闪存转换层仿真测试方法,所述方法包括:
产生网络块设备、虚拟化硬件加速器、闪存转换层模块及基于所述网络块设备的虚拟化闪存;
利用所述网络块设备接收并转发测试信息,所述测试信息包括读指令和/或写指令及待写入数据;
利用所述虚拟化硬件加速器分配所述测试信息到所述虚拟化硬件加速器的各个线程,并对所述闪存转换层模块进行虚拟硬件加速;
利用所述闪存转换层模块根据所述测试信息对所述虚拟化闪存进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器将读操作结果返回所述网络块设备,或,当所述测试信息包括写指令时,通过所述闪存转换层模块将写操作结果返回所述网络块设备。
在一种可能的实施方式中,所述网络块设备包括网络块设备客户端、网络块设备服务端,所述方法还包括:
利用所述网络块设备客户端接收测试请求,并解析所述测试请求得到所述测试信息;
利用所述网络块设备服务端根据所述测试信息的类型将所述测试信息中的指令入队列转发到所述虚拟化硬件加速器、将待写入数据拷贝到所述虚拟化硬件加速器。
在一种可能的实施方式中,当所述测试信息包括写指令及待写入数据时,所述方法还包括:
利用所述闪存转换层模块执行以下操作:
从所述虚拟化闪存申请存储空间;
进行逻辑地址到物理地址的转换;
根据得到的物理地址将所述待写入数据写入申请到的存储空间,并将写操作结果返回所述网络块设备。
在一种可能的实施方式中,当所述测试信息包括读指令时,所述方法还包括:
利用所述闪存转换层模块执行以下操作:
进行逻辑地址到物理地址的转换;
根据转换得到的物理地址从虚拟化闪存读取数据,将读操作结果返回所述虚拟化硬件加速器。
在一种可能的实施方式中,所述虚拟化硬件加速器、所述闪存转换层模块包括一个或多个线程。
根据本公开的一方面,提供了一种电子设备,包括:处理器;用于存储处理器可执行指令的存储器;其中,所述处理器被配置为调用所述存储器存储的指令,以执行上述方法。
根据本公开的一方面,提供了一种计算机可读存储介质,其上存储有计算机程序指令,所述计算机程序指令被处理器执行时实现上述方法。
通过以上系统,本公开实施例通过网络块设备接收并转发测试信息,通过虚拟化硬件减速器分配所述测试信息到所述虚拟化硬件加速器的各个线程,并对所述闪存转换层模块进行虚拟硬件加速,通过闪存转换层模块根据所述测试信息对所述虚拟化闪存进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器将读操作结果返回所述网络块设备,或,当所述测试信息包括写指令时,通过所述闪存转换层模块将写操作结果返回所述网络块设备,以使得闪存转换层在所述系统上进行测试、设计、开发,从而定位关键路径并分析闪存转换性能,对FTL固件中空指针访问等特殊异常具有较好的探测能力,提升FTL设计稳定性及开发效率。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,而非限制本公开。根据下面参考附图对示例性实施例的详细说明,本公开的其它特征及方面将变得清楚。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,这些附图示出了符合本公开的实施例,并与说明书一起用于说明本公开的技术方案。
图1示出了根据本公开一实施例的闪存转换层仿真测试系统的框图。
图2示出了根据本公开一实施例的闪存转换层仿真测试系统的示意图。
图3示出了根据本公开一实施例的闪存转换层仿真测试方法的流程图。
图4示出了根据本公开一实施例的一种电子设备的框图。
图5示出了根据本公开一实施例的一种电子设备的框图。
具体实施方式
以下将参考附图详细说明本公开的各种示例性实施例、特征和方面。附图中相同的附图标记表示功能相同或相似的元件。尽管在附图中示出了实施例的各种方面,但是除非特别指出,不必按比例绘制附图。
在本公开的描述中,需要理解的是,术语“长度”、“宽度”、“上”、“下”、“前”、“后”、“左”、“右”、“竖直”、“水平”、“顶”、“底”、“内”、“外”等指示的方位或位置关系为基于附图所示的方位或位置关系,仅是为了便于描述本公开和简化描述,而不是指示或暗示所指的装置或元件必须具有特定的方位、以特定的方位构造和操作,因此不能理解为对本公开的限制。
此外,术语“第一”、“第二”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或者隐含地包括一个或者更多个该特征。在本公开的描述中,“多个”的含义是两个或两个以上,除非另有明确具体的限定。
在本公开中,除非另有明确的规定和限定,术语“安装”、“相连”、“连接”、“固定”等术语应做广义理解,例如,可以是固定连接,也可以是可拆卸连接,或成一体;可以是机械连接,也可以是电连接;可以是直接相连,也可以通过中间媒介间接相连,可以是两个元件内部的连通或两个元件的相互作用关系。对于本领域的普通技术人员而言,可以根据具体情况理解上述术语在本公开中的具体含义。
在这里专用的词“示例性”意为“用作例子、实施例或说明性”。这里作为“示例性”所说明的任何实施例不必解释为优于或好于其它实施例。
本文中术语“和/或”,仅仅是一种描述关联对象的关联关系,表示可以存在三种关系,例如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。另外,本文中术语“至少一种”表示多种中的任意一种或多种中的至少两种的任意组合,例如,包括A、B、C中的至少一种,可以表示包括从A、B和C构成的集合中选择的任意一个或多个元素。
另外,为了更好地说明本公开,在下文的具体实施方式中给出了众多的具体细节。本领域技术人员应当理解,没有某些具体细节,本公开同样可以实施。在一些实例中,对于本领域技术人员熟知的方法、手段、元件和电路未作详细描述,以便于凸显本公开的主旨。
在基于嵌入式控制器的固态硬盘中,闪存转换层(FTL)是固件的核心组件,其主要维护主机逻辑地址(LDA)和闪存物理地址(PDA)的映射关系,当主机对固态硬盘进行读写操作时,FTL便会根据映射关系寻找对应的闪存地址。因此要求FTL能够实现高效优异的算法来管理这种映射关系,从而能够决定固态硬盘的性能,稳定性,寿命等特征。此外嵌入式控制器为了提升固态硬盘的性能,会设计相应的硬件加速器来解决一些关键路径的瓶颈,从而需要FTL软件做到软硬件配合设计。因此设计FTL软件最直接的方法便是以嵌入式控制器自身为平台进行设计开发,但出于成本控制,嵌入式控制器中CPU无法提供额外的能力去支持对FTL软件的调试与分析,且相关技术无法探测到空指针访问等特殊异常,这类异常通常会引起固件崩溃,相关技术仅通过调试代码分析FTL性能瓶颈,无法量化分析FTL算法的性能。本公开实施例提供一种闪存转换层仿真测试系统,以对FTL结合硬件加速器时对FTL进行低成本、高效率测试,并能够解决基于嵌入式控制器开发时无法被探测到的特殊异常,比如空指针访问。其次,通过该仿真测试系统可以借助其他测试分析工具分析FTL算法(例如IO测试软件(FIO等),以及包括GCC提供的一些侧写工具等)。
请参阅图1,图1示出了根据本公开一实施例的闪存转换层仿真测试系统的框图。
如图1所示,所述系统包括网络块设备10、虚拟化硬件加速器20、闪存转换层模块30及基于所述网络块设备10的虚拟化闪存40,其中,
所述网络块设备(Network Block Device,NBD)10,用于接收并转发测试信息,所述测试信息包括读指令和/或写指令及待写入数据;
所述虚拟化硬件加速器20,连接于所述网络块设备10及所述闪存转换层模块30,用于分配所述测试信息到所述虚拟化硬件加速器20的各个线程,并对所述闪存转换层模块30进行虚拟硬件加速;
所述闪存转换层模块30,连接于所述虚拟化闪存40及所述网络块设备10,用于根据所述测试信息对所述虚拟化闪存40进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器20将读操作结果返回所述网络块设备10,或,当所述测试信息包括写指令时,通过所述闪存转换层模块30将写操作结果返回所述网络块设备10。
通过以上系统,本公开实施例通过网络块设备接收并转发测试信息,通过虚拟化硬件减速器分配所述测试信息到所述虚拟化硬件加速器的各个线程,并对所述闪存转换层模块进行虚拟硬件加速,通过闪存转换层模块根据所述测试信息对所述虚拟化闪存进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器将读操作结果返回所述网络块设备,或,当所述测试信息包括写指令时,通过所述闪存转换层模块将写操作结果返回所述网络块设备,以使得闪存转换层在所述系统上进行测试、设计、开发,从而定位关键路径并分析闪存转换性能,对FTL固件中空指针访问等特殊异常具有较好的探测能力,提升FTL设计稳定性及开发效率。
本公开实施例的闪存转换层仿真测试系统可以基于各种平台架构实现,例如,可以基于X86平台,本公开实施例根据嵌入式控制器中固件与主机端、闪存端的交互方式,在X86平台中设计了虚拟化的前端(网络块设备)、后端(虚拟化闪存)与硬件加速器模块。基于这些虚拟化硬件模块,再组合嵌入式控制器固件中的FTL软件,从而构成了一个基于X86平台的虚拟化固态硬盘仿真系统。
本公开实施例的网络块设备10可以接收主机(如安装和计算机系统的计算机或其他电子设备)发出的测试信息,在一个示例中,可以在主机上设置NBD,使用网络块设备与计算机进行操作需要一个服务器和客户端模式,在服务器上,被称为“设备节点”的东西被维护,这通常是一个硬盘,一个磁盘阵列,或一种通常被称为磁盘映像的文件类型。服务器运行一小段称为后台程序的软件,允许客户端从服务器访问设备节点并将其本地安装,从客户端计算机的角度来看,访问设备节点就像访问任何其他磁盘驱动器一样。
本公开实施例对网络块设备NBD的具体实现方式不做限定,本领域技术人员可以参考相关技术实现,本公开实施通过NBD实现对闪存转换层FTL的测试,将前端接口由原来的nvme接口替换为NBD接口,对于在linux下的测试工具,以FIO为例,就等效于对一个nvme设备的操作转换到了对NBD设备的操作。这样在读写测试中便可观察到FTL模块的运行状态,包括是否异常(例如空指针访问)和性能数据,解决了利用SSD进行FTL测试的高成本、低效率的问题。
本公开实施例可以利用基于NBD的大文件模拟闪存介质,得到虚拟化闪存40,通过对大文件的读写操作模拟对闪存的操作,以降低测试成本,提高测试效率。
本公开实施例的虚拟化硬件加速器20通过软件模拟硬件加速器的功能,可以用来加速例如数据传递的效率,映射表的快速更新,快速查找,更高效的内存管理等功能。示例性的,虚拟硬件加速器模块可以设置多个线程间的队列以传递命令和数据,目的是实现各模块间的通信,同时采用相应算法模拟硬件加速器核心功能。本公开实施例对虚拟化硬件加速器20的具体实现方式不做限定,本领域技术人员可以根据相关技术实现。
本公开实施例的闪存转换层模块30可以是基于SSD的控制器的FTL软件得到的,例如,可以将SSD的嵌入式控制器中的FTL软件迁移到所述系统,以对FTL模块进行测试。
在一种可能的实施方式中,所述虚拟化硬件加速器20、所述闪存转换层模块30可以包括一个或多个线程,以模拟单核至多核CPU的软件设计,提高适应性及灵活性。
请参阅图2,图2示出了根据本公开一实施例的闪存转换层仿真测试系统的示意图。
在一种可能的实施方式中,如图2所示,所述网络块设备10包括网络块设备客户端110、网络块设备服务端120,
所述网络块设备客户端110用于接收测试请求,并解析所述测试请求得到所述测试信息;
所述网络块设备服务端120,用于根据所述测试信息的类型将所述测试信息中的指令入队列转发到所述虚拟化硬件加速器20、将待写入数据拷贝到所述虚拟化硬件加速器20。
在一个示例中,网络块设备客户端110和网络块设备服务端120合起来等效于实际固态硬盘中的nvme接口硬件,即控制器中的前端。客户端执行接收主机的读写请求等操作。服务端是上述客户端在接收到主机的请求后将这些请求转发给FTL内部,可以认为服务端是命令和数据的转发接口。
在一个示例中,如图2所示,在仿真过程中,该软件进程会创建一个基于网络块设备(NBD)的真实物理盘符,当主机向该盘符发送读写命令时,NBD server端会接收到这些读写命令并转发给虚拟化硬件加速器线程,再由硬件加速器线程将主机命令转化为FTL命令并派发至FTL模块进行处理,同时与FTL模块进行读写数据的传输。后端模块(虚拟化闪存40)仅仅与FTL模块进行通信,在接收FTL模块的读写命令后执行相应的文件读写操作。当读数据传输完成后,由硬件加速器模块执行完成响应,而当写数据传输完成后,由FTL模块执行完成响应,从而提高响应速度。
通过所述闪存转换层仿真测试系统,本公开实施例可直接借助测试工具对固态硬盘核心组件FTL进行功能和性能的仿真分析。
在一种可能的实施方式中,当所述测试信息包括写指令及待写入数据时,所述闪存转换层模块30还用于:
从所述虚拟化闪存40申请存储空间;
进行逻辑地址到物理地址的转换;
根据得到的物理地址将所述待写入数据写入申请到的存储空间,并将写操作结果返回所述网络块设备10。
在一种可能的实施方式中,当所述测试信息包括读指令时,所述闪存转换层模块30还用于:
进行逻辑地址到物理地址的转换;
根据转换得到的物理地址从虚拟化闪存40读取数据,将读操作结果返回所述虚拟化硬件加速器20。
本公开实施例对FTL进行地址转换的方式不做限定,对读取、写入数据的方式不做限定,本领域技术人员可以参考相关技术实现。
本公开实施例易于探测到FTL软件中空指针访问等特殊异常,提升FTL设计稳定性。由于系统具有物理设备块,因此可像真实固态硬盘一样实施各种测试用例,进而可统计到FTL模块测试信息,从而定位软件中关键路径并分析FTL性能及优化,比如主机读写IO路径是固件中的关键组成,因为它影响固态硬盘最终的性能水平,这条路径由很多软件函数接口组成,通过GCC的profile工具可以分析这些函数接口的调用频率,执行时间等信息,从而可以针对性的优化代码来减少固件在IO路径上的执行时间,最终提升固件在读写上的性能。基于该系统的模块化设计,FTL可以直接在该系统上进行设计开发,在功能与性能验证后可直接移植到嵌入式控制器中,提升开发效率。
本公开实施例的闪存转换层仿真测试系统,可以基于X86平台实施,因此可以借助常规针对于固态硬盘的测试工具对该系统进行测试分析。此外该系统基于模块化设计,各模块之间耦合性低,易于FTL软件从嵌入式控制器开发环境中移植到系统,反之亦然;同时当硬件加速器设计方案变化时,也仅仅需要修改虚拟硬件加速器模块即可,具有较大的灵活性,可以提升测试效率。
请参阅图3,图3示出了根据本公开一实施例的闪存转换层仿真测试方法的流程图。
如图3所示,所述方法包括:
步骤S11,产生网络块设备10、虚拟化硬件加速器20、闪存转换层模块30及基于所述网络块设备10的虚拟化闪存40;
步骤S12,利用所述网络块设备10接收并转发测试信息,所述测试信息包括读指令和/或写指令及待写入数据;
步骤S13,利用所述虚拟化硬件加速器20分配所述测试信息到所述虚拟化硬件加速器20的各个线程,并对所述闪存转换层模块30进行虚拟硬件加速;
步骤S14,利用所述闪存转换层模块30根据所述测试信息对所述虚拟化闪存40进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器20将读操作结果返回所述网络块设备10,或,当所述测试信息包括写指令时,通过所述闪存转换层模块30将写操作结果返回所述网络块设备10。
通过以上方法,本公开实施例通过网络块设备接收并转发测试信息,通过虚拟化硬件减速器分配所述测试信息到所述虚拟化硬件加速器的各个线程,并对所述闪存转换层模块进行虚拟硬件加速,通过闪存转换层模块根据所述测试信息对所述虚拟化闪存进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器将读操作结果返回所述网络块设备,或,当所述测试信息包括写指令时,通过所述闪存转换层模块将写操作结果返回所述网络块设备,以使得闪存转换层在所述系统上进行测试、设计、开发,从而定位关键路径并分析闪存转换性能,对FTL固件中空指针访问等特殊异常具有较好的探测能力,提升FTL设计稳定性及开发效率。
在一种可能的实施方式中,所述网络块设备10包括网络块设备客户端110、网络块设备服务端120,所述方法还包括:
利用所述网络块设备客户端110接收测试请求,并解析所述测试请求得到所述测试信息;
利用所述网络块设备服务端120根据所述测试信息的类型将所述测试信息中的指令入队列转发到所述虚拟化硬件加速器20、将待写入数据拷贝到所述虚拟化硬件加速器20。
在一种可能的实施方式中,当所述测试信息包括写指令及待写入数据时,所述方法还包括:
利用所述闪存转换层模块30执行以下操作:
从所述虚拟化闪存40申请存储空间;
进行逻辑地址到物理地址的转换;
根据得到的物理地址将所述待写入数据写入申请到的存储空间,并将写操作结果返回所述网络块设备10。
在一种可能的实施方式中,当所述测试信息包括读指令时,所述方法还包括:
利用所述闪存转换层模块30执行以下操作:
进行逻辑地址到物理地址的转换;
根据转换得到的物理地址从虚拟化闪存40读取数据,将读操作结果返回所述虚拟化硬件加速器20。
在一种可能的实施方式中,所述虚拟化硬件加速器20、所述闪存转换层模块30包括一个或多个线程。
可以理解,本公开提及的上述各个方法实施例,在不违背原理逻辑的情况下,均可以彼此相互结合形成结合后的实施例,限于篇幅,本公开不再赘述。本领域技术人员可以理解,在具体实施方式的上述方法中,各步骤的具体执行顺序应当以其功能和可能的内在逻辑确定。
应该说明的是,所述闪存转换层仿真测试方法为前述的闪存转换层仿真测试系统对应的方法项,其具体介绍请参考之前对系统的介绍,在此不再赘述。
本公开实施例的主机可以为电子设备,电子设备可以被提供为终端、服务器或其它形态的设备。
请参阅图4,图4示出了根据本公开一实施例的一种电子设备的框图。
例如,电子设备800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等终端。
参照图4,电子设备800可以包括以下一个或多个组件:处理组件802,存储器804,电源组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
处理组件802通常控制电子设备800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
存储器804被配置为存储各种类型的数据以支持在电子设备800的操作。这些数据的示例包括用于在电子设备800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件806为电子设备800的各种组件提供电力。电源组件806可以包括电源管理系统,一个或多个电源,及其他与为电子设备800生成、管理和分配电力相关联的组件。
多媒体组件808包括在所述电子设备800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当电子设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当电子设备800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件814包括一个或多个传感器,用于为电子设备800提供各个方面的状态评估。例如,传感器组件814可以检测到电子设备800的打开/关闭状态,组件的相对定位,例如所述组件为电子设备800的显示器和小键盘,传感器组件814还可以检测电子设备800或电子设备800一个组件的位置改变,用户与电子设备800接触的存在或不存在,电子设备800方位或加速/减速和电子设备800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如互补金属氧化物半导体(CMOS)或电荷耦合装置(CCD)图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件816被配置为便于电子设备800和其他设备之间有线或无线方式的通信。电子设备800可以接入基于通信标准的无线网络,如无线网络(WiFi),第二代移动通信技术(2G)或第三代移动通信技术(3G),或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种非易失性计算机可读存储介质,例如包括计算机程序指令的存储器804,上述计算机程序指令可由电子设备800的处理器820执行以完成上述方法。
请参阅图5,图5示出了根据本公开一实施例的一种电子设备的框图。
例如,电子设备1900可以被提供为一服务器。参照图5,电子设备1900包括处理组件1922,其进一步包括一个或多个处理器,以及由存储器1932所代表的存储器资源,用于存储可由处理组件1922的执行的指令,例如应用程序。存储器1932中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件1922被配置为执行指令,以执行上述方法。
电子设备1900还可以包括一个电源组件1926被配置为执行电子设备1900的电源管理,一个有线或无线网络接口1950被配置为将电子设备1900连接到网络,和一个输入输出(I/O)接口1958。电子设备1900可以操作基于存储在存储器1932的操作系统,例如微软服务器操作系统(Windows ServerTM),苹果公司推出的基于图形用户界面操作系统(Mac OSXTM),多用户多进程的计算机操作系统(UnixTM),自由和开放原代码的类Unix操作系统(LinuxTM),开放原代码的类Unix操作系统(FreeBSDTM)或类似。
在示例性实施例中,还提供了一种非易失性计算机可读存储介质,例如包括计算机程序指令的存储器1932,上述计算机程序指令可由电子设备1900的处理组件1922执行以完成上述方法。
本公开可以是系统、方法和/或计算机程序产品。计算机程序产品可以包括计算机可读存储介质,其上载有用于使处理器实现本公开的各个方面的计算机可读程序指令。
计算机可读存储介质可以是可以保持和存储由指令执行设备使用的指令的有形设备。计算机可读存储介质例如可以是(但不限于)电存储设备、磁存储设备、光存储设备、电磁存储设备、半导体存储设备或者上述的任意合适的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、静态随机存取存储器(SRAM)、便携式压缩盘只读存储器(CD-ROM)、数字多功能盘(DVD)、记忆棒、软盘、机械编码设备、例如其上存储有指令的打孔卡或凹槽内凸起结构、以及上述的任意合适的组合。这里所使用的计算机可读存储介质不被解释为瞬时信号本身,诸如无线电波或者其他自由传播的电磁波、通过波导或其他传输媒介传播的电磁波(例如,通过光纤电缆的光脉冲)、或者通过电线传输的电信号。
这里所描述的计算机可读程序指令可以从计算机可读存储介质下载到各个计算/处理设备,或者通过网络、例如因特网、局域网、广域网和/或无线网下载到外部计算机或外部存储设备。网络可以包括铜传输电缆、光纤传输、无线传输、路由器、防火墙、交换机、网关计算机和/或边缘服务器。每个计算/处理设备中的网络适配卡或者网络接口从网络接收计算机可读程序指令,并转发该计算机可读程序指令,以供存储在各个计算/处理设备中的计算机可读存储介质中。
用于执行本公开操作的计算机程序指令可以是汇编指令、指令集架构(ISA)指令、机器指令、机器相关指令、微代码、固件指令、状态设置数据、或者以一种或多种编程语言的任意组合编写的源代码或目标代码,所述编程语言包括面向对象的编程语言—诸如Smalltalk、C++等,以及常规的过程式编程语言—诸如“C”语言或类似的编程语言。计算机可读程序指令可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络—包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。在一些实施例中,通过利用计算机可读程序指令的状态信息来个性化定制电子电路,例如可编程逻辑电路、现场可编程门阵列(FPGA)或可编程逻辑阵列(PLA),该电子电路可以执行计算机可读程序指令,从而实现本公开的各个方面。
这里参照根据本公开实施例的方法、装置(系统)和计算机程序产品的流程图和/或框图描述了本公开的各个方面。应当理解,流程图和/或框图的每个方框以及流程图和/或框图中各方框的组合,都可以由计算机可读程序指令实现。
这些计算机可读程序指令可以提供给通用计算机、专用计算机或其它可编程数据处理装置的处理器,从而生产出一种机器,使得这些指令在通过计算机或其它可编程数据处理装置的处理器执行时,产生了实现流程图和/或框图中的一个或多个方框中规定的功能/动作的装置。也可以把这些计算机可读程序指令存储在计算机可读存储介质中,这些指令使得计算机、可编程数据处理装置和/或其他设备以特定方式工作,从而,存储有指令的计算机可读介质则包括一个制造品,其包括实现流程图和/或框图中的一个或多个方框中规定的功能/动作的各个方面的指令。
也可以把计算机可读程序指令加载到计算机、其它可编程数据处理装置、或其它设备上,使得在计算机、其它可编程数据处理装置或其它设备上执行一系列操作步骤,以产生计算机实现的过程,从而使得在计算机、其它可编程数据处理装置、或其它设备上执行的指令实现流程图和/或框图中的一个或多个方框中规定的功能/动作。
附图中的流程图和框图显示了根据本公开的多个实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或指令的一部分,所述模块、程序段或指令的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
该计算机程序产品可以具体通过硬件、软件或其结合的方式实现。在一个可选实施例中,所述计算机程序产品具体体现为计算机存储介质,在另一个可选实施例中,计算机程序产品具体体现为软件产品,例如软件开发包(Software Development Kit,SDK)等等。
以上已经描述了本公开的各实施例,上述说明是示例性的,并非穷尽性的,并且也不限于所披露的各实施例。在不偏离所说明的各实施例的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。本文中所用术语的选择,旨在最好地解释各实施例的原理、实际应用或对市场中的技术的改进,或者使本技术领域的其它普通技术人员能理解本文披露的各实施例。
Claims (8)
1.一种闪存转换层仿真测试系统,其特征在于,所述系统包括网络块设备、虚拟化硬件加速器、闪存转换层模块及基于所述网络块设备的虚拟化闪存,其中,
所述网络块设备,用于接收并转发测试信息,所述测试信息包括读指令和/或写指令及待写入数据;
所述虚拟化硬件加速器,连接于所述网络块设备及所述闪存转换层模块,用于分配所述测试信息到所述虚拟化硬件加速器的各个线程,并对所述闪存转换层模块进行虚拟硬件加速;
所述闪存转换层模块,连接于所述虚拟化闪存及所述网络块设备,用于根据所述测试信息对所述虚拟化闪存进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器将读操作结果返回所述网络块设备,或,当所述测试信息包括写指令时,通过所述闪存转换层模块将写操作结果返回所述网络块设备,所述网络块设备包括网络块设备客户端、网络块设备服务端,
所述网络块设备客户端用于接收测试请求,并解析所述测试请求得到所述测试信息;
所述网络块设备服务端,用于根据所述测试信息的类型将所述测试信息中的指令入队列转发到所述虚拟化硬件加速器、将待写入数据拷贝到所述虚拟化硬件加速器。
2.根据权利要求1所述的系统,其特征在于,所述虚拟化硬件加速器、所述闪存转换层模块包括一个或多个线程。
3.根据权利要求1所述的系统,其特征在于,当所述测试信息包括写指令及待写入数据时,所述闪存转换层模块还用于:
从所述虚拟化闪存申请存储空间;
进行逻辑地址到物理地址的转换;
根据得到的物理地址将所述待写入数据写入申请到的存储空间,并将写操作结果返回所述网络块设备。
4.根据权利要求1所述的系统,其特征在于,当所述测试信息包括读指令时,所述闪存转换层模块还用于:
进行逻辑地址到物理地址的转换;
根据转换得到的物理地址从虚拟化闪存读取数据,将读操作结果返回所述虚拟化硬件加速器。
5.一种闪存转换层仿真测试方法,其特征在于,所述方法包括:
产生网络块设备、虚拟化硬件加速器、闪存转换层模块及基于所述网络块设备的虚拟化闪存;
利用所述网络块设备接收并转发测试信息,所述测试信息包括读指令和/或写指令及待写入数据;
利用所述虚拟化硬件加速器分配所述测试信息到所述虚拟化硬件加速器的各个线程,并对所述闪存转换层模块进行虚拟硬件加速;
利用所述闪存转换层模块根据所述测试信息对所述虚拟化闪存进行操作,得到操作结果,其中,当所述测试信息包括读指令时,通过所述虚拟化硬件加速器将读操作结果返回所述网络块设备,或,当所述测试信息包括写指令时,通过所述闪存转换层模块将写操作结果返回所述网络块设备,所述网络块设备包括网络块设备客户端、网络块设备服务端,所述方法还包括:
利用所述网络块设备客户端接收测试请求,并解析所述测试请求得到所述测试信息;
利用所述网络块设备服务端根据所述测试信息的类型将所述测试信息中的指令入队列转发到所述虚拟化硬件加速器、将待写入数据拷贝到所述虚拟化硬件加速器。
6.根据权利要求5所述的方法,其特征在于,当所述测试信息包括写指令及待写入数据时,所述方法还包括:
利用所述闪存转换层模块执行以下操作:
从所述虚拟化闪存申请存储空间;
进行逻辑地址到物理地址的转换;
根据得到的物理地址将所述待写入数据写入申请到的存储空间,并将写操作结果返回所述网络块设备。
7.根据权利要求5所述的方法,其特征在于,当所述测试信息包括读指令时,所述方法还包括:
利用所述闪存转换层模块执行以下操作:
进行逻辑地址到物理地址的转换;
根据转换得到的物理地址从虚拟化闪存读取数据,将读操作结果返回所述虚拟化硬件加速器。
8.根据权利要求5所述的方法,其特征在于,所述虚拟化硬件加速器、所述闪存转换层模块包括一个或多个线程。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110812619.2A CN113342697B (zh) | 2021-07-19 | 2021-07-19 | 闪存转换层仿真测试系统及方法 |
US17/555,130 US11537329B1 (en) | 2021-07-19 | 2021-12-17 | Emulation test system for flash translation layer and method thereof |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110812619.2A CN113342697B (zh) | 2021-07-19 | 2021-07-19 | 闪存转换层仿真测试系统及方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113342697A CN113342697A (zh) | 2021-09-03 |
CN113342697B true CN113342697B (zh) | 2022-08-26 |
Family
ID=77480018
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110812619.2A Active CN113342697B (zh) | 2021-07-19 | 2021-07-19 | 闪存转换层仿真测试系统及方法 |
Country Status (2)
Country | Link |
---|---|
US (1) | US11537329B1 (zh) |
CN (1) | CN113342697B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20230342070A1 (en) * | 2022-04-22 | 2023-10-26 | Western Digital Technologies, Inc. | Configurable Arithmetic HW Accelerator |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103744612A (zh) * | 2013-12-17 | 2014-04-23 | 记忆科技(深圳)有限公司 | 基于闪存转换层的精简配置的方法及其系统 |
CN107870870A (zh) * | 2016-09-28 | 2018-04-03 | 北京忆芯科技有限公司 | 访问超过地址总线宽度的内存空间 |
EP3608787A1 (en) * | 2018-08-07 | 2020-02-12 | Marvell World Trade Ltd. | Virtualizing isolation areas of solid-state storage media |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
IL154481A0 (en) * | 2001-08-14 | 2003-09-17 | Axis Systems Inc | Vcd-on-demand system and method |
US8041878B2 (en) * | 2003-03-19 | 2011-10-18 | Samsung Electronics Co., Ltd. | Flash file system |
US7398337B2 (en) * | 2005-02-25 | 2008-07-08 | International Business Machines Corporation | Association of host translations that are associated to an access control level on a PCI bridge that supports virtualization |
US8683456B2 (en) * | 2009-07-13 | 2014-03-25 | Apple Inc. | Test partitioning for a non-volatile memory |
KR101702366B1 (ko) * | 2010-12-22 | 2017-02-03 | 삼성전자주식회사 | 동적으로 확장 가능한 기능을 제공하는 스토리지 장치 및 그것의 동작 방법 |
CN103543955A (zh) * | 2013-08-05 | 2014-01-29 | 记忆科技(深圳)有限公司 | 利用固态硬盘作为设备读缓存的方法、系统及固态硬盘 |
CN104503707B (zh) * | 2014-12-24 | 2018-03-06 | 华为技术有限公司 | 读取数据的方法以及装置 |
US9910619B2 (en) * | 2015-12-21 | 2018-03-06 | Toshiba Memory Corporation | Dual buffer solid state drive |
US10241956B2 (en) * | 2016-09-12 | 2019-03-26 | International Business Machines Corporation | Virtualizing coherent hardware accelerators |
US10860357B1 (en) * | 2017-04-18 | 2020-12-08 | Amazon Technologies, Inc. | Secure reconfiguring programmable hardware with host logic comprising a static portion and a reconfigurable portion |
CN109445691B (zh) * | 2018-10-16 | 2022-03-29 | 深圳忆联信息系统有限公司 | 一种提高ftl算法开发和验证效率的方法及装置 |
US10970228B2 (en) * | 2018-12-14 | 2021-04-06 | Micron Technology, Inc. | Mapping table compression using a run length encoding algorithm |
CN109710187B (zh) * | 2018-12-24 | 2022-12-02 | 深圳忆联信息系统有限公司 | NVMe SSD主控芯片的读命令加速方法、装置、计算机设备及存储介质 |
KR20210125477A (ko) * | 2019-02-11 | 2021-10-18 | 인텔 코포레이션 | 가상 플래시 |
-
2021
- 2021-07-19 CN CN202110812619.2A patent/CN113342697B/zh active Active
- 2021-12-17 US US17/555,130 patent/US11537329B1/en active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103744612A (zh) * | 2013-12-17 | 2014-04-23 | 记忆科技(深圳)有限公司 | 基于闪存转换层的精简配置的方法及其系统 |
CN107870870A (zh) * | 2016-09-28 | 2018-04-03 | 北京忆芯科技有限公司 | 访问超过地址总线宽度的内存空间 |
EP3608787A1 (en) * | 2018-08-07 | 2020-02-12 | Marvell World Trade Ltd. | Virtualizing isolation areas of solid-state storage media |
Also Published As
Publication number | Publication date |
---|---|
US20230014058A1 (en) | 2023-01-19 |
CN113342697A (zh) | 2021-09-03 |
US11537329B1 (en) | 2022-12-27 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10346036B2 (en) | Apparatus and method of executing plural objects displayed on a screen of an electronic device, and computer-readable recording medium for recording the method | |
US9261995B2 (en) | Apparatus, method, and computer readable recording medium for selecting object by using multi-touch with related reference point | |
CN105653084B (zh) | 屏幕配置方法、电子设备和存储介质 | |
CN109429102B (zh) | 用于显示应用的电子装置及服务器 | |
CN108463799B (zh) | 电子设备的柔性显示器及其操作方法 | |
KR102193404B1 (ko) | 상호작용 개발 환경으로부터의 소프트웨어 아티팩트의 점진적 컴파일링 기법 | |
EP3614250A1 (en) | Data processing method and electronic device | |
EP3207458A1 (en) | Input signal emulation | |
KR20180110395A (ko) | 플러그인 서비스를 포함하는 결제 서비스 제공 방법 및 그 전자장치 | |
EP3757739A1 (en) | Method for display when exiting an application, and terminal | |
US20190212858A1 (en) | Flexible device and operation method of flexible device | |
KR20170127809A (ko) | 전자 장치 및 전자 장치에서의 정보 제공 방법 | |
US9990912B2 (en) | Electronic device and method for reproducing sound in the electronic device | |
US20140164186A1 (en) | Method for providing application information and mobile terminal thereof | |
CN113342697B (zh) | 闪存转换层仿真测试系统及方法 | |
US20190369827A1 (en) | Remote data input framework | |
US10740252B2 (en) | Serial peripheral interface filter for processor security | |
US10929085B2 (en) | Electronic apparatus for controlling display of virtual input interface in environment of a plurality of output screens and operating method thereof | |
US20180004380A1 (en) | Screen display method and electronic device supporting the same | |
CN110162251B (zh) | 图像缩放方法及装置、存储介质、电子设备 | |
CN112988194A (zh) | 基于设备信息的程序优化方法、装置、电子设备及存储介质 | |
CN117667241B (zh) | 设备加载方法、装置、电子设备及存储介质 | |
KR20170065295A (ko) | 외부 전자 장치를 제어하는 전자 장치 및 동작 방법 | |
CN116401017B (zh) | 虚拟显卡的实现方法、装置、设备和存储介质 | |
CN104239244B (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 | ||
CP03 | Change of name, title or address | ||
CP03 | Change of name, title or address |
Address after: Room 601-606, No. 40, Lane 565, Shengxia Road, Pudong New Area (Shanghai) Pilot Free Trade Zone, Shanghai, October 2012 Patentee after: Yingren Technology Co.,Ltd. Address before: 2 / F, No.1, Lane 500, shengxia Road, Shanghai pilot Free Trade Zone, 201210 Patentee before: Yingren Technology (Shanghai) Co.,Ltd. |