8086cpu寄存器组
通用寄存器
四个16位寄存器:AX,BX,CX,DX
每个可拆分成两个8位寄存器:AH,AL,BH,BL,CH,CL,DH,DL
8086中也只有如上八个8位的寄存器.
通用寄存器只能存放数据,不可存放地址。
AX:累加器
BX:基址寄存器
CX:计数寄存器
DX:数据寄存器
指令和变址寄存器
SP:堆栈指针寄存器
BP:基址指针寄存器
SI:源变址寄存器
DI:目的变址寄存器
存放某一段内地址的偏移量,用来形成操作数地址,主要在堆栈操作和变址运算中使用。
段寄存器
CS:代码段寄存器 (系统自动设置)
DS:数据段寄存器
SS:堆栈段寄存器
ES:附加段寄存器
存放逻辑段首地址
指令和指针寄存器和标志位寄存器
IP:指令指针寄存器
存放下一条指令在现代码段中的偏移量。(用于跳转)
PSW:标志寄存器
存放运算结果特征,用作后续条件转移指令的转移控制条件。
具体格式:
状态标志位:
CF:进位 有进位为1
PF:奇偶 (第八位)1的个数,偶为1
AF:辅助进位 第四位向第五位 有进位为1
ZF:零 为零则为1
SF:符号 本次运算结果符号位为1则为1 (第8或16位)
OF:溢出 两带符号数运算 溢出为1
控制标志位:
TF:单步标志 为1可使cpu进入单步调试状态
IF:中断允许 为1则cpu可响应可屏蔽中断
DF:方向标志 串行操作指令中,通过DF选择对DI/SI寄存器的内容进行递增 或递减,为1则递减
存储地址的分段管理
由于8086cpu的寄存器只有16位,只可访问64KB字节的存储空间,而数据总线有20条,可访问1MB的存储空间。所以对存储单元的地址进行分段管理,将20位的物理地址分为16位的段基址和16位的偏移地址分开存放,段基址放在段寄存器中,偏移地址放在IP中,运行指令时,两地址在地址加法器中合成20位的物理地址来访问全部的存储单元。
物理地址的确定方法:
物理地址 = 段基址 * 16 + 偏移地址
8086的分体结构
1MB的存储空间分为两部分:偶地址存储体和奇地存储体,各512KB当引脚A0=0时,访问偶地址存储体,与数据线低八位相连。当引脚BHE#=0时,访问奇地址存储体,与数据线高八位相连。