LHU 的地址偏移范围是多少?
基础加载指令使用符号扩展的 12 位偏移,通常可表示 -2048 到 2047 字节。
从内存加载16位半字,零扩展至32位后写入rd
LHU 使用 opcode 0000011(0x03)、funct3 101。rs1 字段选择源寄存器,12 位立即数提供第二操作数,rd 选择目标寄存器。
LHU指令采用I型格式(opcode=0000011, funct3=101)。从有效地址(rs1+12位偏移)读取16位半字值,经零扩展为32位后写入rd。自然对齐的半字地址为2的倍数。与LH的区别在于LH进行有符号扩展而LHU进行零扩展。
LHU 从 rs1 加 12 位有符号偏移形成的有效地址读取16 位半字,然后零扩展写入 rd。
结合 «lhu x8, 2(x10) # x8 = zero_ext(mem[x10+2][15:0])» 等实际代码理解该场景。
结合 «lhu x8, 2(x10) # x8 = zero_ext(mem[x10+2][15:0])» 等实际代码理解该场景。
基础加载指令使用符号扩展的 12 位偏移,通常可表示 -2048 到 2047 字节。
LB/LH/LW 会把加载值符号扩展到 XLEN;LBU/LHU 会零扩展。RV64 中需要零扩展 32 位字时使用 LWU。