U-type 高位加载
LUI 把 20 位 U-immediate 放入目标寄存器的高位位置,并将低 12 位清零;在 RV64 上,结果按 32 位值符号扩展到 XLEN。
RISC-V Unprivileged ISA, RV32I integer computational instructions将20位立即数装入目标寄存器的高20位,低12位用零填充
LUI 使用 opcode 0110111(0x37)。20 位立即数加载到 rd 的高 20 位,低 12 位填零。
LUI指令采用U型格式(opcode=0110111)。将20位U型立即数放入目标寄存器rd的高20位,低12位自动填充为零。该指令用于构造32位常数,通常与ADDI配合实现完整的32位立即数加载。rd为x0时用作HINT编码预留空间。
LUI 把 U-immediate 放入 rd 的高位位置并把低 12 位清零,常作为构造较大常量的第一步。
以下要点按 RISC-V Unprivileged ISA 手册核准,用于补充操作语义、立即数范围和边界行为。
LUI 把 20 位 U-immediate 放入目标寄存器的高位位置,并将低 12 位清零;在 RV64 上,结果按 32 位值符号扩展到 XLEN。
RISC-V Unprivileged ISA, RV32I integer computational instructions结合 «lui x5, 0x12345 # x5 = 0x12345 << 12 = 0x12345000» 等实际代码理解该场景。
不能。LUI 只设置高 20 位,低 12 位为 0;完整常量通常还需要 ADDI 等后续指令。
LUI 只基于立即数形成值;AUIPC 会把高位立即数形成的偏移加到当前 PC。