闪存接口的性能评估方法及相关装置制造方法及图纸

技术编号:38842343 阅读:15 留言:0更新日期:2023-09-17 09:55
本申请实施例涉及存储设备应用领域,公开了一种闪存接口的性能评估方法及相关装置,闪存接口的性能评估方法包括:获取IO模型的信息;根据IO模型的信息生成IO命令,并将若干个IO命令存放至不同的命令队列;根据命令队列的状态执行IO命令;根据在命令执行总时间内执行完成的IO命令的数量,计算每种命令类型对应的闪存接口带宽。通过根据IO模型的信息生成IO命令,将若干个IO命令存放至不同的命令队列,并根据命令队列的状态执行IO命令,以及根据在命令执行总时间内执行完成的IO命令的数量,计算每种命令类型对应的闪存接口带宽,本申请能够准确评估闪存接口在纯读、纯写或混合读写场景下的理论性能,而不依赖任何硬件实现。而不依赖任何硬件实现。而不依赖任何硬件实现。

【技术实现步骤摘要】
闪存接口的性能评估方法及相关装置


[0001]本申请涉及存储设备应用领域,特别是涉及一种闪存接口的性能评估方法及相关装置。

技术介绍

[0002]闪存设备,例如:固态硬盘(Solid State Drives,SSD),是采用固态电子存储芯片阵列而制成的硬盘,固态硬盘包括控制单元和存储单元(FLASH存储芯片或 DRAM存储芯片)。在对闪存设备进行性能评估时,需要评估闪存接口的性能。
[0003]目前,通常采用先计算读(写)请求数据传输时间和读(写)请求等待时间,然后根据读(写)请求等待时间和(n

1)*读(写)请求数据传输时间的关系,确定读(写)带宽的方式评估闪存接口的性能,其中,n为一个通道内裸片(Die)的数量。然而,这种方式只能针对纯读和纯写场景进行评估,无法评估混合读写场景下闪存接口的性能;且未考虑命令和地址传输时间及查询时间,性能评估不够准确。

技术实现思路

