加载指令(7) lb、lbu、lh、lhu、lw、lwl、lwr
| op[31:26] | base[25:21] | rt[20:16] | offset[15:0] |
|---|
| 名称 | 指令用法 | 指令码[31:26] | rt[20:16] | offset[15:0] |
|---|---|---|---|---|
| LB | lb rt, offset(base) | 6’b 10_0000 | rt | offset |
| LBU | lbu rt, offset(base) | 6’b 10_0100 | rt | offset |
| LH | lh rt, offset(base) | 6’b 10_0001 | rt | offset |
| LHU | lhu rt, offset(base) | 6’b 10_0101 | rt | offset |
| LW | lw rt, offset(base) | 6’b 10_0011 | rt | offset |
| LWL | lwl rt, offset(base) | 6’b 10_0010 | rt | offset |
| LWR | lwr rt, offset(base) | 6’b 10_0110 | rt | offset |
加载地址计算方法:将16位的offset符号扩展至32位,在与地址为base的通用寄存器的值相加
加载地址 = signed_extended(offset) + GPR[base]
lb:字节加载指令。从内存中指定的加载地址处,读取一个字节,然后符号扩展至32位,保存到地址为rt的通用寄存器中;
lbu:无符号字节加载指令。从内存中指定的加载地址处,读取一个字节,然后无符号扩展至32位,保存到地址为rt的通用寄存器中;
lh:半字加载指令。从内存中指定的加载地址处,读取一个半字,然后符号扩展至32位,保存到地址为rt的通用寄存器中;该指令有地址对齐要求,要求加载地址的最低位为0;
lhu:无符号半字加载指令。从内存中指定的加载地址处,读取一个半字,然后无符号扩展至32位,保存到地址为rt的通用寄存器中;该指令有地址对齐要求,要求加载地址的最低位为0;
lw:字加载指令。从内存中指定的加载地址处,读取一个字,保存到地址为rt的通用寄存器中。该指令有地址对齐要求,要求加载地址的最低两位为00;
加载地址loadaddr的最低两位设为0后的值称为loadaddr_align
加载地址 loadaddr = signed_extended(offset) + GPR[base]
n = loadaddr[1:0]
loadaddr_align = loadaddr - n
lwl:非对齐加载指令,向左加载。从内存中指定的加载地址处,加载一个字的最高有效部分。从地址loadaddr_align处加载一个字,然后将这个字的最低4 - n个字节保存到地址为rt的通用寄存器的高位,并保持低位不变;
lwr:非对齐加载指令,向右加载。从内存中指定的加载地址处,加载一个字的最低有效部分。从地址loadaddr_align处加载一个字,然后将这个字的最高n + 1个字节保存到地址为rt的通用寄存器的低位,并保持高位不变;
存储指令(5) sb、sh、sw、swl、swr
| op[31:26] | base[25:21] | rt[20:16] | offset[15:0] |
|---|
| 名称 | 指令用法 | 指令码[31:26] | rt[20:16] | offset[15:0] |
|---|---|---|---|---|
| SB | sb rt, offset(base) | 6’b 10_1000 | rt | offset |
| SH | sh rt, offset(base) | 6’b 10_1001 | rt | offset |
| SW | sw rt, offset(base) | 6’b 10_1011 | rt | offset |
| SWL | swl rt, offset(base) | 6’b 10_1010 | rt | offset |
| SWR | swr rt, offset(base) | 6’b 10_1110 | rt | offset |
存储地址计算方法:将16位的offset符号扩展至32位,在与地址为base的通用寄存器的值相加
存储地址 = signed_extended(offset) + GPR[base]
sb:字节存储指令。将地址为rt的通用寄存器的最低字节存储到内存中的指定地址;
sh:半字存储指令。将地址为rt的通用寄存器的最低两个字节存储到内存中的指定地址。该指令有地址对齐要求,要求计算出来的存储地址的最低位为0;
sw:字存储指令。将地址为rt的通用寄存器的值存储到内存中的指定地址。该指令有地址对齐要求,要求计算出来的存储地址的最低两位为00;
存储地址storeaddr的最低两位设为0后的值称为storeaddr_align
存储地址storeaddr = signed_extended(offset) + GPR[base]
n = storeaddr[1:0]
storeaddr_align = storeaddr - n
swl:非对齐存储指令,向左存储。将地址为rt的通用寄存器的高位部分存储到内存中指定的地址处,存储地址的最低两位确定要存储rt通用寄存器的哪几个字节。将地址为rt通用寄存器的最高4 - n个字节存储到地址storeaddr处;
slr:非对齐存储指令,向右存储。将地址为rt的通用寄存器的低位部分存储到内存中指定的地址处,存储地址的最低两位确定要存储rt通用寄存器的哪几个字节。将地址为rt通用寄存器的最低n + 1个字节存储到地址storeaddr处;
ID译码走向

本文详细介绍了MIPS架构中的加载与存储指令,包括字节、半字和字的加载与存储指令及其非对齐版本。每条指令均附有使用格式、操作码及功能说明,有助于理解数据如何在内存与寄存器间传输。
4429

被折叠的 条评论
为什么被折叠?



