一、概述

我们知道,计算机指令是指挥机器工作的指示和命令,程序就是一系列指令按照顺序排列的集合,执行程序的过程就是计算机的工作过程

从微观上看,我们输入指令的时候,计算机会将指令转换成二进制码存储在存储单元里面,然后在即将执行的时候拿出来

那么计算机是怎么知道我们输入的是什么指令,指令要怎么执行呢?

这就要提到ISA也就是指令集, 指令集就是CPU用来计算和控制计算机系统的一套指令的集合,而每种新型的CPU在设计的时候就规定了一系列和其他硬件电路配合的指令系统

计算机就可以通过指令集,判断这一段二进制码是什么意思,然后通过CPU转换成控制硬件执行的信号,从而完成整个操作,这样一来,指令集其实就是硬件和软件之间的接口(interface),我们不再需要直接和硬件进行交互,而是和具有更高的抽象程度的ISA进行交互,集中注意在指令的编写逻辑,提高工作效率

指令集不仅仅是指令的集合,还包括全部指令的指令格式、寻址方式和数据形式

二、 操作数个数

ISA设计中的一个重要的设计因素就是一条指令中可以使用的操作数的个数,它会影响到字的长度(word size)和CPU的复杂程度

以ADD为例,两个数相加需要两个操作数,结果需要一个操作数,可能还因为指令跳转需要第四个操作数,如果每条指令都要这么多操作数,那么这个指令就会变得很长很长

但是在现实生活中,我们很少用到上面说的这种存有四个操作数地址的指令结构,最常见的是1、2和3个地址,原因有:

  • CPU复杂度太高
  • word的长度太长
  • 所有的操作数都不会得到充分的使用

ISA分类

按照使用的地址的个数,我们可以将ISA分成几类:

  1. 累加器(Accumulator):只使用一个地址,例:acc  ⬅️  acc + Mem[A](add A)
  2. 堆(stack):不需要地址,因为stack先进先出, 例:tos  ⬅️ tos + next(add)
  3. 存储器-存储器型(Memory-Memory): 两个或者三个地址, mem[A] ⬅️  mem[A] + mem[B](add A, B)/ mem[A] ⬅️  mem[B] + mem[C](add A, B, C)
  4. 寄存器-存储器型(Register-Memory): 两个地址, R1 ⬅️ R1 + mem[A](add R1, A)
  5. 寄存器-寄存器型(Register-Register): 三个地址,R1 ⬅️ R2 + R3 (add R1, R2, R3)

TIPS:寄存器

寄存器是计算机存储结构中最靠近CPU的存储器,它比cache和主存储器更快,但是相应的,寄存器的容量很小,而且寄存器的数量是有限的

寄存器中存储的是指令和数据

简单介绍一下这几种就是:

Stack:我们需要在计算之前要先把第一个操作数 A给PUSH进去,然后直接在下一条指令里面用到第二个操作数(ADD B) ,这个时候Stack的顶端就是A+B,最后我们把它POP出来聚能得到结果

Accumulator:假设我们要计算(A+B)* (C+D),那么我们可以先计算A+B,这个时候我们先将A 加载到累加器里面(LOAD  A),然后再将B拿出来进行加法运算(ADD  B),这个加法运算是发生在ALU里面的,然后这个时候,ALU里就有了A+B的结果,我们把这个结果放回存储器的E中,然后进行C+D,当ALU中有了C+D之后,我们不是将它存储进存储器,而是拿出E来乘(MUL  E),ALU计算完成之后,里面就有了我们要的结果,但是❗️我们还要把它存回存储器(Store X)

剩下的三个原理差不多,可以认为是我们有可以存放不只一个操作数的缓冲空间,这样我们就有了更多选择,可以从Mem中直接拿,可以先拿到Reg里面再进行操作……

指令格式

接下来再来看看操作数对指令格式的影响

如果我们的指令长度是16bit,OpCode占用4bit,每个地址占用6bit,那么指令就是:

