- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在为嵌入式设备编写自定义 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_exact
和 pci_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/
我正在编写一个支持多种设备的 Linux 设备驱动程序。我有一个 x8 PCIe 卡,上面有 4 个这样的设备。每个都通过一个 PCIe 交换机运行并获得 2 个 PCIe channel 。有没有办
有谁知道放在 PCIe 卡上的 COM,它有一些闪存、一些 RAM、JTAG 支持(或某种调试支持)、一些输入端口,如 USB,也许支持一些输出,如通过 VGA 或 LVDS,只是像这个板子:http
我是 PCIe 的新手,所以这可能是个愚蠢的问题。这似乎是询问有关 PCIe 接口(interface)的相当基本的信息,但我找不到答案,所以我猜我遗漏了一些使答案显而易见的信息。 我有一个系统,其中
为了实现NVMe SSD和其他PCIe设备之间的p2p通信,我想知道是否需要对Linux内核和NVMe驱动程序进行一些修改,或者其他什么?我应该做哪些修改?我已经搜索了几天,但是这方面的信息很少,我需
我一直在阅读令人恐惧的 PCIe 规范,但仍然无法对以下问题得到任何解决方案。 PCIe 是否允许将巨大(例如 16GB)64 位不可预取内存空间映射到 4GB 边界以上?或者它们仍然与 32 位时代
两个独立的设备(端点)可以在没有根复合体参与 PCIe 的情况下相互通信(根据 PCIe 规范是的,但是如何)? 在内存和 IO 事务的情况下,一个端点如何知道另一个端点的地址? 交换机如何在两个下游
对于另一个问题,我使用了与附件相同的情节。可以看到峰值带宽超过5.5GB/s。我正在使用来自代码示例的 NVidia 带宽测试程序来查找主机到设备之间的带宽,反之亦然。 该系统由两个插槽上的 12 个
过去几天开始,我尝试开发主机和端点之间的数据传输,但我无法实现该实现。我尝试了如何使用一些调用读取配置空间(pci_read_long),已成功读取vendor_id、device_id...等数据。
我正在 Linux 中为在 Xilinx UltrascaleMPSoC FPGA 部分上实现的 PCIe 端点编写一个设备驱动程序。我已经正确实现了删除功能。我使用适配器将设备连接到电脑,打开设备,
我正在为 openwrt 开发一个 PCIE 设备驱动程序,在尝试访问定时器中断中的 io 内存时遇到了数据总线错误,我在 last question 中提到过.经过大量研究,我想我可能找到了原因,但
我正在尝试使用流式 DMA 映射将 DMA 添加到我的 PCIe Linux 驱动程序。 FPGA(端点)为 DMA 配置了 BAR4,在我的设置函数中我做了(按顺序): pci_set_master
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我在这里发现了一些关于它的话题,但没有一个能解释我遇到的问题。我只是想通过将其映射到 Linux 中的用户内存空间来访问 PCIe 设备的内部状态寄存器。这是我的系统配置: # uname -a Li
例如,当我使用带有 CUDA C/C++ 和 GPUDirect 2.0 P2P 的多 GPU 系统时,我使用嵌套的 PCI-Express 开关,如图所示,那么我必须知道任意两个 GPU 之间有多少
我正在开发一个在启动时将大量数据推送到显卡的流媒体应用程序。在推送数据时,CPU 几乎没有做任何事情,它以接近零的使用率闲置。 我想监控哪些机器在推送初始数据时遇到困难,哪些机器可以应付,以便我可以为
我写了一个简单的 PCIe 驱动程序,我想测试它是否有效。例如,如果也可以写入和读取从设备使用的内存。 我该怎么做? 哪些东西也应该被证明? 最佳答案 例如,您需要找到设备的 sysfs 条目 /sy
我在我的 intel i7 PC 上使用 intel i210 1G NIC 卡,我想知道这个 NIC 如何与主机通信而无需开箱即用的任何配置。 什么 NIC 作为 PCIe 设备输出到主机,主机 p
我希望能够将视频从连接到我的计算机的摄像头直接流式传输到我通过 PCIE 连接到我的计算机的 FPGA。 我不介意使用 javascript 或 C# 等高级语言来执行此操作(因为这些是我知道的具有视
我已经编写了一个 PCIe 设备驱动程序,但读/写功能无法正常工作。该设备有 3 个内存区域,分别从 0x10800000、0x0c000000 和 0x80000000 开始。仅出于测试目的,我在驱
我正在为 Linux 编写一个 PCIe 驱动程序,目前没有 DMA,并且需要知道一旦从用户空间启用它后如何读取和写入 PCIe 设备。 在驱动程序中,我在 probe() 中执行基础操作: pci_
我是一名优秀的程序员,十分优秀!