首页/指令库/VSHA2MS-VV
VSHA2MS.VV

RISC-V VSHA2MS.VV 指令详解

指令手册R-type

向量 SHA-2 消息调度扩展,产生后续 4 个消息字;Zvknha 仅 SEW=32,Zvknhb 支持 SEW=32/64。

指令语法

vsha2ms.vv vd, vs2, vs1
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
ZvknhaZvknhb向量密码SHA-256

指令行为说明

VSHA2MS.VV 是向量 SHA-2 element-group 指令。它从 vd、vs2、vs1 中的最近消息调度字计算下一组消息字。Zvknha 下 SEW 必须为 32;Zvknhb 下 SEW 可为 32 或 64。

快速理解与检索要点

VSHA2MS.VV 属于向量 SHA-2 element-group 指令,不能按普通逐元素算术或带 v0.t 掩码的指令理解。

SEW=32 对应 SHA-256;SEW=64 对应 SHA-512 且需要 Zvknhb。
寄存器组重叠限制是编码合法性的一部分。

常见使用场景

加密与密码

结合 «vsha2ms.vv vd, vs2, vs1» 等实际代码理解该场景。

向量化加速

结合 «vsha2ms.vv vd, vs2, vs1» 等实际代码理解该场景。

使用前检查清单

语法检查
  • 确认当前指令格式为 R-type。
  • 确认操作数排列顺序与示例一致。
语义检查
  • 确认目标寄存器用途和调用约定兼容。
  • 确认该指令不是伪指令展开后的底层形式。

容易混淆 / 常见误区

无 vm 操作数;该 element-group crypto 指令不可掩码执行。
vd 寄存器组不得与 vs1 或 vs2 重叠。
SHA-2 element group 使用 EGS=4;vl 与 vstart 必须按 element group 对齐。
软件需要按 SHA-2 标准处理消息/最终哈希的大端字节序要求。

常见问题

VSHA2MS.VV 是否支持 vm 掩码?

不支持。官方语法没有 vm 操作数。

VSHA2MS.VV 的 SEW 怎么选?

由当前 vtype 决定,但必须满足 Zvknha/Zvknhb 对 SEW=32 或 64 的限制。