What offset range does LHU use?
Base load instructions use a sign-extended 12-bit byte offset, typically -2048 through 2047.
Load a 16-bit halfword from memory, zero-extend to 32 bits, and write to rd
LHU uses opcode 0000011 (0x03), funct3 101. The rs1 field selects the source register, the 12-bit immediate provides the second operand, and rd selects the destination.
LHU (I-type, opcode=0000011, funct3=101) loads a 16-bit halfword from memory at the effective address, zero-extends it to 32 bits, and writes to rd. Naturally aligned addresses are multiples of 2. Unlike LH (sign-extension), LHU uses zero-extension.
LHU reads a 16-bit halfword from the effective address formed by rs1 plus a signed 12-bit offset, then zero-extends the value into rd.
Understand this scenario with real code like «lhu x8, 2(x10) # x8 = zero_ext(mem[x10+2][15:0])».
Understand this scenario with real code like «lhu x8, 2(x10) # x8 = zero_ext(mem[x10+2][15:0])».
Base load instructions use a sign-extended 12-bit byte offset, typically -2048 through 2047.
LB/LH/LW sign-extend the loaded value to XLEN; LBU/LHU zero-extend. On RV64, use LWU when a 32-bit word should be zero-extended.