RORIW

RISC-V RORIW 指令详解

指令手册I-type

字循环右移立即数(RV64)

指令语法

roriw rd, rs1, shamt
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数所在的寄存器。
立即数 imm:12 位有符号立即数,符号扩展后与 rs1 进行运算。
BZbb位操作

指令行为说明

将rs1低32位循环右移shamt位(0-31),结果符号扩展到XLEN。RV64。属于Zbb和Zbkb。注意shamt[5]=1编码保留。

快速理解与检索要点

RORIW 是 B/Zbb 指令,低 32 位循环右移并符号扩展。页面内容按官方 B 扩展语义校对,重点区分 XLEN、W 后缀、.uw 后缀和按位/循环操作的边界。

W 后缀形式只操作 rs1 的低 32 位,移位量使用 5 位。
32 位结果按 bit 31 符号扩展到 XLEN,不能当作普通 64 位循环移位。

常见使用场景

加密与安全

结合 «roriw x10, x11, 8 ; x10 = sign_ext(rotr(x11[31:0], 8))» 等实际代码理解该场景。

常量与立即数

结合 «roriw x10, x11, 8 ; x10 = sign_ext(rotr(x11[31:0], 8))» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

仅适用于RV64
对低32位操作
W 后缀指令只产生 32 位结果,并把 bit[31] 符号扩展到 XLEN;不要把它当作普通 64 位运算。
它们只存在于 RV64/RV128 相关环境,RV32 中没有这些 W 形式。

常见问题

RORIW 会访问内存吗?

不会。它只读写整数寄存器;任何内存访问都必须由单独的 load/store 指令完成。

RORIW 的结果宽度是什么?

除 W 后缀先形成 32 位结果再符号扩展、.uw 先提取 32 位无符号操作数外,结果按 XLEN 写入 rd。