86系列CPU硬件中断程序设计:中断服务与向量设置

需积分: 48 1 下载量 57 浏览量 更新于2024-07-12 收藏 650KB PPT 举报
本文档是关于硬件中断程序设计的讲解,主要涉及86系列CPU的中断系统、中断源分类、中断向量表以及硬件中断程序设计的两个关键步骤。 在计算机系统中,硬件中断是一种处理突发事件的重要机制。86系列CPU能够处理256种不同类型的中断,这些中断分为可屏蔽中断(INTR)和不可屏蔽中断(NMI)。中断源可以是外部硬件设备或微处理器内部产生的事件。中断服务子程序负责处理中断事件,而中断向量表则存储了每个中断服务子程序的地址,CPU通过中断类型号来查找并执行相应的服务子程序。 硬件中断程序设计主要包括两部分: 1. 编写中断服务子程序,这需要以中断函数的形式实现。例如,可以定义一个名为`myint`的中断服务函数,使用`interrupt`关键字进行声明: ```c void interrupt myint(void) { // 函数体,处理中断逻辑 } ``` 在使用此函数之前,需要对其进行声明: ```c void interrupt myint(void); ``` 2. 设置中断向量,即将中断服务子程序的地址放入中断向量表中。这通常通过`setvect()`函数完成,该函数需要中断类型号和指向中断服务函数的指针作为参数: ```c #include <dos.h> void setvect(int num, void interrupt (*isr)()); // 如果要设置类型号为0x08的中断服务函数为myint,代码如下: setvect(0x08, myint); ``` 在C语言中,可以利用DOS中断和BIOS中断提供的功能,例如通过调用中断服务子程序来与硬件设备交互或执行特定操作。中断服务子程序应当高效且快速,因为它们打断了正常程序的执行流程,处理完事件后需要尽快恢复原程序的执行。 总结来说,硬件中断是计算机系统中处理紧急事件的关键机制,而中断服务子程序和中断向量表是实现这一机制的核心组成部分。通过编写中断函数和设置中断向量,开发者能够有效地响应和管理各种硬件中断事件。