首页/指令库/SHA512低位Sigma低32位
SHA512SIG0L

RISC-V SHA512SIG0L 指令详解

指令手册R-type

SHA-512 σ0 结果的低32位(RV32):从rs1和rs2的64位输入计算σ0并返回bits[31:0]

指令语法

sha512sig0l rd, rs1, rs2
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
Zknh加密与密码

指令编码

31..25
funct7
24..20
rs2
19..15
rs1
14..12
funct3
11..7
rd
6..0
opcode

SHA512SIG0L 使用 opcode 0110011(0x33)、funct3 110、funct7 0101010。rs1 和 rs2 字段选择两个源寄存器,rd 字段选择目标寄存器。

格式: R-type
opcode: 0110011 (0x33)
funct3: 110 (0x6)
funct7: 0101010 (0x2a)

指令行为说明

sha512sig0l 是 Zknh 扩展的 SHA-512 σ0 函数的低位指令(仅 RV32)。将 rs1(高 32 位)和 rs2(低 32 位)拼接为 64 位输入,计算 σ0(x) = ROTR(x, 1) ⊕ ROTR(x, 8) ⊕ SHR(x, 7),返回结果的 bits[31:0](低 32 位)写入 rd。与 sha512sig0h 配对实现 RV32 上的完整 SHA-512 σ0。

快速理解与检索要点

SHA512SIG0L 是 Zknh 标量密码指令,SHA-512 RV32 拆分变换。页面内容按官方标量密码扩展校对,避免把算法轮函数、密钥调度和寄存器来源混淆。

sha512sig0l 是 RV32 上计算 SHA-512 64 位 sigma 结果的一半,需要与对应 h/l 指令配对使用。
标量密码指令使用整数 X 寄存器,官方要求相关密码指令以数据无关执行延迟实现。
RV32 SHA-512 拆分形式需要按官方 h/l 或反向源寄存器序列组合出完整 64 位结果。

常见使用场景

加密与密码

结合 «sha512sig0l a0, a1, a2» 等实际代码理解该场景。

哈希算法

结合 «sha512sig0l a0, a1, a2» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

仅适用于 RV32。rs1=高32位,rs2=低32位。
必须与 sha512sig0h 配对使用。

常见问题

SHA512SIG0L 使用浮点或向量寄存器吗?

不使用。标量密码扩展的这些指令使用整数 X 寄存器。

SHA512SIG0L 是完整算法实现吗?

不是。它是 AES、SHA、SM3 或 SM4 中的一个低级步骤,软件仍需按算法顺序组合多条指令和轮常数/轮密钥。