第十四章 端口

第十四章 端口

在PC机系统中,和CPU通过总线相连的芯片除各种存储器外,还有以下3种芯片。

  • 各种接口卡(比如,网卡、显卡)上的接口芯片,它们控制接口卡进行工作;
  • 主板上的接口芯片,CPU通过它们对部分外设进行访问;
  • 其他芯片,用来存储相关的系统信息,或进行相关的输入输出处理。

在这些芯片中,都有一组可以由CPU读写的寄存器。这些寄存器,它们在物理上可能处于不同的芯片中,但是它们在以下两点上相同。

  • 都和CPU的总线相连,这种连接是通过它们所在的芯片进行的;
  • CPU对它们进行读或写的时候都通过控制线向它们所在的芯片发出端口读写命令。

从CPU的角度,将这些寄存器都当作端口,对它们进行统一编址,从而建立了一个统一的端口地址空间。

每一个端口在地址空间中都有一个地址。在访问端口的时候,CPU通过端口地址来定位端口。因为端口所在的芯片和CPU通过总线相连,CPU可以直接读写以下3个地方的数据。

  • CPU内部的寄存器;
  • 内存单元;
  • 端口。

14.1 端口的读写

端口地址和内存地址一样,通过地址总线来传送。在PC系统中,CPU最多可以定位64KB个不同的端口。则端口地址的范围为0-65535。

端口的读写指令只有两条:in和out,分别用于从端口读取数据和往端口写入数据。

在in和out指令中,只能使用ax或al来存放从端口中读入的数据或要发送到端口中的数据。

14.2 CMOS RAM芯片

  1. 包含一个实时钟和一个有128个存储单元的RAM存储器。
  2. 靠电池供电,关机后内部时钟仍可以工作,RAM中的信息不丢失。
  3. 128个字节的RAM中,内部实时钟占用0~0dh单元来保存时间信息,其余大部分用于保存系统配置信息,供系统启动时B10S程序读取。BI0S也提供了相关的程序,使得可以在开机的时候配置CMOS RAM中的系统信息。
  4. 该芯片内部有2个端口,端口地址为70h和71h。CPU通过这两个端口来读写CMOS RAM。
  5. 70h为地址端口,存放要访问的CMOS RAM单元的地址:71h为数据端口。如:读CMOS RAM的2号单元:1.将2送入端口70h2.从端口71h读出2号单元的内容mov al,2out 70h, alin al, 71h

14.3 shl和shr指令

shl功能

1.将一个寄存器或内存单元中的数据向左移位

2.将最后移出的一位写入CF3.最低位用0补充

如:mov al,10001001bshl al,1;将al中的数据左移一位执行完后(al)=00010010b,CF=1。

shr功能

1.将一个寄存器或内存单元中的数据向右移位

2.将最后移出的一位写入CF3.最高位用0补充

如:mov al,10001001bshr al,1;将al中的数据右移一位执行完后(al)=01000100b,CF=1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值