基本框架:
- 寄存器:
- 寄存器是cpu的主要部件,是程序员可以用指令读写的部件。
- 8086cpu有14个寄存器:AX,BX,CX,DX(通用寄存器)SI,DI,SP,BP(基址和变址寄存器)IP,(指令指针和标志寄存器)CS,SS,ES,DS(段寄存器)
- 通用寄存器:AX,BX,CX,DX。这4个寄存器可以分为两个可独立使用的8位寄存器(最大可以存放值为255的数据)来使用。其中0~7位为低位字节(L),8~15位为高位字节(H),如AH、AL。 一般用16进制来表示一个数据。
- 字在寄存器中的存储:8086cpu可以一次性处理字节和字两种尺寸的数据
- 字节:内存划分的基本单位:由8个bit位组成,可以放在8位寄存器中。
- 字:由两个字节组成,可以放在16位寄存器中。
- 双字:四个字节。
- 四字:八个字节。
- 汇编指令:mov、add:
- 进位导致的最高位的丢失。(这里的丢失不是cpu真的丢弃这个进位制,存放在别的地方,后面会学)
- 低位与高位寄存器是两个不同的寄存器,相互是独立的。
- 在进行数据传送或运算时要注意指令的两个操作对象的位数是一致的。
- 8086cpu给出物理地址(所有内存单元构成的存储空间是一个一维的线性空间,每一个内存单元在这个空间都有唯一的地址)的方法:8086cpu有20位地址总线,但其又是16位结构。所以解决方案:物理地址=段地址*16+偏移地址。段地址*16:左移4位(2进制)。
- 本质含义:cpu访问内存时,用一个基础地址(段地址*16)和一个相对于基础地址的偏移地址相加,给出内存单元的物理地址。
- 段的概念:内存并没有分段,段的划分来自于cpu,段的划分是灵活的。将若干地址连续的内存单元看成一个段。
- 段地址*16必然是16的倍数,所以一个段的起始地址也一定是16的倍数。一个段的长度最大为64KB。(2的16次方)
- CS和IP
- CS:代码段寄存器(段地址)
- IP:指令指针寄存器(偏移地址)
- CS:IP:指令的物理地址=cs*16+ip
- 计算器工作原理:
- CPU基于CS:IP,计算出物理地址,然后到相应的内存单元读取指令,送到指令缓冲区。
- CPU自动修改IP的值,IP = IP + 所读取指令的长度,从而为下一条指令读取做准备;
- 执行指令。 回到第1步,重复此过程。
来源:https://www.cnblogs.com/toubunengtu/p/9827688.html