汇编之端口
文章目录
[toc]
端口
在PC机系统中,和CPU通过总线相连的芯片除各种存储器外,还有以下3种芯片。
- 各种接口卡(比如,网卡、显卡)上的接口芯片,它们控制接口卡进行工作;
- 主板上的接口芯片,CPU通过它们对部分外设进行访问;
- 其他芯片,用来存储相关的系统信息,或进行相关的输入输出处理。
在这些芯片中,都有一组可以由CPU读写的寄存器。这些寄存器,它们在物理上可能处于不同的芯片中, 但是它们在以下两点上相同。
- 都和CPU的总线相连,这种连接是通过它们所在的芯片进行的;
- CPU对它们(芯片上的寄存器)进行读或写的时候都通过控制线向它们所在的芯片发出端口读写命令。
从CPU的角度,将这些寄存器都当作端口,对它们进行统一编址,从而建立了一个统一的端口地址空间。 每一个端口在地址空间中都有一个地址。在访问端口的时候,CPU通过端口地址来定位端口。因为端口所在的芯片和CPU通过总线相连,
CPU可以直接读写以下3个地方的数据。
- CPU内部的寄存器
- 内存单元
- 端口
1、端口的读写
端口地址和内存地址一样,通过地址总线来传送。在PC系统中,CPU最多可以定位64KB个不同的端口。则端口地址的范围为0-65535
。
端口的读写指令只有两条:in
和out
,分别用于从端口读取数据和往端口写入数据。
在in和out指令中,只能使用ax或al来存放从端口中读入的数据或要发送到端口中的数据。
|
|
2、CMOS RAM芯片
PC机中,有一个CMOS RAM芯片,一般简称为CMOS。此芯片的特征如下
- 包含一个实时钟和一个有128个存储单元的RAM存储器
- 该芯片靠电池供电。关机后内部的实时钟正常工作,RAM中的信息不丢失
- 128个字节的RAM中,内部实时钟占用
0~0dh
单元来保存时间信息,其余大部分单元用于保存系统配置信息,供系统启动时BIOS程序读取。BIOS也提供了相关的程序,使我们可以在开机的时候配置CMOS RAM中的系统信息。 - 该芯片内部有两个端口,端口地址为70h和71h。CPU通过这两个端口来读写CMOS RAM
- 70h为地址端口,存放要访问的CMOS RAM单元的地址;71h为数据端口,存放从选定的CMOS RAM单元中读取的数据,或要写入到其中的数据。 可见,CPU对CMOS RAM的读写分两步进行,比如,读CMOS RAM的2号单元: ①将2送入端口70h; ②从端口71h读出2号单元的内容。
CMOS RAM中存储的时间信息
在CMOS RAM中,存放着当前的时间:年、月、日、时、分、秒。长度都为1个字节, 存放单元为:
9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
---|---|---|---|---|---|---|---|---|---|
年 | 月 | 日 | 时 | 分 | 秒 |
BCD码是以4位二进制数表示十进制数码的编码方法 4 == 0100B
一个字节可表示两个BCD码。则CMOS RAM存储时间信息的单元中,存储了用两个BCD码表示的两位十进制数,高4位的BCD码表示十位,低4位的BCD码表示个位。比如,00010100b表示14。
|
|
3、shl和shr指令
shl和shr是逻辑移位指令
shl是逻辑左移指令,它的功能为:
- 将一个寄存器或内存单元中的数据向左移位;
- 将最后移出的一位写入CF中;
- 最低位用0补充。
shr是逻辑右移指令,同理
|
|
将X逻辑左移一位,相当于执行X=X*2 将X逻辑右移一位,相当于执行X=X/2
4、总结
什么是端口?
CPU通过总线连着很多芯片(网卡、显卡、某些外设)。CPU和这些芯片“沟通”的渠道就是端口。例如使用cmos ram芯片时,CPU通过地址总线将地址信息传输到这个芯片接收地址信号的端口上,这样就可以指定芯片内部的CPU指令的操作对象地址,之后,数据则会通过芯片的另一个端口进行读或写。
对端口的读写实际上就是遵照“先传地址,再操作数据”的原则,本质上就是对和CPU相联的芯片里面的寄存器进行读写。
文章作者 cold-bin
上次更新 2023-01-28