NVMe系统内存结构 - 完成消息格式

本文详细解析了NVMe协议中的完成消息格式,包括StatusField的各个位域含义、StatusCodeType的不同取值以及MediaErrors类型的错误分类。重点介绍了如何通过SQID、CID和StatusField跟踪命令状态和潜在错误。
摘要由CSDN通过智能技术生成


本文属于《 NVMe协议基础系列教程》之一,欢迎查看其它文章。

命令需要被提交到Submission Queue中,以便NVMe控制器执行,在执行结束后,会有对应的完成状态,放入到Completion Queue中。
NVMe命令长度均为64Byte,对应的Completion消息长度均为16Byte。

1 完成消息定义

每条完成消息的大小为16字节,其数据结构,如下图所示:
在这里插入图片描述

  • Dword 0的内容是特定于命令的。如果一个命令使用Dword 0,那么这个Dword的定义,包含在关联的命令定义中。如果命令不使用Dword 0,则保留该字段。
  • Dword 1是保留的。
  • Dword 2与Dword 3,都在下表中定义。将来定义的任何附加的l/O Command Set都可以使用另一种Completion Queue条目大小或格式。
Dword 2
BitDescription
31:16SQ Identifier (SQID):表示当前完成消息,对应命令所在的Submission Queue的ID值。
当多个Submission Queue共享一个Completion Queue时,可以用SQID与Command Identifier (CID)唯一地确定已完成的命令,主机软件才需要使用此字段。除此以外,此字段保留。
15:00SQ Head Pointer (SQHD):表示SQID标识的Submission Queue的当前Head指针。
这用于向主机指示,已使用的Submission Queue条目,这些条目处于空闲,可重新用于新条目。

注意: 返回的值,是创建Completion Queue条目时,SQ Head pointer的值。在宿主软件消耗Completion Queue条目的时候,控制器可能有一个SQ Head pointer,它已经超出了所指示的值。
Dword 3
BitDescription
31:17Status Field (SF):表示正在执行的命令的状态。
16Phase Tag ( P ):标识一个Completion Queue条目是否是新的。
在将CC.EN设置为“1”之前,主机软件应将所有Completion Queue条目的Phase Tag值初始化为“0”。当控制器在Completion Queue中放置一个条目时,它应该反转Phase Tag,使主机软件能够识别一个新条目。
1)具体来说,对于CC.EN设置为’ 1 ‘后的第一组Completion Queue条目,所有Phase Tag在发布时都设置为’ 1 '。
2)对于第二组Completion Queue条目,当控制器绕到Completion Queue顶部时,所有Phase Tag在发布时清除为“0”。
Phase Tag的值,在每次通过Completion Queue时被反转。
15:00Command Identifier (CID):表示正在执行的命令的标识符。
当命令提交到Submission Queue时,该标识符由主机软件分配。SQ标识符(SQID)和命令标识符(CID)的组合,可以唯一标识正在执行的命令。最大未完成请求数为64K。

2 Status Field定义

在完成消息的Dword 3中Status Field字段(31:17),其各个位域定义,如下表所示。

Dword 3.Status Field
BitDescription
31Do Not Retry (DNR):如果设置为’ 1 ',表示如果再次提交相同的命令,则预期会失败。
如果清除为“0”,表示重试相同的命令可能会成功。
如果一个命令由于时间限制的错误恢复而被放弃,这个字段应该被清除为“0”。
30More (M):如果设置为’ 1 ',则此命令的更多状态信息可以作为错误信息日志的一部分,可以使用Get Log Page命令检索。
如果清除为“0”,则此命令没有额外的状态信息。
29:28保留
27:25Status Code Type (SCT):表示Completion Queue条目的状态码类型。这表示控制器返回的状态类型。
24:17Status Code (SC):表示一个状态码,用于标识所指示命令的任何错误或状态信息。

Status Field的值为0h,表示命令完成成功,没有致命或非致命错误条件。

2.1 Status Code Type (SCT)

SCT状态码类型,取值情况,如下表所示:

ValueDescription
0hGeneric Command Status:表示本完成消息,所对应的命令已经完成。
这些状态值在所有命令类型中都是通用的,包括成功、不支持操作码和无效字段等条件。
1hCommand Specific Status:表示特定于特定命令opcode的状态值。这些值可能表明需要额外的处理。
此类型会报告状态值,如无效的固件映像或超过最大队列数。
2hMedia Errors:发生在NVM或数据完整性类型错误中的,任何媒体特定错误,都应属于这种类型。
3h ~ 6h保留
7h特定于供应商的

2.2 Status Code (SC)

完成消息中的状态码(SC),表示命令完成的更详细状态信息。
状态码的值,分为三个范围:

  • 00h ~ 7Fh:适用于Admin Command Set,或跨多个命令集。
  • 80h ~ BFh:I/O Command Set特定的状态码。
  • C0h ~ FFh:供应商特定的状态码。

