算术溢出行为
整数加法结果只保留低 XLEN 位;算术溢出不会触发异常。需要检测溢出时,应由软件用额外比较或分支序列完成。
RISC-V Unprivileged ISA, RV32I integer computational instructions将rs1与12位有符号立即数相加,结果写入rd
ADDI 使用 opcode 0010011(0x13)、funct3 000。rs1 字段选择源寄存器,12 位立即数提供第二操作数,rd 选择目标寄存器。
ADDI指令采用I型格式(opcode=0010011, funct3=000)。将rs1寄存器的值与12位有符号立即数相加(算术溢出被忽略,仅保留低XLEN位),结果写入rd。当rd=x0,rs1=x0,imm=0时即为NOP指令(编码为ADDI x0,x0,0)。当ADDI rd,x0,imm时等价于向rd加载一个小立即数(伪指令LI)。当ADDI rd,rs1,0时等价于寄存器搬移(伪指令MV)。
ADDI 把符号扩展后的 12 位立即数加到 rs1 并写入 rd。它是小常量、栈指针调整、地址偏移和寄存器搬移伪指令的常见底层形式。
以下要点按 RISC-V Unprivileged ISA 手册核准,用于补充操作语义、立即数范围和边界行为。
整数加法结果只保留低 XLEN 位;算术溢出不会触发异常。需要检测溢出时,应由软件用额外比较或分支序列完成。
RISC-V Unprivileged ISA, RV32I integer computational instructionsADDI 将符号扩展后的 12 位立即数加到 rs1。可编码范围是 -2048 到 2047;更大的常量通常由 LUI/AUIPC 与 ADDI 或 li 伪指令组合生成。
RISC-V Unprivileged ISA, RV32I integer computational instructions结合 «addi x5, x6, 100 # x5 = x6 + 100» 等实际代码理解该场景。
结合 «addi x5, x6, 100 # x5 = x6 + 100» 等实际代码理解该场景。
结合 «addi x5, x6, 100 # x5 = x6 + 100» 等实际代码理解该场景。
结合 «addi x5, x6, 100 # x5 = x6 + 100» 等实际代码理解该场景。
ADDI 使用符号扩展的 12 位立即数,通常可直接表示 -2048 到 2047。更大的常量需要 LUI/AUIPC 与 ADDI 等序列。
基础整数指令集中没有单独的 SUBI。减去小常量通常写成 ADDI 并使用负立即数。