26考研 | 王道 | 计算机组成原理 | 四、指令系统

26考研 | 王道 | 计算机组成原理 | 四、指令系统

文章目录

1.指令系统

0.指令集体系结构

1. 指令格式

1.按地址码数目不同来分
2.指令-按指令长度分类

机器字长和存储字长固定不变。

3.指令-按操作码长度分类
4.指令-按操作类型分类

程序控制类指令除了上述还有循环指令

2. 扩展操作码指令格式

2.指令的寻址方式

###1. 指令寻址

1.顺序寻址(PC)+"1"-->PC



图中的指令字长是变化的,不是右边的16bit,所以才会每次读入一个字

2.跳跃寻址:由转移指令指出


本节回顾

  1. 转移指令是通过修改PC实现的
  2. 程序计数器PC:存放下一条指令所在单元的地址
  3. 累加器ACC:用来存放操作数或运算结果
  4. 指令寄存器IR:临时放置从内存里面取得的程序指令的寄存器,用于存放当前从主存储器读出的正在执行的一条指令。
  5. 地址寄存器MAR:用来保存当前CPU所访问的内存单元的地址。

2. 数据寻址

1.常见寻址方式

取指令也需要一次访存(如果指令字长等于存储字长的话)

直接寻址

间接寻址

寄存器寻址

寄存器间接寻址

隐含寻址

立即寻址

2. 数据寻址--偏移寻址

基址寻址

变址寻址


其实IX的值就是个偏移量

基址&变址复合寻址

相对寻址


等到取指令取完第M+3条指令之后,PC值就会变为M+4,而不是M+3,所以相对寻址(跳转指令)就得按照PC=M+4来算,也就是补码表示的-4

基址寻址中程序浮动指的是整段程序在内存里的浮动,相对寻址中程序浮动指的是一段代码在程序内部的浮动。

本节回顾

硬件如何实现数的"比较"

注:无条件转移指令jmp2,就不会管PSW的各种标志位。PC=2

3. 数据寻址--堆栈寻址


硬堆栈压入和弹出都不需要访存,而软堆栈不管压入还是弹出都需要一次访存,因为软堆栈是在主存中划分出来了一部分内容作为堆栈(也是函数调用时候保存信息的哪个堆栈)


3.程序的机器级代码表示

1. 高级语言与机器级代码之间的对应

X86汇编语言指令基础

以MOV指令为例

X86架构CPU,有哪些寄存器?

通用寄存器另外两种表示方式

####📊 通用寄存器功能概览

寄存器 主要用途 细分功能 典型指令示例
AX 累加器(核心运算) 乘除运算、I/O操作、数据中转 MULDIVINOUT
BX 基址寄存器(内存寻址) 存储偏移地址、数组/结构体访问 MOV AX, [BX]LEA
CX 计数器(循环/字符串控制) 循环次数计数、字符串操作重复控制 LOOPREP MOVSB
DX 数据寄存器(I/O及高精度运算) I/O端口寻址、乘除法辅助、大数存储 IN AX, DXMUL DX

更多例子

总结

2. 常用的X86汇编语言指令

常见的算数运算指令

destination:目的地(d目的操作数)

source:来源地(s源操作数)

目的操作数d不可以是常量,可以来是寄存器或者主存

而s三者都可以

在进行除法运算之前,需要把被除数位扩展,如32bit/32bit要变成64b/32b,存放64位的被除数需要两个寄存器,edx:eax,高32位存放在edx,低32位存放在eax

X86汇编语言当中不允许两个操作数同时来源于主存。

3. ATu0026T格式和intel格式

4. 选择语句的机器级表示

程序默认是顺序执行的

程序中的选择语句(分支结构)

无条件转移指令--jmp

无条件转移指令,类似于c语言里的goto语句

无条件转移指令无法实现if,else语句,因为不需要任何条件就可以跳转

条件转移指令--jxxx

示例:选择语句的机器级表示

扩展:cmp指令的底层原理

5. 循环语句机器级表示

用条件转移指令实现循环

用loop指令实现循环

6.函数调用的机器级表示

1.call和ret指令
2.如何访问栈帧
3.如何切换栈帧
进入函数

通过这两条命令保存上一层函数的栈帧地址,并设置当前函数的栈帧地址

enter是零地址指令,直接等价于那两条命令

函数返回

执行那两条指令前是这样的

执行第一条指令后,也就是让esp和ebp指向同一个位置

执行第二条指令后,就返回了上一层函数调用

这两条等价于leave

ret指令
4.如何传递参数和返回值

如果用来保存 被调用函数的返回值 的寄存器原来有数据,那就得压栈,然后去保存返回值,等把返回值读出来以后再回复原来的数据

前两句代码执行:相当于enter

执行sub指令,相当于划分了一片属于自己的空间,即图中绿色部分

执行接下来两句,作用是初始化变量temp1和temp2

接下来四句指令都是给下层函数add传递参数,需要倒腾一遍,先把temp1放到寄存器,再从寄存器放回主存的对应地址(不从主存直接写到主存是因为汇编的源操作数和目的操作数不可以同时是主存)

执行call指令,然后就是惯例执行add的前两行,这是保存上一层函数的信息

通过ebp访问上层函数保存的本层函数要用的参数,保存到寄存器中

执行add

执行leave

执行ret

通过eax寄存器使用返回值

再次使用eax给再上一层函数返回值

之后就是leave和ret了

4. CISC和RISC

有的复杂指令用硬件实现困难,那就把组成复杂指令的一些简单的指令存储起来(微程序),完成这个复杂指令

比如矩阵乘就可以由剩下的整数加减乘和矩阵加减来完成

相关推荐
dcloud_jibinbin11 小时前
【uniapp】小程序体积优化,分包异步化
前端·vue.js·webpack·性能优化·微信小程序·uni-app
蒙奇D索大12 小时前
【11408学习记录】考研英语长难句精析:三步拆解真题复杂结构,轻松攻克阅读难关!
笔记·学习·考研·改行学it
初恋叫萱萱20 小时前
从正确到卓越:昇腾CANN算子开发高级性能优化指南
性能优化
进击的圆儿20 小时前
HTTP协议深度解析:从基础到性能优化
网络协议·http·性能优化
潘达斯奈基~20 小时前
spark性能优化2:Window操作和groupBy操作的区别
大数据·性能优化·spark
天天进步201520 小时前
从零开始构建现代化React应用:最佳实践与性能优化
前端·react.js·性能优化
小武~1 天前
嵌入式Linux系统性能优化:深入剖析I/O性能瓶颈
linux·运维·性能优化
John_ToDebug1 天前
【深度解析】Performance API 与 UKM:从开发者工具到浏览器遥测,全面解锁 Web 性能优化格局
chrome·性能优化
小白学大数据1 天前
增量爬取策略:如何持续监控贝壳网最新成交数据
爬虫·python·性能优化
一只叫煤球的猫2 天前
从1996到2025——细说Java锁的30年进化史
java·后端·性能优化