汇编学习笔记【2】

本文介绍了8086CPU的寄存器结构,包括通用寄存器、段寄存器和特殊寄存器CS与IP的作用。详细阐述了16位结构CPU的寻址能力,8086CPU如何通过段地址和偏移地址合成20位物理地址的过程,并解析了CPU的工作流程以及如何通过 jmp 指令修改CS和IP的值。
摘要由CSDN通过智能技术生成

寄存器介绍
对于一个汇编程序员来说,CPU中的主要部件就是寄存器。
不同的CPU,寄存器的个数、结构是不相同的,8086CPU有14个寄存器,每个寄存器有一个名称,分别是:AX,BX,CX,DX,SI,DI,SP,BP,IP,CS,SS,DS,ES,PSW。
这些寄存器都是16位的,AX,BX,CX,DX这4个常用来存放一般性数据,因此被称为通用寄存器

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

什么是16位结构的CPU ?
概括地讲:
1) 运算器一次最多可以处理16位的数据
2)寄存器的最大宽度为16位
3)寄存器和运算器之间的通路为16位的

8086CPU有20位地址总线,可以传送20位地址,达到1MB的寻址能力。8086CPU又是16位结构,它只能送出16位的地址,表现出的寻址能力只有64KB。
8086CPU采用一种在内部用两个16位地址合成的方法形成一个20位的物理地址
所以当8086CPU要读写内存时,它会:
1.CPU中的相关部件提供两个16位的地址,一个称为段地址,一个称为偏移地址;
2.段地址和偏移地址通过内部总线送入一个称为地址加法器的部件
3.地址加法器将两个16位的地址合成一个20位的物理地址
4.地址加法器通过内部总线将20位物理地址送入输入输出控制电路
5.输入输出控制电路将20位物理地址送上地址总线
6.20位物理地址被地址总线传送到存储器

地址加法器采用
物理地址=段地址*16+偏移地址的算法

在8086CPU中有4个段寄存器:CS,DS,SS,ES,由这4个段寄存器提供什段地址
CS和IP是8086CPU中两个最关键的寄存器,它们指示了CPU当前要读取指令的地址,CS为代码段寄存器,IP为指令指针寄存器。
在8086CPU中,任意时刻,设CS中的内容为M,
IP中的内容为N,8086CPU将从内存M*16+N单元开始,读取一条指令并执行。
也可以这样表述:8086CPU中,任意时刻,CPU将CS:IP指向的内容当作指令执行

8086CPU的工作过程可以简要描述如下:
a.从CS:IP指向内存单元读取指令,读取的指令进入指令缓冲器
b.IP=IP+所读取指令的长度,从而指向下一条指令
c.执行指令,转到步骤a,重复这个过程

在8086CPU加电启动或复位后CS和IP被设置为CS=F000H,IP=FFFFH,即在8086PC机刚启动时,CPU从内存FFFF0H单元中读取指令执行,FFFF0H单元中的指令是8086PC机开机后执行的第一条指令

最简单修改CS、IP的指令:jmp指令
若想同时修改CS、IP的内容,可以用指令"jmp 段地址:偏移地址“完成
比如jmp 2AE3:3,执行后CS=2AE3H,IP=0003H
若只想修改IP的内容,可用指令“jmp某一合法寄存器”完成
如:
jmp ax 执行后ax、CS的内容不变,IP的值变为ax的值

在编程时,可以根据需要,将一组内存单元定义为一个段,可以将长度为N(N<=64KB)的一组代码,存在一组地址连续、起始地址为16的倍数的内存单元中,可以认为,这段内存是用来存放代码的,从而定义了一个代码段.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值