在英特尔软件开发人员手册中,它说中断向量 32-255 通常是用户为外部 IO 设备定义的。在我的系统编程类(class)中,我必须开发一个简单的设备驱动程序。我的问题是如何定义用于特定设备的特定中断向量?这是通过BIOS完成的吗?
注意:我们正在开发一个简单的操作系统,所以我的情况非常具体,但是,最后我需要了解这一切是如何在 x86 系统上发生的。当前,我们的系统设置为将 32 位以上的一些中断向量分配给串行端口和键盘等设备。在阅读 Intel 82801EB ICH5 IO Controller 的数据表时,特别是有关 8259 PIC 的部分,它说 IRQ15 是辅助 IDE channel 。它最终将如何作为中断向量放在堆栈中?
我可能只是很困惑,以至于这个问题没有意义,所以我提前道歉。
编辑:所以我们的系统编程类有一个非常简单的操作系统,它有内核例程,用于安装 ISR 来处理给定向量编号的特定中断。在上个季度的类里面,教授给了我们一个头文件,其中将键盘定义为矢量编号 0x2c 或类似的东西。我试图找出如何使用我们的内核例程将主要和/或次要 IDE channel 中断映射到各种 ISR。目前,所有未使用的中断向量都有一个默认处理程序,如果发生中断,它将打印消息,因此目前 IDE 中断甚至没有打开,但这是另一个问题。
最佳答案
您可以对 PIC(可编程中断 Controller )进行编程以映射某些设备 IRQ。
在 x86 上,有两个 PIC 菊花链提供 IRQ0-IRQ17。 IRQ0-7 由 8259 管理,IRQ8-15 由第二个 8259 管理。第一个向 CPU 发出信号并且是主机,第二个(从机)向第一个发出信号。
IDT(中断描述符表)将中断映射到 ISR(中断服务程序)的地址。中断可以通过 INT 指令直接引发(软件陷阱)。
例如,要引发中断 0x80,请执行 INT 0x80
。
要处理 0x80, mov [0x80*4], int_80_handler
。假设是 32 位架构,int_80_handler
函数的地址现在存储在 IDT 中的第 0x80 个位置。
你会发现这些很有帮助:
http://en.wikipedia.org/wiki/Intel_8259
http://en.wikipedia.org/wiki/Interrupt_Handler
http://en.wikipedia.org/wiki/Interrupt
http://en.wikipedia.org/wiki/Interrupt_descriptor_table
关于x86 - 如何识别 x86 上的设备特定中断?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/773199/