《汇编语言》— 第十四章(端口)

本文介绍了CPU如何通过端口与外部设备交互,包括端口的读写操作,详细讲解了CMOS RAM芯片的功能、地址空间及读取时间信息的过程。还探讨了SHL和SHR逻辑移位指令的应用,并展示了如何从CMOS RAM读取月份并以十进制形式显示在屏幕上的实例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

各种存储器都通过地址总线,数据总线以及控制总线与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.该芯片靠电池供电。所以关机后仍正常工作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值