SUB 和 ADD 的编码差异是什么?
二者 opcode 和 funct3 相同,SUB 使用 funct7=0100000,而 ADD 使用 funct7=0000000。
从rs1减去rs2,结果写入rd
SUB 使用 opcode 0110011(0x33)、funct3 000、funct7 0100000。rs1 和 rs2 字段选择两个源寄存器,rd 字段选择目标寄存器。
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 x5, x6, x7 # x5 = x6 - x7» 等实际代码理解该场景。
结合 «sub x5, x6, x7 # x5 = x6 - x7» 等实际代码理解该场景。
结合 «sub x5, x6, x7 # x5 = x6 - x7» 等实际代码理解该场景。
二者 opcode 和 funct3 相同,SUB 使用 funct7=0100000,而 ADD 使用 funct7=0000000。
使用 ADDI 并写负立即数,例如减 8 可写为 addi rd, rs1, -8。