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