《汇编语言》第二章 寄存器

一个典型的CPU由运算器,控制器,寄存器,时钟组成,这些在CPU内部的器件靠内部总线相连,内部总线实现CPU内各个器件之间的联系,外部总线实现CPU和主板上其它器件的联系

运算器:进行信息处理
寄存器:进行信息存储
控制器:控制各种器件进行工作
时钟:负责发出CPU开始计时的时钟信号,时钟的频率越高,CPU的运行速度越快
内部总线:连接各种器件,在它们间进行数据的传输

对于一个程序员来说,CPU中主要部件是寄存器,寄存器是程序员可以用指令读写的部件,程序员通过改变各种寄存器中的内容来实现对CPU的控制

不同的CPU,寄存器的个数,结构不同。8086CPU有14个寄存器:AX,BX,CX,DX,SI,DI,SP,BP,IP,CS,SS,DS,ES,PSW

2.1 通用寄存器

8086CPU的所有寄存器都是16位的,可以存放2个字节,AX,BX,CX,DX这4个寄存器通常用来存放一般性的数据,被称为通用寄存器

AX的逻辑结构:
在这里插入图片描述
16位数据在寄存器中存放方式:
在这里插入图片描述

8086上一代CPU中寄存器都是8位的,为了保证兼容,8086CPU的AX,BX,CX,DX这4个寄存器可以分为两个独立使用的8位寄存器来使用,分为高8位8-15位(如AH)和低8位0-7位(如AL)

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

2.2 字在寄存器中的存储

出于对兼容性的考虑,8086CPU可以一次处理两种尺寸的数据

1,1字节即8位,可以存在8位寄存器中
2,字,记为word,一个字由2个字节组成,这两个字节分别称为这个字的高位字节和低位字节,高位字节存储在高8位寄存器,低位字节存储在低8位寄存器

在这里插入图片描述

2.3 几条汇编指令

move ax,18 将18送入寄存器AX AX = 18

add ah,78 将寄存器AX中的数值加78 AX = AX + 78 

在使用汇编指令时,要注意运算的值不能越接,超过寄存器的存储范围,且操作对象的位数应该一致

2.4 物理地址

CPU在访问内存单元时,要给出内存单元的地址。所有的内存单元构成的存储空间是一个一维的线性空间。每一个内存单元在这个空间中都有唯一的地址,即物理地址

CPU通过地址总线送入寄存器的,必须是一个内存单元的物理地址,在CPU向地址总线上发出物理地址之前,必须要在内部形成这个物理地址

2.5 16位结构的CPU

16位结构描述了CPU的几个特性:
1,运算器一次可以处理16位的数据
2,寄存器最大宽度为16位
3,寄存器和运算器之间的通路为16位

8086CPU内部,能一次性处理,传输,暂时存储的信息的最大长度为16位。内存单元的地址在送上地址总线之前,必须在CPU中处理,传输,暂时存放,对于16位CPU,能一次处理,传输,暂时存储16位的地址

2.6 8086CPU 给出物理地址的方法

8086CPU有20位地址总线,达到1MB寻址能力,但8086CPU又是16位结构,在内部一次传输,处理,暂存的地址只能有16位,如果将地址从内部简单地发出,那么只能送出16位地址,表现出的寻址能力只有64KB

8086CPU采用一种在内部用两个16位地址合成的方法来形成一个20位的物理地址
在这里插入图片描述

地址加法器采用 物理地址 = 段地址*16 + 偏移地址的方法和成物理地址,8086CPU要访问123C8H的内存单元的过程:

在这里插入图片描述

2.7 物理地址 = 段地址 * 16 + 偏移地址

物理地址 = 段地址 * 16 + 偏移地址:该表达式的本质意义是,CPU在访问内存时,用一个基础地址(段地址*16)和一个相对于基础地址的偏移地址相加,给出内存单元的物理地址

即8086CPU的寻址功能是基础地址 + 偏移地址 = 物理地址寻址模式的一种具体实现方案

2.8 段的概念

其实内存并没有分段,段的划分来自于CPU
在这里插入图片描述
将若干地址连续的内存单元看作一个段,用段地址*16 定位段的起始地址(基础地址),用偏移地址定位段中的内存单元

注:
1,段地址*16必然是16的整数倍,则一个段的起始地址一定是16的倍数
2,偏移地址为16位,16位寻址能力为64kb,所以一个段的长度最大为64kb

CPU可以用不同的段地址和偏移地址形成同一个物理地址

