首页/指令库/无符号大于等于时分支
BGEU

RISC-V BGEU 指令详解

指令手册B-type

若rs1无符号比较大于等于rs2,则分支跳转

指令语法

bgeu rs1, rs2, offset
操作数说明
源寄存器 rs1:第一个比较操作数。
源寄存器 rs2:第二个比较操作数。
立即数偏移:13 位有符号分支偏移(bit 0 隐含为 0,范围 ±4 KiB)。
RV32I控制转移分支

指令编码

31..25
imm[12|10:5]
24..20
rs2
19..15
rs1
14..12
funct3
11..7
imm[4:1|11]
6..0
opcode

BGEU 使用 opcode 1100011(0x63)、funct3 111。rs1 和 rs2 保存比较操作数,13 位立即数编码分支偏移(±4 KiB)。

格式: B-type
opcode: 1100011 (0x63)
funct3: 111 (0x7)

指令行为说明

BGEU指令采用B型格式(opcode=1100011, funct3=111)。将rs1和rs2作为无符号整数比较,若rs1>=rs2则产生分支跳转(范围±4KiB)。BLEU可通过交换BGEU的操作数来实现。BLTU是BGEU的逻辑反。常用于地址比较和内存范围检查。

快速理解与检索要点

BGEU 是条件分支指令:当 rs1 与 rs2 的比较结果满足“无符号大于等于”时,PC 跳到当前指令 PC 加 B-type 偏移;条件不成立时顺序执行。

B-type 分支偏移以 2 字节为单位编码,范围约为当前 PC 的 +/-4 KiB。
RISC-V 条件分支不会写 rd,也不会保存返回地址。

官方规范要点

以下要点按 RISC-V Unprivileged ISA 手册核准,用于补充操作语义、立即数范围和边界行为。

常见使用场景

比较与判断

结合 «bgeu x11, x12, valid # if x11 >= x12 (unsigned), go to valid» 等实际代码理解该场景。

类型转换

结合 «bgeu x11, x12, valid # if x11 >= x12 (unsigned), go to valid» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

有符号数比较请使用BGE
BLEU可由BGEU交换操作数实现

常见问题

BGEU 的跳转范围是多少?

条件分支使用 B-type 立即数,目标范围约为当前 PC 的正负 4 KiB。

有符号和无符号分支有什么区别?

BLT/BGE 按有符号整数比较;BLTU/BGEU 按无符号整数比较。BEQ/BNE 只判断位模式是否相等,不区分符号。