8086cpu学习笔记(2):寄存器

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时,访问奇地址存储体,与数据线高八位相连。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sdhdwyx

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值