首页/指令库/VSM4K-VI
VSM4K.VI

RISC-V VSM4K.VI 指令详解

指令手册I-type

向量 SM4 轮密钥扩展,uimm 选择 key-schedule 轮;作为不可掩码的 element-group 密码指令执行。

指令语法

vsm4k.vi vd, vs2, uimm
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数所在的寄存器。
立即数 imm:12 位有符号立即数,符号扩展后与 rs1 进行运算。
Zvksed向量密码SM4

指令行为说明

VSM4K.VI 是向量 SM4 轮密钥扩展,uimm 选择 key-schedule 轮 指令。SM4 指令使用 SEW=32、EGW=128、EGS=4。

快速理解与检索要点

VSM4K.VI 是 SM4 向量密码指令,按 element group 执行,不能逐元素独立套用普通整数公式。

SM4 使用 128 位 element group;.vs 形式从 vs2 取一个标量 element group。
官方语法没有 vm,不能添加 v0.t 掩码。

常见使用场景

加密与密码

结合 «vsm4k.vi vd, vs2, uimm» 等实际代码理解该场景。

向量化加速

结合 «vsm4k.vi vd, vs2, uimm» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

无 vm 操作数;该 element-group crypto 指令不可掩码执行。
SEW 必须为 32,vl/vstart 必须是 EGS=4 的整数倍。
注意 vd 的输入/输出角色和官方规定的寄存器组重叠限制。

常见问题

VSM4K.VI 是否逐元素可掩码?

不是。它是 element-group 密码指令,官方语法无 vm。

VSM4K.VI 的 vtype 关键限制是什么?

SEW 必须为 32,且 LMUL*VLEN 要能覆盖 128 位 element group。