各个部分所占用的长度取决于“数量”:

上面的OpCode一共要使用4bit,其实我们就能看出,这个指令集中一共有2^4个指令类型

每个地址要有6bit,所以我们推断要么寄存器有2^6个存储单元,要么Mem有2^6个存储单元

如果ISA只支持寄存器取数,一共有2^m个指令,寄存器存储单元有2^k个,每个指令需要x个操作数

那么这条指令的长度就是 (m + k * x) bit

如果要求Mem取数,就要看Mem有多少个存储单元

我们下面主要以MIPS以参考对象来进行解释和学习

三、MIPS

1. 寄存器

MIPS是寄存器-寄存器型的架构,一共有32个寄存器,每个寄存器的大小是32bit,而且MIPS要求:所有的操作数必须从寄存器中拿,如果操作数在Mem里面,那么就要先从Mem拿到寄存器里面,然后再进行操作

a. MIPS中有一些特殊的寄存器:

  • R0 : 存储的值永远是0
  • PC:存储的是下一条指令的地址
  • 浮点数寄存器

b. 寄存器的操作顺序:

我们拿 add R5,R5,R6来举例,这个指令的意思其实是将R5 + R6的数值存储到R5中,也就是说,在operation之后的第一个寄存器是目的寄存器,第二、三个寄存器是操作数所在的寄存器

2.memory(存储器)

首先我们要知道,从微观上来说,存储器是一个很大的一位数组,数组中的每个元素的location占用1B也就是8 bits,地址从0开始编号

a. 存储器 vs 寄存器

存储器                         寄存器
存储单元大小 1 Byte = 8 bits 32 bits
存储单元数量

对于32位架构来说是2^32-1

对于64位结构来说是2^64-1

32
性能

容量大,存取速度慢

容量小,存取速度快

b. 字节地址和字地址

首先我们要明确的是,这两种地址是从不同角度对存储器的存储单元做出的解释。出现字地址的原因是存储器的存储单元大小固定是1 Byte,但是我们在将数据从存储器拿进寄存器的时候是4 Byte也就是1 word为单位拿,为了方便起见,引入字地址

字节地址将存储单元的单位设置成为字节Byte,字地址将存储器的存储单元的单位设置为4 Byte = 1 word

但是如果要引入字地址,就一定要注意对齐(word-aligned)

我们从word的角度去看memory的时候,要注意怎么存取,我们只能去找4的整数倍,也就是地址的最后两位是00的地址,否则,如果我们去找7,9号地址,我们将memory的存储单元看成字就没有意义了

3.指令的执行

执行原则:

在MIPS中,所有的指令默认是顺序执行的,并且一次执行只执行一条指令,只有在上一条指令执行完成之后我们才会去执行下一条指令

存储原则:

MIPS的指令集架构是建立在存储程序型的计算机上面的,这种计算机的特点是:

1⃣️程序和数据都存储在memory里面,不分彼此

2⃣️当我们需要执行指令的时候,需要从memory里面拿

3⃣️当我们需要数据执行计算命令的时候,需要从memory里面拿

顺序执行流程

数值计算相关的执行流程

  • 在执行语句之前,PC中早就存储了即将执行的这条语句的地址A(注意不是语句本身,而是地址),然后根据A,相应的指令I会从memory中被拿到,然后放进IR寄存器(Instruction register)里面
  • control unit会对I进行翻译和解码,然后给ALU和寄存器们发送控制信号,告知他们要完成的操作,然后ALU就会对寄存器中的数据进行计算,然后将结果放回寄存器
  • 最后control unit会更新PC,然后准备执行下一条指令

从memory中拿取数值相关的执行流程(LW  R6,R5)

  • 和数值计算相关的执行流程相比,只有ALU部分有所不同
  • ALU会计算memory的地址,这个地址会存储在存储器地址寄存器(Memory Address Register),然后根据这个地址拿到对应的数据之后,数据会被存储在存储数据寄存器(Memory Data Register)中
  • 然后数据就可以被放进寄存器中