[0004]本申请实施例提供一种闪存接口的性能评估方法及相关装置,以准确评估闪存接口在纯读、纯写或混合读写场景下的理论性能。
[0005]本申请实施例提供以下技术方案:第一方面,本申请实施例提供一种闪存接口的性能评估方法,包括:获取IO模型的信息;根据IO模型的信息生成IO命令,并将若干个IO命令存放至不同的命令队列;根据命令队列的状态执行IO命令;根据在命令执行总时间内执行完成的IO命令的数量,计算每种命令类型对应的闪存接口带宽。
[0006]在一些实施例中,IO模型的信息包括命令类型、每一种命令类型对应的命令数据大小、每一种命令类型对应的带宽占比;根据IO模型的信息生成IO命令,并将若干个IO命令存放至不同的命令队列,包括:根据带宽占比,计算每一种命令类型对应的命令类型数量占比;根据命令类型数量占比,确定每种命令类型对应的命令类型占比区间;基于随机算法生成一个随机数,计算随机数对应的区间概率,其中,随机数对应的区间概率=随机数的数值/随机数的区间范围;根据区间概率对应的命令类型占比区间,确定待生成的IO命令的命令类型,以生成IO命令;将每一IO命令依次存放至不同的命令队列,直至生成的IO命令的个数大于或等于预设命令个数阈值。
[0007]在一些实施例中,该闪存接口的性能评估方法应用于闪存命令执行模拟器,闪存
命令执行模拟器包括命令模拟执行器,命令模拟执行器包括队列调度器、写命令执行器和读命令执行器,命令队列与队列调度器一一对应;命令队列的状态包括空闲状态和执行状态;根据命令队列的状态执行IO命令,包括:控制队列调度器遍历命令队列,获取处于空闲状态的命令队列中的IO命令;根据IO命令的命令类型,控制写命令执行器或读命令执行器执行IO命令,以得到第一执行时间;根据第一执行时间,控制队列调度器更新命令执行总时间和队列深度;控制队列调度器将命令队列的状态修改为执行状态,并将当前队列的开始执行时间设置为更新后的命令执行总时间。
[0008]在一些实施例中,根据命令队列的状态执行IO命令,还包括:控制写命令执行器或读命令执行器,执行处于执行状态的命令队列中的IO命令,以得到第二执行时间和IO命令的执行状态;根据第二执行时间,控制队列调度器更新命令执行总时间;在IO命令的执行状态为完成状态时,控制队列调度器将命令队列的状态修改为空闲状态,其中,IO命令的执行状态包括未完成状态和完成状态。
[0009]在一些实施例中,根据IO命令的命令类型,控制写命令执行器或读命令执行器执行IO命令,以得到第一执行时间,包括:若写命令执行器处于发送命令状态,则控制写命令执行器计算发送写命令和地址的时间、数据传输时间与第一执行时间,并确定IO命令的执行状态为未完成状态,其中,第一执行时间=发送写命令和地址的时间+数据传输时间;若写命令执行器不处于发送命令状态,则控制写命令执行器执行写查询命令,并记录写查询命令对应的写查询时间;在命令执行总时间与当前队列的开始执行时间之差大于编程等待时间时,确定IO命令的执行状态为完成状态,并确定第一执行时间为所述写查询时间;在命令执行总时间与当前队列的开始执行时间之差小于或等于编程等待时间时,确定IO命令的执行状态为未完成状态,并确定第一执行时间为写查询时间。
[0010]在一些实施例中,根据IO命令的命令类型,控制写命令执行器或读命令执行器执行IO命令,以得到第一执行时间,还包括:若读命令执行器处于发送命令状态,则控制读命令执行器计算发送读命令和地址的时间与第一执行时间,并确定IO命令的执行状态为未完成状态;若读命令执行器不处于发送命令状态,则控制读命令执行器执行读查询命令,并记录读查询命令对应的读查询时间;在命令执行总时间与当前队列的开始执行时间之差大于编程等待时间时,控制读命令执行器进行数据传输,并计算数据传输时间;确定IO命令的执行状态为完成状态,并计算第一执行时间;在命令执行总时间与当前队列的开始执行时间之差小于或等于编程等待时间时,确定IO命令的执行状态为未完成状态,并确定第一执行时间为读查询时间。
[0011]在一些实施例中,每种命令类型对应的闪存接口带宽=闪存设备的通道数目*命令
数据大小*IO命令的数量/命令执行总时间。
[0012]第二方面,本申请实施例提供一种闪存命令执行模拟器,应用如第一方面所述的闪存接口的性能评估方法,闪存命令执行模拟器包括:命令生成器,用于根据IO模型的信息,生成IO命令,并将若干个IO命令存放至不同的命令队列;命令模拟执行器,用于根据命令队列的状态,执行IO命令。
[0013]在一些实施例中,命令模拟执行器包括队列调度器、写命令执行器和读命令执行器,其中,队列调度器,用于控制写命令执行器或读命令执行器执行IO命令,得到第一执行时间或第二执行时间,以及IO命令的执行状态,以更新命令执行总时间和命令队列的状态,其中,命令队列的状态包括空闲状态和执行状态;写命令执行器,用于执行写命令,计算第一执行时间或第二执行时间,并确定IO命令的执行状态,其中,IO命令的执行状态包括未完成状态和完成状态;读命令执行器,用于执行读命令,计算第一执行时间或第二执行时间,并确定IO命令的执行状态。
[0014]第三方面,本申请实施例提供一种存储控制芯片,包括:如第二方面的闪存命令执行模拟器。
[0015]第四方面,本申请实施例提供一种闪存设备,包括:如第三方面的存储控制芯片;至少一个闪存介质,与存储控制芯片通信连接。
[0016]第五方面,本申请实施例还提供了一种非易失性计算机可读存储介质,非易失性计算机可读存储介质存储有计算机可执行指令,计算机可执行指令用于使闪存设备能够执行第一方面的闪存接口的性能评估方法。
[0017]本申请实施例的有益效果是:区别于现有技术的情况下,本申请实施例提供一种闪存接口的性能评估方法,该闪存接口的性能评估方法包括:获取IO模型的信息;根据IO模型的信息生成IO命令,并将若干个IO命令存放至不同的命令队列;根据命令队列的状态执行IO命令;根据在命令执行总时间内执行完成本文档来自技高网
...

