各种存储器都通过地址总线,数据总线以及控制总线与CPU相连。CPU对这些各种存储器组成的存储单元进行统一编址,统一寻址。除了各种存储器和CPU相连之外,还有以下几种芯片和CPU相连:
(1)各种接口卡(比如网卡,显卡)上的芯片,它们控制接口卡工作
(2)主板上的接口芯片,CPU通过它们对部分外设进行访问
(3)其他芯片,用来存储相关的系统信息,或进行相关的输入输出处理
在这些芯片中,都有一些可以用CPU读写的寄存器,虽然这些寄存器在物理上不同的芯片,但是有如下两个相同点:
(1)都和CPU的总线相连,当然这种连接是通过它们所在的芯片进行的
(2)CPU对它们进行读或写的时候通过控制线向它们的芯片发出端口读写命令
从CPU的角度,CPU对这些端口统一进行寻址,每个端口在地址空间都有独一无二的地址。
CPU可以直接从:内存地址空间,端口,CPU内部寄存器这三个地方直接读写数据。
14.1端口的读写
CPU和端口所在的芯片通过地址总线相连,所以端口地址和内存地址一样,通过地址总线来传送。在PC系统中,CPU最多可以定位64KB个不同的端口。则端口的地址范围为0~65535.
对端口的读写只能用in和out指令。
访问内存和访问端口的区别:
(1)访问内存:
mov ax,ds:[8] ;假设执行前(ds)=8
执行步骤:
一.cpu通过地址线将地址信息8发出
二.cpu通过控制线发出内存读命令,选中存储器芯片,并通知它,将要从中读取数据
三.存储器将8号单元中的数据通过数据线送入CPU
(2)访问端口:
in al,60h ;从60号端口读入一个字节
执行步骤:
一.CPU通过地址线将地址信息60h发出
二.CPU通过控制线发出端口命令,告诉芯片将要读取该端口的信息
三.端口所在芯片将60h端口的信息送到al中
14.2 CMOS RAM芯片
在PC中有一个CMOS RAM芯片,该芯片特征如下:
1.包含一个时钟和一个128个存储单元的RAM存储器
2.该芯片靠电池供电。所以关机后仍正常工作