SH 会写整个寄存器吗?
SH 只写 rs2 的低 16 位半字,不是总是写完整 XLEN 宽寄存器。
SH 使用 opcode 0100011(0x23)、funct3 001。rs1 保存基地址,rs2 保存存储数据,12 位立即数(拆分在 imm[11:5] 和 imm[4:0])提供偏移量。
SH指令采用S型格式(opcode=0100011, funct3=001)。有效地址由rs1与12位有符号偏移相加得到,将rs2寄存器的低16位写入该地址。自然对齐的半字地址应为2的倍数。
SH 使用 rs1 加 12 位有符号偏移形成有效地址,并把 rs2 的低 16 位半字写入内存。
结合 «sh x6, 2(x10) # mem[x10+2][15:0] = x6[15:0]» 等实际代码理解该场景。
结合 «sh x6, 2(x10) # mem[x10+2][15:0] = x6[15:0]» 等实际代码理解该场景。
SH 只写 rs2 的低 16 位半字,不是总是写完整 XLEN 宽寄存器。
有效地址由基址寄存器 rs1 加符号扩展的 12 位字节偏移得到。