【发布时间】:2017-03-16 16:00:35
【问题描述】:
我在 Freescale MPC8308 处理器(基于 PowerPC 架构)上使用 PCI-e 端口,但在尝试使用它时遇到了一些问题。端点 PCI-e 设备的内存空间等于 256 MB。我可以使用“pciutils”包轻松读写端点设备的配置空间。
在配置寄存器中写入正确的值并获得访问内存空间的权限后;我尝试使用 C 中的“mmap()”函数访问内存空间,并使用位于:
的文件描述符"/sys/devices/pci0000:00/0000:00:00.0/resource0"
正好是 256 MB(等于端点设备的内存空间),所以我似乎使用了正确的文件描述符路径。在这里您可以使用https://github.com/billfarrow/pcimem 中提到的“mmap()”找到我的代码:
https://github.com/billfarrow/pcimem/blob/master/pcimem.c
但不幸的是,当我尝试使用“mmap()”函数的返回地址来使用内存空间时;我无法正确读取端点设备的只读寄存器。此外,当我读取大于“0x7FFFFFC”的地址时,MPC8308 会重新启动。 考虑到上述情况,我是否错过了初始化 PCI-e 接口的任何步骤?我应该更改 Linux 内核映像或 U-Boot 代码中的任何内容吗?将 PowerPC PCI-e 与 mmap() 一起使用有什么不同吗?你有任何示例代码可以帮助我读取 PCI-e 内存空间吗?
谢谢
【问题讨论】:
-
端点的 256MB 内存空间似乎太大了。在我的处理器 (i.MX6) 上,我的端点不能大于 16MB。您在 Linux 引导 PCIe 时遇到初始化错误吗?您的 PCI-e 存储设备是什么?是 FPGA 吗?
-
是的,这对我来说似乎太多了,但我在 Linux 启动中没有任何错误,并且它为设备分配了 256 MB 的内存,正如我在 /proc/iomem 中看到的那样。端点设备不是 FPGA。它是一个带有 PCI-e 接口的 ASIC。
-
另一种方法是找到设备的基本物理地址及其限制,并映射到 /dev/mem。 (老实说,不能保证这会奏效。我很好奇它是否有效。)
标签: linux mmap pci-e memory-mapping