如果有多个状态码,适用于特定的命令故障,控制器应报告具有最小数值的状态码。

2.2.1 Generic Command Status类型

Generic Command Status类型的状态码,取值情况,如下所示。
在这里插入图片描述
在这里插入图片描述
这些状态值,在许多不同类型的命令中是通用的。
从上述,也可以看出,状态码分为了三个范围:00h ~ 7Fh,80h ~ BFh,C0h ~ FFh。

2.2.2 Command Specific Status类型

Command Specific Status类型的状态码,取值情况,如下所示。
在这里插入图片描述
在这里插入图片描述

2.2.3 Media Errors类型

在这里插入图片描述
在这里插入图片描述

  • 22
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: NVMe(Non-Volatile Memory Express)是一种基于PCIe总线的高性能存储接口标准。NVMe SCSI(Small Computer System Interface)是在NVMe基础上将SCSI命令映射到NVMe的一种实现方式。 NVMe SCSI是一种在NVMe存储设备上执行SCSI命令的协议。其中,NVMe SCSI Primary Commands - 5是一组用于执行传输数据、控制设备和查询设备信息的SCSI命令。 这组命令包括读取命令(Read Command)、写入命令(Write Command)、写入长命令(Write Long Command)、写入同步命令(Write Synchronization Command)和预取命令(Prefetch Command)。 读取命令用于从存储设备中读取数据。可以通过设置数据传输长度和传输起始位置来指定需要读取的数据范围。 写入命令用于向存储设备中写入数据。与读取命令类似,可以设置数据传输长度和传输起始位置来指定写入的数据范围。 写入长命令用于写入长数据。相比于写入命令,写入长命令支持更大的数据传输长度。 写入同步命令用于在写入数据之前先进行一个或多个同步确认。这样可以确保之前的所有写入操作都完成后再进行下一个写入操作。 预取命令用于指定设备预取机制的信息,以优化读取性能。 总之,NVMe SCSI Primary Commands - 5是一组在NVMe设备上执行SCSI命令的指令集,用于实现数据读取、写入、同步和预取等操作,提供了高性能和效率的存储访问方式。 ### 回答2: NVMe(Non-Volatile Memory Express)是一种高性能存储接口协议,它的SCSI(Small Computer System Interface)主要命令集中的第5个命令被称为NVMe SCSI Primary Command - 5。 具体而言,NVMe SCSI Primary Command - 5是用于完成NVMe设备通信的主要命令之一。它允许主机与NVMe设备之间进行读写操作,以获取或修改存储在设备上的数据。 通过进行读取操作,NVMe SCSI Primary Command - 5命令可以传输存储在NVMe设备中的数据到主机中。这对于从存储设备中获取文件和信息非常有用。主机可以指定读取的起始地址和读取的数据长度,以确保获取正确的数据。 与读取操作相反,NVMe SCSI Primary Command - 5也支持写入操作。主机可以将数据写入NVMe设备,以便在存储中创建、修改或更新文件和信息。通过指定写入的起始地址和写入的数据长度,主机可以确保写入正确的位置和适当的数据。 总的来说,NVMe SCSI Primary Command - 5命令是与NVMe设备通信的关键命令之一。它通过读取和写入操作,允许主机与NVMe设备之间高效地传输数据。 ### 回答3: NVMe SCSI primary commands - 5,是指NVMe(Non-volatile Memory Express)SCSI(Small Computer System Interface)主要命令的第五个版本。 第五版的NVMe SCSI primary commands扩展了之前版本的功能,提供了更高的性能和更丰富的功能支持。这些命令是用于与NVMe设备进行通信和控制的指令集。 NVMe是一种针对固态存储器(SSD)的高速、低延迟、高吞吐量的连接协议。SCSI是一种通用的存储设备接口,用于连接计算机和外部存储设备。 NVMe SCSI主要命令-5包括了以下几个方面的功能: 1. 带宽管理:命令集提供了更灵活的带宽管理功能,可以根据需要灵活地分配和管理带宽资源,以最大程度地提高系统性能。 2. 多路径支持:命令集扩展了多路径支持的功能,使得在多条路径之间进行负载平衡和故障转移更加灵活和可靠。 3. 电源管理:命令集增加了更多的电源管理命令,以支持设备的低功耗状态和快速唤醒。 4. 安全性增强:命令集引入了更多的安全性增强功能,包括加密、数据完整性保护等,以保护存储数据的安全性。 5. 性能优化:命令集提供了更多的性能优化命令,包括请求队列管理、命令优先级管理等,以提高系统性能和响应速度。 总之,NVMe SCSI主要命令-5是为了更好地满足NVMe设备的高性能和高可靠性需求而设计的指令集。通过扩展功能和提供更多的控制能力,它可以提供更优秀的存储性能和多样化的应用场景支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

百里杨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值