我有一个用 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。我还有一些问题。
为什么“消息地址寄存器包含 0xFEE 的固定顶部”。
消息地址寄存器中的 RH、DM 和 XX 位是什么?
这如何与 LAPIC 一起使用?基本上,它如何触发 LAPIC 中的中断。这是 PCI 设备的一项特殊功能,允许它们在 LAPIC 中触发中断。或者仅仅是PCI设备使用一些触发中断的特定数据写入LAPIC的内存映射寄存器。因为通常情况下,LAPIC 是在每个 LAPIC 都相同的地址从内核内部访问的。它是来自CPU外部的某种处理器间中断吗?