当前位置:鱼C工作室 >汇编语言 > 查看文章

外中断01 – 零基础入门学习汇编语言69

第十五章:外中断01

 

让编程改变世界

Change the world by program


 

引言

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

也就是说,CPU 除了有运算能力外,还要有 I/O( Input/Output ,输入/输出)能力。

 

接口芯片和端口

 

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

 

外设的输入不直接送入内存和CPU ,而是送入相关的接口芯片的端口中;

CPU 向外设的输出也不是直接送入外设,而是先送入端口中,再由相关的芯片送到外设。

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

 

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

CPU 在执行完当前指令后,可以检测到发送过来的中断信息,引发中断过程,处理外设的输入。

 

外中断信息

 

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

1、可屏蔽中断

2、不可屏蔽中断

可屏蔽中断是CPU 可以不响应的外中断。CPU 是否响应可屏蔽中断,要看标志寄存器的IF 位的设置。

 

当CPU 检测到可屏蔽中断信息时:

如果IF=1,则CPU 在执行完当前指令后响应中断,引发中断过程;

如果IF=0,则不响应可屏蔽中断。

 

我们回忆一下内中断所引发的中断过程:

(1)取中断类型码n;

(2)标志寄存器入栈,IF=0,TF=0;

(3)CS 、IP 入栈;

(4)(IP)=(n*4),(CS)=(n*4+2)

由此转去执行中断处理程序。

 

可屏蔽中断所引发的中断过程 ,除在第一步的实现上有所不同外,基本上和内中断的中断过程相同。

因为可屏蔽中断信息来自于CPU外部,中断类型码是通过数据总线送入CPU 的;

而内中断的中断类型码是在CPU内部产生的。

 

现在,我们可以解释中断过程中将IF置为0的原因了。将IF置0的原因就是,在进入中断处理程序后,禁止其他的可屏蔽中断。

当然,如果在中断处理程序中需要处理可屏蔽中断,可以用指令将IF置1 。

 

8086CPU 提供的设置IF的指令如下:

sti,用于设置IF=1;

cli,用于设置IF=0。

 

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

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

 

不可屏蔽中断的中断过程:

1、标志寄存器入栈,IF=0,TF=0;

2、CS、IP入栈;

3、(IP)=(8),(CS)=(0AH)。

 

几乎所有由外设引发的外中断,都是可屏蔽中断。当外设有需要处理的事件(比如说键盘输入)发生时,相关芯片向CPU 发出可屏蔽中断信息。

不可屏蔽中断是在系统中有必须处理的紧急情况发生时用来通知CPU 的中断信息。在我们的课程中,主要讨论可屏蔽中断。

分页阅读: 1 2 下一页
为您推荐

报歉!评论已关闭.