将数据存储进memory的相关执行流程(SW R6,R5)

  • 和数值计算相关的执行流程相比,只有ALU部分有所不同
  • 首先ALU先将R5中存储的地址放进Memory Address Register中
  • 然后再从寄存器R6中拿到数据,放进Memory Data Register中之后,将数据写进memory中

在这个执行流程中,有几个小细节需要拓展出去:

第一个是PC的更新

指令的跳转

由于判断语句的存在,我们可能有的时候并不想让程序顺序执行,而是跳转到想要执行的语句

1⃣️ bne  R1, R2, Label

当R1和R2寄存器中的数值不相等的时候,跳转到Label这个地址对应的指令,否则继续顺序执行

2⃣️beq  R1,R2,Label

当R1和R2寄存器中的数值相等的时候,跳转到Label这个地址对应的指令,否则继续顺序执行

3⃣️j  Label

有点类似于goto语句,无论前面是什么语句,这条语句直接让执行流跳转到Label这个地址所在的语句

比较典型的应用是在if..else语句中和loop里面

if...else语句

在这个类型的语句中,最容易忘记的是jump指令

我们假设有代码if(i == j)h = i + j;
elseh = i - j;寄存器:R1(i)、R2(j)、R3(h)那么就有:bne  R1 , R2 , ELSEadd  R3 , R1 , R2j    NEXT
ELSE: sub  R3 , R1 , R2
NEXT:........

loop

在这个语句中,其实包含初始化的格式和其他的一些汇编语言模式,但是最容易忘记的还是jump和递增语句

我们假设有代码:for(int i = 0;i < 5;i ++)
{b = b + i;
}寄存器: R5(i) , R6(b)那么有MIPS的汇编代码:addi    R5, R0, 0addi    R1, R0, 5
Loop:   beq     R1, R5, Exitadd     R6, R6, R5addi    R5, R5, 1j       Loop
Exit:   .........

4. 指令的翻译(语义)

在执行流程中我们能看到,指令在进入ALU执行步骤之前需要在control unit进行识别,那么control unit的识别机制又是怎么样的?

MIPS的三种指令类型

1⃣️R型指令

R型指令主要是用于算数运算和逻辑运算

R型 Opcode(6 bits) rs(5 bits)

rt(5 bits)

rd(5 bits) shamt(5 bits) funct(6 bits)

Opcode + Funct: 用来描述语句的类型,在R型指令里面,Opcode全部都是0000 00,这是因为MIPS要用这种设置来将R型指令和其他两种指令区分开来,但是因为R型指令里面还有很多子指令,i.e. add, sub, 所以需要funct这一段来指明这是哪种子指令

rs(source register): 第一个源寄存器

rt(source register):第二个源寄存器

上面

