SUB

RISC-V SUB 指令详解

指令手册R-type

从rs1减去rs2,结果写入rd

指令语法

sub rd, rs1, rs2
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
RV32I算术运算

指令编码

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

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

格式: R-type
opcode: 0110011 (0x33)
funct3: 000 (0x0)
funct7: 0100000 (0x20)

指令行为说明

SUB指令采用R型格式。将rs1值减去rs2值(溢出忽略),结果写入rd。funct7=0100000, funct3=000。funct7的bit30=1使SUB与ADD共享相同的funct3(000)和opcode(0110011),仅在funct7区分。无直接SUBI指令,需通过ADDI配合负数立即数实现。

快速理解与检索要点

SUB 从 rs1 中减去 rs2 并写入 rd。它是寄存器减法;基础整数 ISA 没有立即数减法,减小常量通常用 ADDI 负立即数。

SUB 与 ADD 共享 opcode/funct3,通过 funct7=0100000 区分。
整数减法溢出同样不会产生异常。

常见使用场景

地址与指针

结合 «sub x5, x6, x7 # x5 = x6 - x7» 等实际代码理解该场景。

寄存器操作

结合 «sub x5, x6, x7 # x5 = x6 - x7» 等实际代码理解该场景。

特定用途

结合 «sub x5, x6, x7 # x5 = x6 - x7» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

溢出被静默忽略
与 ADD 的唯一区别在 funct7 字段(ADD:0000000, SUB:0100000),确保编码正确
无立即数减法,需用 ADDI 配合负数立即数实现

常见问题

SUB 和 ADD 的编码差异是什么?

二者 opcode 和 funct3 相同,SUB 使用 funct7=0100000,而 ADD 使用 funct7=0000000。

如何做立即数减法?

使用 ADDI 并写负立即数,例如减 8 可写为 addi rd, rs1, -8。