gpt4 book ai didi

自定义 linux pcie 驱动程序 MSI 中断

转载 作者:IT王子 更新时间:2023-10-29 00:44:07 30 4
gpt4 key购买 nike

我正在为嵌入式设备编写自定义 linux PCIe 驱动程序。为此,我需要启用多个 MSI vector 。当我使用函数 pci_enable_msi(pdev) 时,代码工作正常。但是,当我使用 pci_enable_msi_block(pdev,4); 时,该函数返回 1,这意味着它只能分配 1 个中断。如果我使用 pci_enable_msi_block(pdev,32); 函数返回 16,我使用 pci_enable_msi_block(pdev,16); 但返回值还是 1。

我尝试检查所有可能参数的返回值,结果如下:

for(i=2;i<33;i++)
{
ret = pci_enable_msi_block(pdev,i);
printk(KERN_DEBUG "For request i=%d the return value is=%d\n",i, ret);
}


[   89.421184] For request i=2 the return value is=1
[ 89.421196] For request i=3 the return value is=1
[ 89.421208] For request i=4 the return value is=1
[ 89.421220] For request i=5 the return value is=1
[ 89.421232] For request i=6 the return value is=1
[ 89.421243] For request i=7 the return value is=1
[ 89.421255] For request i=8 the return value is=1
[ 89.421266] For request i=9 the return value is=1
[ 89.421278] For request i=10 the return value is=1
[ 89.421290] For request i=11 the return value is=1
[ 89.421301] For request i=12 the return value is=1
[ 89.421313] For request i=13 the return value is=1
[ 89.421325] For request i=14 the return value is=1
[ 89.421336] For request i=15 the return value is=1
[ 89.421348] For request i=16 the return value is=1
[ 89.421353] For request i=17 the return value is=16
[ 89.421359] For request i=18 the return value is=16
[ 89.421364] For request i=19 the return value is=16
[ 89.421369] For request i=20 the return value is=16
[ 89.421374] For request i=21 the return value is=16
[ 89.421380] For request i=22 the return value is=16
[ 89.421385] For request i=23 the return value is=16
[ 89.421390] For request i=24 the return value is=16
[ 89.421395] For request i=25 the return value is=16
[ 89.421401] For request i=26 the return value is=16
[ 89.421406] For request i=27 the return value is=16
[ 89.421411] For request i=28 the return value is=16
[ 89.421416] For request i=29 the return value is=16
[ 89.421422] For request i=30 the return value is=16
[ 89.421427] For request i=31 the return value is=16
[ 89.421432] For request i=32 the return value is=16

只有在使用pci_enable_msi_block(pdev,1) 时函数调用才会成功(返回0)。

我也曾尝试使用 pci_enable_msi_exactpci_enable_msi_range 函数,但代码无法编译并给出隐式函数声明错误。

请提供有关如何解决此问题的建议,以便我可以使用四个 MSI vector 。

最佳答案

您需要检查您的配置寄存器以确定有多少 MSI 可以分配。 PCIe 设备决定了这一点。

您将需要探测配置寄存器。取 DWORD 的 LSB 以获得命令寄存器。这控制传统中断。取地址 0x50 的 MSB 来确定消息控制。这控制了 MSI。

确保在命令寄存器中禁用传统中断并启用总线主机。使用 0x50 (MSB) 来确定可以分配多少 MSI。位 4:6 确定这一点,位 0 启用 MSI。

我遇到了类似的问题,但事实证明我的端点只能支持单个 MSI,并且由于供应商限制我无法更改它。

关于自定义 linux pcie 驱动程序 MSI 中断,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36028374/

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