What offset range does LB use?
Base load instructions use a sign-extended 12-bit byte offset, typically -2048 through 2047.
Load a byte from memory, sign-extend to 32 bits, and write to rd
LB uses opcode 0000011 (0x03), funct3 000. The rs1 field selects the source register, the 12-bit immediate provides the second operand, and rd selects the destination.
LB (I-type, opcode=0000011, funct3=000) loads an 8-bit byte from memory at the effective address (rs1 + sign-extended 12-bit offset), sign-extends it to 32 bits, and writes to rd. Misaligned access behavior depends on the EEI.
LB reads a 8-bit byte from the effective address formed by rs1 plus a signed 12-bit offset, then sign-extends the value into rd.
Understand this scenario with real code like «lb x5, 0(x10) # x5 = sign_ext(mem[x10+0][7:0])».
Understand this scenario with real code like «lb x5, 0(x10) # x5 = sign_ext(mem[x10+0][7:0])».
Understand this scenario with real code like «lb x5, 0(x10) # x5 = sign_ext(mem[x10+0][7: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.