自己动手写CPU(11)——加载存储指令说明

加载指令(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]
LBlb rt, offset(base)6’b 10_0000rtoffset
LBUlbu rt, offset(base)6’b 10_0100rtoffset
LHlh rt, offset(base)6’b 10_0001rtoffset
LHUlhu rt, offset(base)6’b 10_0101rtoffset
LWlw rt, offset(base)6’b 10_0011rtoffset
LWLlwl rt, offset(base)6’b 10_0010rtoffset
LWRlwr rt, offset(base)6’b 10_0110rtoffset

加载地址计算方法:将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]
SBsb rt, offset(base)6’b 10_1000rtoffset
SHsh rt, offset(base)6’b 10_1001rtoffset
SWsw rt, offset(base)6’b 10_1011rtoffset
SWLswl rt, offset(base)6’b 10_1010rtoffset
SWRswr rt, offset(base)6’b 10_1110rtoffset

存储地址计算方法:将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译码走向
在这里插入图片描述

补充

  • 2
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值