首页/指令库/无符号立即数小于置位
SLTIU

RISC-V SLTIU 指令详解

指令手册I-type

若rs1无符号比较小于立即数,则置rd为1,否则置0

指令语法

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

指令编码

31..20
imm[11:0]
19..15
rs1
14..12
funct3
11..7
rd
6..0
opcode

SLTIU 使用 opcode 0010011(0x13)、funct3 011。rs1 字段选择源寄存器,12 位立即数提供第二操作数,rd 选择目标寄存器。

格式: I-type
opcode: 0010011 (0x13)
funct3: 011 (0x3)

指令行为说明

SLTIU指令采用I型格式。将rs1作为无符号整数与12位立即数(先做有符号扩展,再解释为无符号数)比较,若rs1<立即数则在rd中写入1,否则写入0。SLTIU rd,rs1,1即检测rs1是否为零,若为零则rd=1(伪指令SEQZ)。

快速理解与检索要点

SLTIU 执行无符号比较 rs1 < sign-extended imm;条件为真时 rd=1,否则 rd=0。它适合把比较结果转成可继续参与运算或分支的整数值。

立即数版本使用符号扩展的 12 位立即数。
有符号和无符号比较只改变解释位模式的方式,不改变寄存器宽度。

常见使用场景

比较与判断

结合 «sltiu x5, x6, 10 # x5 = (x6 < 10) ? 1 : 0 (unsigned)» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

立即数先做有符号扩展再解释为无符号(对正值无影响,负值变为极大无符号数)
注意与SLTI的区别

常见问题

SLTIU 写入什么结果?

比较成立时写入 1,否则写入 0。

SLT 和 SLTU 有什么区别?

SLT/SLTI 按有符号整数比较;SLTU/SLTIU 按无符号整数比较。