PC 相对分支范围
条件分支使用 B-type 立即数,表示 2 字节对齐的有符号 PC-relative 偏移,目标范围约为当前 PC 的正负 4 KiB。
RISC-V Unprivileged ISA, RV32I control transfer instructions若rs1无符号比较小于rs2,则分支跳转
BLTU 使用 opcode 1100011(0x63)、funct3 110。rs1 和 rs2 保存比较操作数,13 位立即数编码分支偏移(±4 KiB)。
BLTU指令采用B型格式(opcode=1100011, funct3=110)。将rs1和rs2作为无符号整数比较,若rs1<rs2则产生分支跳转(范围±4KiB)。特别的技巧:有符号数组边界检查可使用一条BLTU指令完成,因为任何负索引(以无符号解释为极大值)都会大于任何非负边界值。BGTU可通过交换操作数实现。
BLTU 是条件分支指令:当 rs1 与 rs2 的比较结果满足“无符号小于”时,PC 跳到当前指令 PC 加 B-type 偏移;条件不成立时顺序执行。
以下要点按 RISC-V Unprivileged ISA 手册核准,用于补充操作语义、立即数范围和边界行为。
条件分支使用 B-type 立即数,表示 2 字节对齐的有符号 PC-relative 偏移,目标范围约为当前 PC 的正负 4 KiB。
RISC-V Unprivileged ISA, RV32I control transfer instructions条件分支只根据比较结果改变 PC,不会写入 rd,也不会保存返回地址。函数调用和返回应使用 JAL/JALR 相关形式。
RISC-V Unprivileged ISA, RV32I control transfer instructions结合 «bltu x9, x10, error # if x9 < x10 (unsigned), branch to error» 等实际代码理解该场景。
结合 «bltu x9, x10, error # if x9 < x10 (unsigned), branch to error» 等实际代码理解该场景。
条件分支使用 B-type 立即数,目标范围约为当前 PC 的正负 4 KiB。
BLT/BGE 按有符号整数比较;BLTU/BGEU 按无符号整数比较。BEQ/BNE 只判断位模式是否相等,不区分符号。