《汇编语言》第十五章 外中断

第15章 外中断

以前我们讨论的都是CPU对指令的执行。我们知道,CPU在计算机系统中,除了能够执行指令,进行运算以外,还应该能够对外部设备进行控制,接受它们的输入,向它们进行输出,也就是说,CPU除了有运算能力外,还要有I/O能力。

要及时处理外设的输入,显然需要解决两个问题:1.外设的输入随时可能方式,CPU如何得知?2.CPU从何处的到外设的输入?

15.1 接口芯片和端口

第14章我们讲过,PC系统的接口卡和主板上,装有各种接口芯片。这些外设接口芯片的内部有若干个寄存器,CPU将这些寄存器当作端口来对待。

外设的输入不直接送入内存和CPU,而是先送入端口中;CPU向外设的输出也不是直接输入外设,而是先送入端口中,再由相关的芯片送到外设,CPU还可以向外设输出控制信息,而这些控制命令也是先送到相关芯片的端口中,然后再由相关的芯片根据命令对外设实施控制。

可见,CPU通过端口和外部设备进行联系。

15.2 外中断信息

现在,我们知道了外设的输入被存放在端口中,可是外设的输入随时都有可能到达,CPU如何及时地知道,并进行处理呢?

CPU提供中断机制来满足这种需要。前面讲过,当CPU的内部有需要处理的事情发生的时候,将产生中断信息,引发冲断过程。这种中断信息来自CPU内部。

还有一种中断信息,来自于CPU外部,当CPU外部有需要处理的事情发生的时候,比如,外设的输入到达,相关芯片将向CPU发出相应的中断信息。CPU在执行完当前指令后,可以检测到发送过来的中断信息,引发中断过程,处理外设的输入。

在PC系统中,外中断源一共有以下两类:

1.可屏蔽中断

可屏蔽中断是CPUCPU可以不相应的外中断。CPU是否相应可屏蔽中断,要看标志寄存器的IF位的设置。当CPU检测到可屏蔽中断信息时,如果IF=1,则CPU执行完当前指令后相应中断,引发中断过程。如果IF=0,则不响应可屏蔽中断。

我们回忆一下引发内中断的一个步骤,IF,TF=0。这样,在引发中断进入中断处理后,不会再相应可以屏蔽的中断,这种设置其实是非常合理的。

当然,我们可以通过指令来手动设置IF位。

sti 设置IF=1,可相应可屏蔽中断
cti 设置IF=0,不可相应可屏蔽中断。

2.不可屏蔽中断

不可屏蔽中断是CPU必须相应的外中断。当CPU检测到不可屏蔽中断信息时,则在执行完当前指令后,立即相应,引发中断过程。

对于8086CPU,不可屏蔽中断的中断类型码固定为2,所以,在中断过程中,不需要取中断类型码,过程如下:

1.标志寄存器入栈,IF=0,TF=0
2.CS,IP入栈
3.IP=8,CS=0AH

几乎所有由外设引发的外中断,都是可屏蔽中断,当外设有需要处理的时间,相关芯片向CPU发出可屏蔽中断信息。不可屏蔽中断信息是在系统有必须要处理的紧急情况发生时用来通知CPU的中断信息。在我们现在,讨论的都是可屏蔽中断

15.3 PC机键盘的处理过程

1.键盘输入

键盘上的每一个键都相当于一个开关,键盘中有一个芯片对键盘上的每一个键的开关状态进行扫描。
按下一个键,开关接通,芯片就产生了一个扫描码,扫描码说明了按下的键在键盘上的位置。扫描码被送入主板上的相关接口芯片的寄存器中,该寄存器的端口地址为60h

注意,端口地址可以直接使用纯数字表示,它不是内存,当用in out指令时计算机会自动识别相关数字为端口,这点不需要你费心,这种简单的道理是需要你明确的。

松开按下的键时,也产生一个扫描码,扫描码说明了松开键的位置。也被送入60h。

两种码分别被称为通码断码。扫描码长度为1个字节, 通码的第7位为0,断码的第7位为1 ,即
断码=通码+80h

比如,g键的通码为22h,断码为a2h。
键盘的扫描码图片

2.引发9号中断

键盘的输入到达60h端口时,相关的芯片就会向CPU发出中断类型码为9的可屏蔽中断信息。CPU检测到该信息后,如果IF=1,则响应中断,否则就会屏蔽中断。

3.执行 int 9 中断例程

BIOS提供了int 9中断例程,用来进行基本的键盘输入处理,主要的工作如下:
1. 读入60h端口中的扫描码;

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值