LoongArch 指令集学习

1 SoC_Lite片上系统结构

在这里插入图片描述
mycpu和dram、confreg之间有一个“一分二”部件。这是因为在LoongArch指令系统架构下,所有I/O设备的寄存器都是采用memory mapped方式访问的。我们这里实现的confreg也不例外。Memory mapped的访问方式意味I/O设备中的寄存器各自都有一个唯一内存编址,所以CPU可以通过load、store指令对其进行访问。不过dram作为内存也是通过load、store指令进行访问的。那么对于一条load或store指令来说,如何知晓它访问的是confreg还是dram?我们在设计SoC的时候用地址对其进行区分。因此在设计SoC的数据通路时就需要在这里引入一个“一分二”部件,它的选择控制信号生成是通过对访存的地址范围进行判断而得到的。

龙芯架构32位精简版典型指令编码格式

在这里插入图片描述

实验6-exp6共有20条指令
wire        inst_add_w;
wire        inst_sub_w;
wire        inst_slt;
wire        inst_sltu;
wire        inst_nor;
wire        inst_and;
wire        inst_or;
wire        inst_xor;
wire        inst_slli_w;
wire        inst_srli_w;
wire        inst_srai_w;
wire        inst_addi_w;
wire        inst_ld_w;
wire        inst_st_w;
wire        inst_jirl;
wire        inst_b;
wire        inst_bl;
wire        inst_beq;
wire        inst_bne;
wire        inst_lu12i_w;
1. add.w
  • 指令格式
    在这里插入图片描述

  • 与 mips 对比

  • 指令码
    在这里插入图片描述

  • mips 对比
    在这里插入图片描述

2. sub.w
  • 指令格式
    在这里插入图片描述

  • 指令码
    在这里插入图片描述

  • mips 对比
    在这里插入图片描述

3. slt、sltu
  • 指令格式
    在这里插入图片描述

  • 指令码
    在这里插入图片描述

  • mips 对比
    在这里插入图片描述

4. inst_nor, inst_and, inst_or,inst_xor
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述

在这里插入图片描述

  • 指令码
    在这里插入图片描述
  • mips 指令对比

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5. inst_slli_w ,inst_srli_w,inst_srai_w
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述
    上述移位指令的移位量均是指令码中 5 比特无符号立即数 ui5
  • 指令码
    在这里插入图片描述
  • mips 指令对比
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/8cb2d5415d354ad493fe5d53c1b21830.pn
    在这里插入图片描述

在这里插入图片描述

6.inst_addi_w
  • 指令格式
    在这里插入图片描述

该指令执行时不对溢出情况做任何特殊处理

  • 指令码
    在这里插入图片描述
  • mips 指令对比
    在这里插入图片描述
7.inst_ld_w,inst_st_w;
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
上述指令的访存地址计算方式是将通用寄存器 rj 中的值与符号扩展后的 12 比特立即数 si12 相加求和。
对于 LD.{H[U]/W}和 ST.{B/H/W}指令,只要其访存地址是自然对齐的,都不会触发非对齐例外;否则
的话将触发非对齐例外。

  • 指令码
    在这里插入图片描述
    在这里插入图片描述

  • mips 指令对比
    在这里插入图片描述

在这里插入图片描述

8. inst_jirl
  • 指令格式
    在这里插入图片描述
    需要注意的是,该指令如果在写汇编时采用直接填入偏移值的方式,则汇编表示中的立即数应填入以
    字节为单位的偏移值,即指令码中 offs16<<2。
  • 指令码
    在这里插入图片描述
    在这里插入图片描述
9. inst_b,inst_bl
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述

  • 指令码
    在这里插入图片描述

  • mips指令格式
    在这里插入图片描述
    在这里插入图片描述

10. inst_beq, inst_bne
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述

  • 指令码
    在这里插入图片描述

  • mips 指令对比
    在这里插入图片描述
    在这里插入图片描述

11. inst_lu12i_w
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述

  • 指令码
    在这里插入图片描述

12. pcaddu12i
  • 指令格式
    在这里插入图片描述
  • 指令码
    在这里插入图片描述
13. slti sltui
  • 指令格式
    在这里插入图片描述
  • 指令码
    在这里插入图片描述
14. andi ori xori
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述

  • 指令码
    在这里插入图片描述

15. sll.w srl.w sra.w

在这里插入图片描述
在这里插入图片描述

  • 指令码
    加粗样式
16. mul.w、mulh.w、mulh.wu
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述

  • 指令码
    在这里插入图片描述

17.div.w、mod.w、div.wu、mod.wu
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 指令码
    在这里插入图片描述

18. blt、bge、bltu、bgeu
  • 编码格式
    在这里插入图片描述
    在这里插入图片描述
  • 指令码
    在这里插入图片描述
19. ld.b、ld.h、ld.bu、ld.hu、st.b、st.h
  • 指令格式
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  • 指令码
    在这里插入图片描述
    在这里插入图片描述
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

疯狂的码泰君

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值