【技术保护点】

【技术特征摘要】
1.一种闪存接口的性能评估方法,其特征在于,包括:获取IO模型的信息;根据所述IO模型的信息生成IO命令,并将若干个所述IO命令存放至不同的命令队列;根据所述命令队列的状态执行所述IO命令;根据在命令执行总时间内执行完成的所述IO命令的数量,计算每种命令类型对应的闪存接口带宽。2.根据权利要求1所述的方法,其特征在于,所述IO模型的信息包括命令类型、每一种命令类型对应的命令数据大小、每一种命令类型对应的带宽占比;所述根据所述IO模型的信息生成IO命令,并将若干个所述IO命令存放至不同的命令队列,包括:根据所述带宽占比,计算每一种命令类型对应的命令类型数量占比;根据所述命令类型数量占比,确定每种命令类型对应的命令类型占比区间;基于随机算法生成一个随机数,计算所述随机数对应的区间概率,其中,所述随机数对应的区间概率=随机数的数值/随机数的区间范围;根据所述区间概率对应的命令类型占比区间,确定待生成的IO命令的命令类型,以生成IO命令;将每一所述IO命令依次存放至不同的命令队列,直至生成的IO命令的个数大于或等于预设命令个数阈值。3.根据权利要求1所述的方法,其特征在于,所述方法应用于闪存命令执行模拟器,所述闪存命令执行模拟器包括命令模拟执行器,所述命令模拟执行器包括队列调度器、写命令执行器和读命令执行器,所述命令队列与所述队列调度器一一对应;所述命令队列的状态包括空闲状态和执行状态;所述根据所述命令队列的状态执行所述IO命令,包括:控制所述队列调度器遍历所述命令队列,获取处于空闲状态的命令队列中的IO命令;根据所述IO命令的命令类型,控制写命令执行器或读命令执行器执行所述IO命令,以得到第一执行时间;根据所述第一执行时间,控制所述队列调度器更新所述命令执行总时间和队列深度;控制所述队列调度器将所述命令队列的状态修改为执行状态,并将当前队列的开始执行时间设置为更新后的命令执行总时间。4.根据权利要求3所述的方法,其特征在于,所述根据所述命令队列的状态执行所述IO命令,还包括:控制写命令执行器或读命令执行器,执行处于执行状态的命令队列中的IO命令,以得到第二执行时间和IO命令的执行状态;根据所述第二执行时间,控制所述队列调度器更新所述命令执行总时间;在所述IO命令的执行状态为完成状态时,控制所述队列调度器将所述命令队列的状态修改为空闲状态,其中,所述IO命令的执行状态包括未完成状态和完成状态。5.根据权利要求3所述的方法,其特征在于,所述根据所述IO命令的命令类型,控制写命令执行器或读命令执行器执行所述IO命令,以得到第一执行时间,包括:若所述写命令执行器处于发送命令状态,则控制所述写命令执行器计算发送写命令和
地址的时间、数据传输时间与第一执行时间,并确定所述命令队列的状态为未完成状态,其中,所述第一执行时间=发送写命令和地址的时间+数据传输时间;若所述写命令执行器不处于发送命令状态,则控制...

【专利技术属性】
技术研发人员:张文刚杨颖万红波
申请(专利权)人:深圳大普微电子科技有限公司
类型:发明
国别省市:

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1