Home/Instructions/Load Word
LW

RISC-V LW Instruction Details

Instruction ManualI-type

Load a 32-bit word from memory into rd

Instruction Syntax

lw rd, offset(rs1)
Operand Breakdown
Destination rd: general-purpose register receiving the result.
Source rs1: register holding the first operand.
Immediate imm: 12-bit signed value, sign-extended before operation with rs1.
RV32IMemory Load

Instruction Encoding

31..20
imm[11:0]
19..15
rs1
14..12
funct3
11..7
rd
6..0
opcode

LW uses opcode 0000011 (0x03), funct3 010. The rs1 field selects the source register, the 12-bit immediate provides the second operand, and rd selects the destination.

Format: I-type
opcode: 0000011 (0x03)
funct3: 010 (0x2)

Instruction Behavior

LW (I-type, opcode=0000011, funct3=010) loads a 32-bit word from memory at the effective address (rs1 + sign-extended 12-bit offset), sign-extends it to XLEN, and writes it to rd. Naturally aligned word addresses are multiples of 4. When rd=x0, exceptions and side effects still occur even though value is discarded. This is the primary load instruction in RV32I.

Quick Understanding & Search Notes

LW reads a 32-bit word from the effective address formed by rs1 plus a signed 12-bit offset, then sign-extends the value to XLEN and writes rd.

All base loads form an effective byte address as rs1 plus a sign-extended 12-bit offset.
Naturally aligned accesses should not raise address-misaligned exceptions; misaligned behavior depends on the execution environment interface.

Official Spec Notes

These notes are checked against the RISC-V Unprivileged ISA manual and summarize operation semantics, immediate ranges, and edge behavior.

Common Usage Scenarios

Data Loading

Understand this scenario with real code like «lw x5, 0(x10) # x5 = mem[x10+0][31:0]».

Register Operations

Understand this scenario with real code like «lw x5, 0(x10) # x5 = mem[x10+0][31:0]».

Pre-Use Checklist

Syntax Check
  • Confirm the current instruction format is I-type.
  • Confirm the operand order matches the example.
Semantic Check
  • Ensure the destination register usage is compatible with the calling convention.
  • Confirm this is not the lower-level form of a pseudo-instruction expansion.

Pitfalls / Common Confusions

Natural alignment requires address multiple of 4
rd=x0 discards load value but still causes memory side effects

FAQ

What offset range does LW use?

Base load instructions use a sign-extended 12-bit byte offset, typically -2048 through 2047.

What is the difference between signed and unsigned loads?

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.