博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
X86 I/O端口
阅读量:6642 次
发布时间:2019-06-25

本文共 1411 字,大约阅读时间需要 4 分钟。

  与外设的交互都是通过读写外设上的寄存器进行的,外设的寄存器也成为“I/O端口”,它有两种编制方式:统一编址和独立编址。

  统一编址

  外设接口中的IO寄存器(即IO端口)与主存单元一样看待,每个端口占用一个存储单元的地址,将主存的一部分划出来用作IO地址空间,如,在 PDP-11中,把最高的4K主存作为IO设备寄存器地址。端口占用了存储器的地址空间,使存储量容量减小。

  统一编址也称为“IO内存方式”,外设寄存器位于内存空间。

  独立编址

  IO地址与存储地址分开独立编址,I/0端口地址不占用存储空间的地址范围,这样,在系统中就存在了另一种与存储地址无关的IO地址,CPU也必须具有专用与输入输出操作的IO指令(IN、OUT等)和控制逻辑。独立编址下,地址总线上过来一个地址,设备不知道是给IO端口的、还是给存储器的,于是处理器通过MEMR/MEMW和IOR/IOW两组控制信号来实现对I/O端口和存储器的不同寻址。如,intel80x86就采用单独编址,CPU内存和I/O是一起编址的,就是说内存一部分的地址和I/O地址是重叠的。

      独立编址也称为“I/O端口”方式,外设寄存器位于“I/O(地址)空间”。
      对于x86架构来说,通过IN/OUT指令访问。PC架构一共有65536个8bit的I/O端口,组成64K个I/O地址空间,编号从0~0xFFFF,有16位,80x86用低16位地址线A0-A15来寻址。连续两个8bit的端口可以组成一个16bit的端口,连续4个组成一个 32bit的端口。I/O地址空间和CPU的物理地址空间是两个不同的概念,例如I/O地址空间为64K,一个32bit的CPU物理地址空间是4G。


 

  几乎每一种外设都是通过读写设备上的寄存器来进行的。外设寄存器也称为“I/O端口”,通常包括:控制寄存器、状态寄存器和数据寄存器三大类,而且一个外设的寄存器通常被连续地编址。CPU对外设IO端口物理地址的编址方式有两种:一种是I/O映射方式(I/O-mapped),另一种是内存映射方式(Memory-mapped)。而具体采用哪一种则取决于CPU的体系结构。

  有些体系结构的CPU(如,PowerPC、 m68k等)通常只实现一个物理地址空间(RAM)。在这种情况下,外设I/O端口的物理地址就被映射到CPU的单一物理地址空间中,而成为内存的一部 分。此时,CPU可以象访问一个内存单元那样访问外设I/O端口,而不需要设立专门的外设I/O指令。这就是所谓的“内存映射方式”(Memory-mapped)。

  而另外一些体系结构的CPU(典型地如X86)则为外设专门实现了一个单独地地址空间,称为“I/O地址空间”或者“I/O端口空间”。这是一个与CPU地RAM物理地址空间不同的地址空间,所有外设的I/O端口均在这一空间中进行编址。CPU通过设立专门的I/O指令(如X86的IN和OUT指令)来访问这一空间中的地址单元(也即I/O端口)。这就是所谓的“I/O映射方式”(I/O-mapped)。与RAM物理地址空间相比,I/O地址空间通常都比较小,如x86 CPU的I/O空间就只有64KB(0-0xffff)。这是“I/O映射方式”的一个主要缺点。

转载于:https://www.cnblogs.com/immortal-worm/p/5867690.html

你可能感兴趣的文章
模拟阻尼运动
查看>>
ASP.NET MVC框架开发系列教程
查看>>
ViewPager,实现真正的无限循环(定时+手动)
查看>>
Android学习笔记十:异步处理
查看>>
微信小程序实现博客园文章阅读功能
查看>>
tortoise svn冲突解决
查看>>
UWP -- Background Task 深入解析
查看>>
分享如何使用PHP将URL地址参数进行加密传输提高网站安全性
查看>>
【批处理学习笔记】第二十课:扩充字符串
查看>>
RabbitMQ使用详解
查看>>
js 特效
查看>>
Python tuple 函数
查看>>
xftp上传文件失败,执行程序发现磁盘满了:No space left on device
查看>>
Ext Js 6.2.1 classic grid 滚动条bug解决方案
查看>>
Linux(Centos )的网络内核参数优化来提高服务器并发处理能力【转】
查看>>
spring中scope作用域(转)
查看>>
RDA CoreDump 实例
查看>>
Struts2中Struts.xml的作用
查看>>
Delphi调用JAVA的WebService上传XML文件(XE10.2+WIN764)
查看>>
kong nginx 配置文件说明&&借鉴
查看>>