gpt4 book ai didi

x86 - 如何识别 x86 上的设备特定中断?

转载 作者:行者123 更新时间:2023-12-04 22:14:45 28 4
gpt4 key购买 nike

在英特尔软件开发人员手册中,它说中断向量 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/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com