2.9 段寄存器

8086CPU在访问内存时需要相关部件提供内存单元的段地址和偏移地址,送入地址加法器合成为物理地址。段地址在8086CPU中的段寄存器存放

8086CPU有4个段寄存器:CS,DS,SS,ES,当8086CPU访问内存时,这4个CPU提供内存单元的段地址

2.10 CS和IP

CS和IP是8086CPU中最关键的寄存器,它们指示了CPU当前要读取指令的地址,CS为代码段寄存器,IP为指令指针寄存器

在8086CPU中,任意时刻,设CS中内容为M,IP中内容为N,8086CPU将从内存M*16 + N(可记作CS:IP)单元开始,读取一条指令并执行

在这里插入图片描述

在这里插入图片描述

8086CPU的工作可以概述为:
1,从CS:IP指向的内存单元读取指令,读取的指令进入指令缓冲器
2,IP = IP + 所读取指令的长度,从而指向下一条指令
3,执行指令,转到步骤1,重复这个过程

内存中的一段信息曾被CPU执行过的话,那么它所在的单元必然被CS:IP指向过

2.11 修改CS,IP的指令

在CPU中,程序员能直接用指令读写的部件只有寄存器,程序员可以通过改变寄存器中的内容来实现对CPU的控制

CPU从何处执行指令由CS,IP中的内容决定的,程序员可以通过改变CS,IP中的内容来控制CPU执行目标指令

mov指令被称为传送指令,可以通过mov指令设置8086CPU内大部分寄存器的值,如 mov ax,123将ax中的值设置为123

但是mov指令并不能用于设置CS,IP的值,能够改变CS,IP的内容的指令被称为转移指令,如 jmp指令

若想同时修改CS,IP中的内容,可以用 jmp 段地址:偏移地址 这样的指令完成,用指令中的段地址修改CS,偏移地址修改IP
jmp 2AE3:3 执行后,CS = 2AE3H,IP=0003H,CPU将从2AE33H读取指令

若仅想修改IP的值,可以用 jmp 某一合法寄存器的指令完成,用该寄存器内的值修改IP
jmp ax,执行前,ax = 1000H,CS=2000H,IP=0003H
执行后,ax = 1000H,CS=2000H,IP=1000H

2.12 代码段

在8086机中,在编程时,可以根据需要将一组内存单元定义为一个段,可以将长度为N(N<=64KB)的一组代码,存放到一组地址连续,起始地址为16的倍数的内存单元中

想要让CPU执行代码段中的指令,需要将CS:IP指向所定义的代码段中的第一条指令的首地址

实验1 查看CPU和内存,用机器指令和汇编指令编程

用到的Debug功能
1,-r,查看,改变CPU寄存器的内容
2,-d,查看内存中的内容
3,-e,改写内存中的内容
4,-u,将内存中的机器指令翻译成汇编指令
5,-t,执行一条机器指令
6,-a,命令以汇编指令的格式在内存中写入一条机器指令

1,用r命令查看CPU内寄存器的内容
在这里插入图片描述
用r命令改变寄存器内的内容

在这里插入图片描述

2,用d命令查看内存中的内容

使用d 段地址:偏移地址来查看10000H中的内容:
在这里插入图片描述
debug将列出从指定内存单元开始的128个内存单元的内容,在使用过
d 1000:0后,debug列出了1000:0到1000:7f的所有内容

输出由3部分组成
1,中间是从指令地址开始的128个内存单元的内容,用16进制的格式输出,每行的输出从16的整数倍的地址开始,最多输出16行的内容
2,左边是每行的起始地址
3,右边是每个内存单元中的数据对应的可显示的ASCII码字符,没有对应可显示的字符时,debug就用 . 来替代

查看1000:9处的内容:
在这里插入图片描述
debug从1000:9开始显示,一直到1000:88,一共128字节

刚进入debug使用d命令列出debug预设地址处的内容,接着使用d命令,查看后续内容
在这里插入图片描述
也可以用d命令查看范围或查看一个物理地址内的内容,采用 d 段地址:起始偏移地址 结尾偏移地址
在这里插入图片描述

3,用e命令改写内存中的内容

修改1000:0-1000:9内存单元中的内容:
在这里插入图片描述

4,用u命令将内存中单元中的内容翻译为汇编指令
在这里插入图片描述
5,使用t命令执行CS:IP指向的指令

在这里插入图片描述
6,用a命令以汇编指令的形式在内存中写入机器指令

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值