MSI-X 如何触发中断处理程序?是否需要轮询选择的内存地址?

问题描述

我有一个使用 UEFI 启动的小内核。我正在使用 QEMU 进行虚拟化。我想在我的内核中编写一个 xHCI 驱动程序来支持 USB 键盘。我很难找到简洁明了的信息。我在内核中“找到”了 xHCI。我有一个指向它的 PCI 配置空间的指针。它支持 MSI-X。我想使用 MSI-X,但我无法理解它如何与 xHCI 和 USB 配合使用。

我的问题是通常 osdev.org 提供的信息非常丰富,并且具有实现某些功能所需的基础。在 MSI-X 的情况下,情况似乎并非如此。我很难将 osdev.org 上的所有信息与 MSI-X 功能联系起来。

所以基本上,我找到了 MSI-X 表,然后我在那里设置了一些地址来告诉 xHCI PCI 设备写入该地址以触发中断。但是在某个时候会调用一个中断处理程序吗?我是否需要轮询这个地址来确定是否发生了中断?我原以为 MSI-X 表中的向量控制字段让我设置一个中断向量,但所有位都被保留。

编辑

我发现以下 stackoverflow 问答部分回答了我的问题:Question about Message Signaled Interrupts (MSI) on x86 LAPIC system

所以基本上,数据寄存器的低字节包含要触发的向量,消息地址寄存器包含要触发的 LAPIC id。我还有一些问题。

  1. 为什么“消息地址寄存器包含固定的 0xFEE 顶部”。

  2. 消息地址寄存器中的 RH、DM 和 XX 位是什么?

  3. 这如何与 LAPIC 配合使用?基本上,它如何触发 LAPIC 中的中断。它是 PCI 设备的一项特殊功能,允许它们在 LAPIC 中触发中断。或者仅仅是 PCI 设备将某些特定数据写入 LAPIC 的内存映射寄存器,从而触发中断。因为通常 LAPIC 是从内核内部访问的,每个 LAPIC 的地址都相同。是不是来自 CPU 之外的某种处理器间中断?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)