各种存储器都和CPU的地址线,数据线,控制线相连,CPU在操控它们的时候,把它们都当作内存来对待,把它们总地看作一个由若干个存储单元组成的逻辑存储器,这个逻辑存储器我们将其称为内存地址空间
在PC机系统中,和CPU通过总线相连的芯片除各种存储器外,还有以下3种芯片:
1,各种接口卡(网卡,显卡)上的接口芯片,它们控制接口卡进行工作
2,主板上的接口芯片,CPU通过它们对部分外设进行访问
3,其它芯片,用来存储相关的系统信息,或进行相关的输入输出处理
这些芯片中,都有一组可以由CPU读写的寄存器,这些寄存器,它们在物理上可能处于不同的芯片中,但是有两点相同:
1,都和CPU的总线相连,这种连接通过它们所在的芯片
2,CPU对它们读写时都是通过控制线向它们所在的芯片发出端口读写命令
从CPU的角度,将这些寄存器都当作端口,对它们进行统一编址,从而建立了一个统一的端口地址空间,每一个端口在地址空间中都有一个地址
CPU可以直接读写以下3个地方的数据:
1,CPU内部的寄存器
2,内存单元
3,端口
14.1 端口的读写
在访问端口的时候,CPU通过端口地址来定位端口,因为端口所在的芯片和CPU通过总线相连,所以端口地址和内存地址一样,通过地址总线来传送
对端口的读写不能用mov,push,pop等内存读写指令,端口的读写指令只有两条:in 和 out,分别用于端口读取数据和往端口写入数据
CPU执行内存访问指令时,总线上的信息:
mov ax,ds:[8]
1,CPU通过地址总线将地址信息8发出
2,CPU通过控制线发出内存读命令,选中存储器芯片,并通知它,将要从中读取数据
3,存储器将8号单元中的数据通过数据线送入CPU
CPU执行端口访问指令时,总线上的信息:
in al,60h //从60h号端口读入一个字节
1,CPU通过地址线将地址信息60h发出
2,CPU通过控制线发出端口读命令,选中端口所在的芯片,并通知它,将要从中读取数据
3,端口所在的芯片将60h端口的数据通过数据线送入CPU
在in和out指令中,只能用ax或al存放从端口中读入的数据或要发送到端口中的数据,访问8位端口时用al,访问16位端口时,用ax
对256~65536的端口进行读写时,端口号放在dx中
mov dx,3f8h ;将端口号3f8h送入dx
in al,dx ;从3f8h端口读入一个字节
out dx,al ;向3f8h端口写入一个字节
14.2 CMOS RAM芯片
PC中,有一个CMOS RAM芯片,一般简称为CMOS,其特征:
1,包含一个实时钟和一个有128个存储单元的RAM
2,靠电池供电,关机后,RAM中信息不丢失
3,128个字节的RAM中,内部实时钟占用0~0dh单元保存时间信息,其余大部分单元用于保存系统配置信息,供系统启动时BIOS程序读取,BIOS也提供了相关的程序,使得开机时配置CMOS RAM中的系统信息
4,该芯片内部有两个端口,端口地址为70h和71h,CPU通过这两个端口来读写CMOS RAM
5,70h为地址端口,存放要访问的CMOS RAM单元的地址,71h为数据端口,存放从选定的CMOS RAM单元中读取的数据,或要写入到其中的数据
CPU对CMOS RAM的读写分为两步,如读写CMOS RAM的2号单元:
1,将2送入端口70h
2,从端口71h读出2号单元的内容
14.3 shl 和 shr 指令
shl 和 shr 是逻辑移位指令
shl是逻辑左移,它的功能:
1,将一个寄存器或内存单元中的数据向左移位
2,将最后移出的一位写入到CF中
3,最低位用0补充
左移1位
mov al,01001000b
shl al,1 ;将al中的数据左移一位
左移1位后结果:
CF = 0
10010000
如果移动位数大于1位,必须将移动位数放到cl中
mov al,01010001b
mov cl,3
shl al,cl
执行后结果:
CF = 0
10001000b
逻辑左移1位相当于乘2,逻辑右移1位相当于除2
14.4 CMOS RAM中存储的时间信息
在CMOS RAM中,存放着当前的时间:年,月,日,时,分,秒这6个信息的长度均为1个字节,存放单元为
秒:0 分:2 时:4 日:7 月:8 年:9
这些数据以BCD码的方式存放,BCD码是以4位2进制数表示十进制数码的编码方法
一个字节表示两个BCD码,则CMOS RAM存储时间信息的单元中,存储了用两个BCD码表示的两位十进制数,高4位的BCD码表示十位,低4位的BCD码表示个位
考虑:在屏幕中间显示当前月份
分析:需要两步:
1,从CMOS RAM的8号单元中读出当前月份的BCD码
2,将用BCD码表示的月份以十进制的形式显示到屏幕上
assume cs:code
code segment
start: mov al,8
out 70h,al
in al,71h
mov ah,al
mov cl,4
shr ah,cl
and al,00001111b
add ah,30h
add al,30h
mov bx,0b800h
mov es,bx
mov byte ptr es:[160*12+40*2],ah
mov byte ptr es:[160*12+40*2+2],al
mov ax,4c00h
int 21h
code ends
end start