计算机体系结构·指令集ISA相关推荐

  1. 【计算机体系结构-03】ISA (Instruction Set Architecture) 指令集架构特性

    1. 指令的类型 上一篇文章里主要介绍了几种机器模型,有机器模型后需要知道计算机有什么样的基本指令,接下来就来看看指令都有哪些类型. [注]:以下指令主要为 MIPS 指令. 类型 指令 数据传输 L ...

  2. 【计算机体系结构-01】指令集体系结构、微体系结构简介

    1. "虚拟" to "现实" 首先可以看这张图片,下面的 Physics 所指的是我们的物理世界中看得见摸得到或者是客观存在的事物,而人类希望将自己的工作内容 ...

  3. 汇编程序设计与计算机体系结构软件工程师教程笔记:处理器、寄存器简介

    <汇编程序设计与计算机体系结构: 软件工程师教程>这本书是由Brain R.Hall和Kevin J.Slonka著,由爱飞翔译.中文版是2019年出版的.个人感觉这本书真不错,书中介绍了 ...

  4. 【趋势】未来十年计算机体系结构的历史和趋势

    来源:机器之心 先分享我对这篇文章的总结,或者我得到的启发: 1.DSA (Domain-Specific Architectures,特定领域的体系结构) 将成为未来十年甚至更长时间,计算机体系结构 ...

  5. subd计算机系统结构,计算机体系结构第2章试题答案.doc

    计算机体系结构第2章试题答案.doc (9页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 9.90 积分 一 填空题1.堆栈型 通用寄存器型2.累加器型 ...

  6. 汇编程序设计与计算机体系结构软件工程师教程笔记:总结

    <汇编程序设计与计算机体系结构: 软件工程师教程>这本书是由Brain R.Hall和Kevin J.Slonka著,由爱飞翔译.中文版是2019年出版的.个人感觉这本书真不错,书中介绍了 ...

  7. 计算机网络体系结构i层,1.2 计算机体系结构

    1 计算机体系结构的发展 概述 1964年,阿姆达尔(Amdahl)在介绍IBM360系统时指出:计算机体系结构是站在程序员的角度所看到的计算机属性,即程序员要能编写出可在机器上正确运行的程序所必须了 ...

  8. 未来十年计算机体系结构的历史和趋势

    编者按: 本文转载自微信公众号 机器之心 图灵人工智能,原文标题为<计算机架构的新黄金时代,两位图灵奖得主最新力作>. 先分享我对这篇文章的总结,或者我得到的启发: 1.DSA(Domai ...

  9. 计算机体系结构的一知半解

    计算机的体系结构是关于计算机自身的系统架构,而软件指令集架构在计算机体系结构中处于核心地位,因为软件和硬件之间都是通过软件指令集架构(ISA)来对话的. 例如,在20世纪60年代早期,IBM 有四个不 ...

最新文章

  1. 关于css中float的一切
  2. 实战:使用Nginx限流
  3. 10个你值得收藏的牛逼开源后台控制面板
  4. 多层感知机MLP常见的超参数有哪些?如果MLP模型对于数据集过拟合了,如何调整这些超参数来进行解决?
  5. 2021-03-12java性能调优三板斧
  6. cocos2d-x实例学习之常用类及其概要作用
  7. hdu1247 字典树或者hash
  8. JSP中javaBean和Servlet理解
  9. Android横竖屏切换继续播放视频
  10. 斯蒂文斯理工学院计算机博士,美国斯蒂文斯理工大学——招收全奖土木工程博士生 - 导师招生 - 小木虫 - 学术 科研 互动社区...
  11. hibernate框架学习之使用SQLQuery查询数据
  12. python 计算时间_python的时间使用和时间计算
  13. 计算机工程与应用 格式,计算机工程与应用模板.doc
  14. math java 计算_Java中的数学计算函数汇总
  15. Java程序设计语言基础05:Java的类和对象
  16. router-link 绑定事件不生效
  17. c#水晶报表连接mysql_C# 水晶报表打印 绑定数据库表
  18. python随机生成字符串_Python 生成一段随机字符串的两种写法
  19. 火狐无法安装扩展_立即安装的前5个Firefox扩展
  20. cnpm : 无法加载文件 C:\Users\zsl\AppData\Roaming\npm\cnpm.ps1,因为在此系统上禁止运行脚本

热门文章

  1. 【GD32F427开发板试用】+demo的正确打开方式(一)
  2. 山东科技大学OJ题库 1219 体重正常吗?
  3. Flink 异常 - 3.java.lang.InternalError: Malformed class name
  4. mysql 记录binlog过程_记录一次mysqlbinlog恢复过程
  5. Cayley n顶点树数定理
  6. android 控件页脚,在布局末尾的android中设置页脚
  7. [Python数据分析] 6-挖掘建模(无监督学习)
  8. i.MX6Q lvds和hdmi双屏同显 1080P 分辨率
  9. 输入框显示表情图标-vue篇
  10. 404单页带时间访问一次自动更换壁纸