Lines Matching refs:MSI
16 MSI驱动指南
26 本指南介绍了消息标记中断(MSI)的基本知识,使用MSI相对于传统中断机制的优势,如何
27 改变你的驱动程序以使用MSI或MSI-X,以及在设备不支持MSI时可以尝试的一些基本诊断方法。
30 什么是MSI?
35 MSI能力首次在PCI 2.2中规定,后来在PCI 3.0中得到增强,允许对每个中断进行单独屏蔽。
36 MSI-X功能也随着PCI 3.0被引入。它比MSI支持每个设备更多的中断,并允许独立配置中断。
38 设备可以同时支持MSI和MSI-X,但一次只能启用一个。
41 为什么用MSI?
44 有三个原因可以说明为什么使用MSI比传统的基于针脚的中断有优势。
47 关的中断处理程序,这导致了整个系统性能的降低。MSI从不共享,所以这个问题不会出现。
52 则要求所有的数据在返回寄存器的值之前到达内存。使用MSI可以避免这个问题,因为中断产
56 发生了什么事件,这就减慢了对常见情况的中断处理。有了MSI,设备可以支持更多的中断,
62 如何使用MSI
65 PCI设备被初始化为使用基于引脚的中断。设备驱动程序必须将设备设置为使用MSI或MSI-X。
66 并非所有的机器都能正确地支持MSI,对于这些机器,下面描述的API将简单地失败,设备将
69 加入内核对MSI的支持
72 为了支持MSI或MSI-X,内核在构建时必须启用CONFIG_PCI_MSI选项。这个选项只在某些架
76 使用MSI
80 MSI功能。
82 要自动使用MSI或MSI-X中断向量,请使用以下函数::
103 如果一个设备同时支持MSI-X和MSI功能,这个API将优先使用MSI-X,而不是MSI。MSI-X支
104 持1到2048之间的任何数量的中断。相比之下,MSI被限制为最多32个中断(而且必须是2的幂)。
105 此外,MSI中断向量必须连续分配,所以系统可能无法为MSI分配像MSI-X那样多的向量。在一
106 些平台上,MSI中断必须全部针对同一组CPU,而MSI-X中断可以全部针对不同的CPU。
108 如果一个设备既不支持MSI-X,也不支持MSI,它就会退回到一个传统的IRQ向量。
110 MSI或MSI-X中断的典型用法是分配尽可能多的向量,可能达到设备支持的极限。如果nvec大于
117 如果一个驱动程序不能或不愿意处理可变数量的MSI中断,它可以要求一个特定数量的中断,将该
124 上述请求类型的最臭名昭著的例子是为一个设备启用单一的MSI模式。它可以通过传递两个1作为
131 一些设备可能不支持使用传统的线路中断,在这种情况下,驱动程序可以指定只接受MSI或MSI-X。::
140 以下用于启用和禁用MSI或MSI-X中断的旧API不应该在新代码中使用::
148 此外,还有一些API来提供支持的MSI或MSI-X向量的数量:pci_msi_vec_count()和
151 并增加一个pci_nr_irq_vectors()助手,透明地处理MSI和MSI-X。
153 使用MSI时需要考虑的因素
160 或单一的MSI,没有必要禁用中断(Linux保证同一中断不会被重新输入)。如果一个设备
165 如何判断一个设备上是否启用了MSI/MSI-X
168 使用“lspci -v“(以root身份)可能会显示一些具有“MSI“、“Message Signalled Interrupts“
169 或“MSI-X“功能的设备。这些功能中的每一个都有一个“启用“标志,后面是“+“(启用)
173 MSI特性
176 众所周知,一些PCI芯片组或设备不支持MSI。PCI协议栈提供了三种禁用MSI的方法:
182 全局禁用MSI
185 一些主控芯片组根本无法正确支持MSI。如果我们幸运的话,制造商知道这一点,并在
186 ACPI FADT表中指明了它。在这种情况下,Linux会自动禁用MSI。有些板卡在表中没
190 如果你有一块有MSI问题的板子,你可以在内核命令行中传递pci=nomsi来禁用所有设
191 备上的MSI。你最好把问题报告给linux-pci@vger.kernel.org,包括完整的
194 禁用桥下的MSI
197 一些PCI桥接器不能在总线之间正确地路由MSI。在这种情况下,必须在桥接器后面的所
198 有设备上禁用MSI。
200 一些桥接器允许你通过改变PCI配置空间的一些位来启用MSI(特别是Hypertransport
202 多知道它们,如果可以的话,会自动启用MSI。如果你有一个Linux不知道的网桥,你可以
203 用你知道的任何方法在配置空间中启用MSI,然后通过以下方式在该网桥上启用MSI::
209 要禁用MSI,请回显0而不是1。改变这个值应该谨慎进行,因为它可能会破坏这个桥下面所
217 众所周知,有些设备的MSI实现是有问题的。通常情况下,这是在单个设备驱动程序中处理的,
218 但偶尔也有必要用一个古怪的方法来处理。一些驱动程序有一个选项可以禁用MSI的使用。虽然
221 寻找设备上MSI被禁用的原因
224 从以上三个部分,你可以看到有许多原因导致MSI没有在某个设备上被启用。你的第一步应该是
225 仔细检查你的dmesg以确定你的机器是否启用了MSI。你还应该检查你的.config以确定你已经
229 将告诉你MSI是否被启用(1)或禁用(0)。如果在任何属于PCI根和设备之间的桥的msi_bus
230 文件中发现0,说明MSI被禁用。
232 也需要检查设备驱动程序,看它是否支持MSI。例如,它可能包含对带有PCI_IRQ_MSI或
236 MSI(-X) APIs设备驱动程序列表
239 PCI/MSI子系统有一个专门的C文件,用于其导出的设备驱动程序APIs - `drivers/pci/msi/api.c` 。