8086CPU只有16位寄存器,却可以访问20位的物理地址

一、背景介绍

Intel 8086是一个由Intel于1978年所设计的16位微处理器芯片,是x86架构的鼻祖。它是以8080和8085的设计为基础,拥有类似的寄存器组,但是数据总线扩充为16位。总线界面单元(Bus Interface Unit)透过6字节预存的队列位指令给执行单元(Execution Unit),所以取指令和执行是同步的,8086 CPU有20条地址线,可直接寻址1MB的存储空间,每一个存储单元可以存放一个字节(8位)二进制信息。

二、16位的寄存器为什么可以访问20位的物理地址

地址线有20位,寄存器却只有16位,这不矛盾么?怎么才能用16位的寄存器来访问20位地址线所表示的内存范围(1M)呢?答案就是用两个寄存器,一个用来表示段(也就是段寄存器),一个用来表示段内的偏移,这样才可以做到访问20位地址线所代表的内存范围。将段地址左移4bit,则扩充到了20bit。我们知道,左移1位就是乘2,所以有了段地址×16+偏移地址,也就是段地址×10H+偏移地址,这个逻辑地址与物理地址的转换公式。

而采取这样的办法纯粹是因为硬件设计的原因,不得已而为之。

这里写图片描述

这两个16位寄存器提供的地址分别称为段地址偏移地址
它们通过地址加法器合成一个20位物理地址,然后通过内部总线将20位物理地址送到输入输出控制,之后,通过地址总线送到储存器

参考:

https://tntaxin.blog.csdn.net/article/details/78965130?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-5.control&dist_request_id=&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-5.control

 

  • 5
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 8086 CPU 中,有四个可以存放地址的寄存器,分别是: 1. IP 寄存器(指令指针寄存器):用于存储下一条指令的地址。 2. CS 寄存器(代码段寄存器):用于存储代码段的起始地址。 3. DS 寄存器(数据段寄存器):用于存储数据段的起始地址。 4. SS 寄存器(堆栈段寄存器):用于存储堆栈段的起始地址。 这些寄存器都是 16 的,可以存储 64KB 的地址空间。其中 IP 寄存器和 CS 寄存器组成了代码段地址,DS 寄存器和偏移地址组成了数据段地址,SS 寄存器和偏移地址组成了堆栈段地址。 ### 回答2: 8086CPU中有四个可以存放地址的寄存器,它们分别是段寄存器和指针寄存器。 段寄存器包括CS(代码段寄存器)、DS(数据段寄存器)、SS(堆栈段寄存器)和ES(附加段寄存器),它们分别用于存放代码段、数据段、堆栈段和附加段的起始地址。在8086CPU中,访问内存时通常采用地址偏移的方式,将段寄存器中存放的段地址与偏移地址相加得到物理地址。 指针寄存器包括SP(堆栈指针寄存器)和BP(基址指针寄存器),它们用于指示堆栈段中的栈顶和基址的置。SP存放堆栈段内的偏移地址,用于记录当前栈顶的置;BP通常用于指向函数堆栈帧的基地址,方便访问函数局部变量和参数。 这四个寄存器的功能不同,但都可以存放地址信息。在程序执行过程中,通过这些寄存器的组合使用,可以实现对内存中不同段的访问和地址的传递,从而操作和处理数据。 ### 回答3: 8086 CPU中有四个可以存放地址的寄存器,分别是: 1. CS(Code Segment Register,代码段寄存器):用于存放当前执行指令的代码段的起始地址,指示CPU执行的代码段。CS寄存器16的,存放的是段地址。 2. DS(Data Segment Register,数据段寄存器):用于存放数据段的起始地址,指示CPU对数据的访问。DS寄存器也是16的,存放的是段地址。 3. ES(Extra Segment Register,附加段寄存器):用于存放附加数据段的起始地址,可以用于一些特殊的数据访问操作。ES寄存器同样是16的,存放的是段地址。 4. SS(Stack Segment Register,堆栈段寄存器):用于存放堆栈段的起始地址,指示CPU对堆栈的操作。SS寄存器同样是16的,存放的是段地址。 这四个寄存器8086 CPU中扮演了重要的角色,通过存放地址信息,CPU能够正确地访问和操作不同的内存区域,实现代码的执行和数据的读写。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值