加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

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

发布时间:2020-12-13 23:19:55 所属栏目:Linux 来源:网络整理
导读:我正在为嵌入式设备编写自定义 Linux PCIe驱动程序.为此,我需要启用多个MSI向量.当我使用函数pci_enable_msi(pdev)时,代码正常工作.但是当我使用pci_enable_msi_block(pdev,4)时;该函数返回1表示它只能分配1个中断.如果我使用pci_enable_msi_block(pdev,32);
我正在为嵌入式设备编写自定义 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=%dn",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_exact和pci_enable_msi_range函数,但代码不编译并给出隐式函数声明错误.

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

解决方法

您需要检查配置寄存器以确定可分配的MSI数量. PCIe设备确定这一点.

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读