定制linux pcie驱动程序MSI中断

我正在为embedded式设备写一个自定义的linux PCIe驱动程序。 为此我需要启用多个MSI向量。 当我使用函数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函数,但是这些代码不能编译,并给出了隐式的函数声明错误。

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

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

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

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

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