第4章 消息服务模型与控制原语 - 页码54
NVMe-MI 1 min read

第4章 消息服务模型与控制原语 - 页码54

Blog Author

继续深入分析 NVM Express® Management Interface Specification, Revision 2.0 中第 55 页的内容,这部分详细描述了 命令消息处理的状态机,包括 Process(处理)Transmit(传输)Control Primitives(控制原语) 的相关内容。我们将逐步分析每个部分。


命令消息处理状态(继续)

Process(处理)状态

处理(Process) 状态下,命令消息的实际处理工作会开始,包括以下步骤:

  • 错误检查:验证命令消息是否正确。
  • 执行命令:根据命令消息的内容执行相应的操作,或者如果需要,执行 中止命令 操作。

状态转换

  1. 完成命令处理:如果命令消息的处理完成,不论管理端点是否处于暂停状态,都会进入 传输(Transmit) 状态。
  2. 需要更多处理:如果命令处理需要更多时间,并且管理端点未被暂停,系统将发送 更多处理需要响应(More Processing Required Response),然后进入 传输(Transmit) 状态。
  3. 暂停状态:如果管理端点处于暂停状态,则不能发送更多处理需要响应消息。
  4. 中止操作:如果命令消息被 中止控制原语(Abort Control Primitive) 中止,命令插槽将返回到 空闲(Idle) 状态,除非命令无法被中止(参见第 4.2.1.3 节)。

特殊情况

  • 如果命令消息处理完成,但 更多处理需要响应 消息无法传输(例如因为管理端点的暂停标志被设置为 1),则 更多处理需要响应 消息会被丢弃。

Transmit(传输)状态

当命令消息处理完成后,传输(Transmit) 状态用于将 响应消息 发送回管理控制器。

状态转换

  1. 完成响应传输:如果命令消息的响应已经完全传输,命令插槽将返回到 空闲(Idle) 状态。
  2. 中止命令:如果 中止控制原语(Abort Control Primitive) 被接收到,命令插槽也会从 传输(Transmit) 状态转移到 空闲(Idle) 状态。
  3. 更多处理需要响应:如果 更多处理需要响应 消息已经传输,命令插槽将返回到 处理(Process) 状态。

控制原语(Control Primitives)

定义

控制原语(Control Primitives) 是从 管理控制器(Management Controller) 发送到 管理端点(Management Endpoint) 的请求消息,用于影响已发出的命令消息的服务状态或获取命令插槽和管理端点的状态。

  • 控制原语仅适用于 带外机制(out-of-band mechanism),并且在 带内隧道机制(in-band tunneling mechanism) 中被禁止使用。

控制原语的特点

  1. 目标为命令插槽:控制原语可以针对 命令插槽 发送,但与命令消息不同,控制原语可以在命令插槽处于任何命令服务状态时发送,并且会立即由管理端点处理。

  2. 处理方式

  3. 除非特别指定,控制原语不会改变命令插槽的服务状态。这意味着控制原语的作用是修改某些设置或触发操作,但不会直接干扰命令消息的处理流程。

控制原语的格式(Figure 36)

控制原语请求消息的格式如下:

+----------------------------+
| Byte 0 ~ Byte 3            | NVMe-MI Message Header (含 Status 等)
+----------------------------+
| Byte 4                     | Control Primitive Opcode (CPO)
+----------------------------+
| Byte 5 ~ Byte 7            | Control Primitive Specific Parameter (CPSP)
+----------------------------+
| Byte 8                     | Tag (TAG)
+----------------------------+

字段说明

字节 字段 说明
0-3 Message Integrity Check 完整性校验字段
4 Control Primitive Opcode (CPO) 控制原语操作码,指示要执行的控制操作
5-7 Control Primitive Specific Parameter (CPSP) 控制原语的特定参数,定义该操作需要的额外信息
8 Tag (TAG) 请求的标识符,用于标记该控制原语请求

控制原语的操作码(CPO)

  • 操作码(CPO) 定义了特定的控制操作。例如,它可以表示获取命令插槽状态、执行命令中止等操作。不同的操作码对应不同的管理操作。

🔍 总结

  1. 处理(Process)状态:在此状态下,命令消息被实际处理。处理过程包括验证命令消息并执行相应操作。如果需要更多时间处理,系统会转移到 传输(Transmit) 状态发送更多处理响应。
  2. 传输(Transmit)状态:命令消息的响应会在此状态下传输给管理控制器,完成后返回空闲状态。如果命令消息的处理需要更多时间,管理端点将在此状态下处理 更多处理需要响应
  3. 控制原语(Control Primitives):控制原语用于影响命令消息的服务状态,支持实时处理命令插槽状态,但不会改变命令插槽的当前状态。

如果你对 控制原语操作码(CPO) 的具体细节感兴趣,或需要进一步理解这些状态转换如何在实际系统中工作,请随时告诉我,我可以继续深入分析。