各种存储器都和CPU的地址线、数据线、控制线相连。CPU在操控它们的时候,把它们都当作内存来对待,把它们总的看作一个由若干存储单元组成的逻辑存储器,这个逻辑存储器称为内存地址空间
在PC机系统中,和CPU通过总线相连的芯片除各种存储器外,还有以下3种芯片:
各种接口卡(网卡、显卡等)上的接口芯片,用于控制接口卡进行工作
主板上的接口芯片,
CPU通过其对部分外设进行访问其他芯片,用来存储相关的系统信息,或进行相关的输入输出处理
在这些芯片中,都有一组可以由CPU读写的寄存器。这些寄存器,它们物理上可能处于不同的芯片种,但它们在以下两点以上相同
都与
CPU的总线相连CPU对它们进行读或写时都通过控制线向它们所在的芯片发出端口读写的命令
从CPU的角度,将这些寄存器都当作端口,对它们进行统一编址,从而建立了一个统一的端口地址空间。每一个端口在地址空间中都有一个地址
CPU可以直接读写3个地方的数据:
CPU内部的寄存器内存单元
端口
端口的读写
在访问端口时,CPU通过端口地址来定位端口
端口地址和内存地址一样,通过地址总线来传送
在PC系统中,CPU最多可以定位64KB个不同的端口,则端口地址的范围是0-65535
端口的读写指令只有两条:
in,从端口读取数据out,往端口写入数据
访问内存时的总线信息
1 | mov ax,ds:[8] |
执行时与总线相关的操作:
CPU通过地址线将地址信息8发出CPU通过控制线发出内存读命令,选中存储器芯片,并通知它,将要从中读取数据存储器将8号单元中的数据通过数据线送入
CPU
访问端口时的总线信息
1 | in al,60h ;从60h号端口读入一个字节 |
执行时与总线相关的操作:
CPU通过地址线将地址信息60h发出CPU通过控制线发出端口读命令,选中端口所在的芯片,并通知它,将要从中读取数据端口所在的芯片将
60h端口中的数据通过数据线送入CPU
在in和out指令中,只能使用ax或al来存放从端口中读入的数据或要发送到端口中的数据。访问8位端口时用al,访问16位端口时用ax
对0-255以内的端口进行读写时:
1 | in al,20h ;从20h端口读入一个字节 |
对256-65535的端口进行读写时,端口号放在dx中:
1 | mov dx,3f8h ;将端口号3f8h送入dx |
CMOS RAM芯片
CMOS芯片是一种低耗电存储器,其主要作用是用来存放BIOS中的设置信息以及系统时间日期。
此芯片的特征:
包含一个实时钟和一个有128个存储单元的
RAM存储器(早期计算机为64个字节)该芯片靠电池供电,关机后其内部的实时钟仍可工作,
RAM中信息不丢失128个字节的
RAM中,内部实时钟占用0-0dh单元来保存时间信息,其余大部分单元用于保存系统配置信息,供系统启动时BIOS程序读取。BIOS也提供了相关的程序,使我们可以在开机的时候配置CMOS RAM中的系统信息该芯片内部有两个端口,端口地址为
70h和71h。CPU通过这两个端口来读写CMOS RAM70h为地址端口,存放要访问的CMOS RAM单元的地址;71h为数据端口,存放从选定的CMOS RAM单元中读取的数据,或要写入到其中的数据CPU对CMOS RAM的读写分两步进行
例:读CMOS RAM的2号单元
将2送入端口
70h从端口
71h读出2号单元的内容
shl和shr指令
逻辑移位指令
shl指令
逻辑左移指令
功能:
将一个寄存器或内存单元中的数据向左移位
将最后移出的一位写入
CF中最低位用0补充
例:
1 | mov al,01001000b |
执行后(al)=10010000b,CF=0
如果移动位数大于1时,必须将移动位数放在cl中
1 | mov al,01010001b |
执行后(al)=10001000b,CF=0
即,将X逻辑左移一位,相当于执行X=X*2
shr指令
逻辑右移指令
功能:
将一个寄存器或内存单元中的数据向右移位
将最后移出的一位写入
CF中最高位用0补充
例:
1 | mov al,10000001b |
执行后(al)=01000000b,CF=1
如果移动位数大于1时,必须将移动位数放在cl中
将X逻辑右移一位,相当于执行X=X/2
CMOS RAM中存储的时间信息
在CMOS RAM中,存放着当前的时间:年、月、日、时、分、秒,每个信息长度1个字节
存放单元为:
| 秒 | 分 | 时 | 日 | 月 | 年 |
|---|---|---|---|---|---|
| 0 | 2 | 4 | 7 | 8 | 9 |
这些数据以BCD码(以4位二进制数表示十进制数码的编码方法)的方式存放:

一个字节可以表示两个BCD码
CMOS RAM存储时间信息的单元中,存储了用两个BCD码表示的两位十进制数,高4位的BCD码表示十位,低4位的BCD码表示个位。例:00010100b表示14
编程,在屏幕中间显示当前的月份
两部分工作:
从
CMOS RAM的8号单元读出当前月份的BCD码将用
BCD码表示的月份以十进制的形式显示到屏幕上BCD码值=十进制数码值,则BCD码值+30h=十进制数对应的ASCII码从
CMOS RAM的8号单元中读出的一个字节,分为两个表示BCD码值的数据显示十位和个位
BCD码值+30h对应的ASCII码字符
1 | assume cs:code |