首页/指令库/加载高位立即数
LUI

RISC-V LUI 指令详解

指令手册U-type

将20位立即数装入目标寄存器的高20位,低12位用零填充

指令语法

lui rd, imm
操作数说明
目标寄存器 rd:存放结果的通用寄存器。
高位立即数:20 位立即数,加载到 rd 的高 20 位,低 12 位填充 0。
RV32I常量与立即数地址计算

指令编码

31..12
imm[31:12]
11..7
rd
6..0
opcode

LUI 使用 opcode 0110111(0x37)。20 位立即数加载到 rd 的高 20 位,低 12 位填零。

格式: U-type
opcode: 0110111 (0x37)

指令行为说明

LUI指令采用U型格式(opcode=0110111)。将20位U型立即数放入目标寄存器rd的高20位,低12位自动填充为零。该指令用于构造32位常数,通常与ADDI配合实现完整的32位立即数加载。rd为x0时用作HINT编码预留空间。

快速理解与检索要点

LUI 把 U-immediate 放入 rd 的高位位置并把低 12 位清零,常作为构造较大常量的第一步。

U-type 立即数字段对应结果的高 20 位,低 12 位为 0。
在 RV64I 中,LUI 产生的 32 位结果会符号扩展到 64 位。

官方规范要点

以下要点按 RISC-V Unprivileged ISA 手册核准,用于补充操作语义、立即数范围和边界行为。

常见使用场景

常量与立即数

结合 «lui x5, 0x12345 # x5 = 0x12345 << 12 = 0x12345000» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

LUI 的低 12 位总是零,如需非零低 12 位需配合 ADDI
在 RV64I 中,32 位结果会符号扩展到 64 位

常见问题

LUI 能一次加载完整 32 位常量吗?

不能。LUI 只设置高 20 位,低 12 位为 0;完整常量通常还需要 ADDI 等后续指令。

LUI 和 AUIPC 的核心区别是什么?

LUI 只基于立即数形成值;AUIPC 会把高位立即数形成的偏移加到当前 PC。