13

我正在寻找可以从驱动程序、用户空间实用程序或系统调用中进行的内核模式调用,该调用将要求内核查看 PCI 总线并完全重新运行其初始化,或初始化特定的设备。具体来说,我需要 Kernel 识别一个在启动后添加到总线上的设备,然后配置它的地址空间、中断和其他配置参数,最后启用该设备,以便我可以为它加载驱动程序(除非这一切作为驱动程序负载的一部分发生)。

为此,我被困在 2.4.x 系列内核上,目前正在使用 2.4.20,但如果重要,将移至 2.4.37。该发行版是在 ram 磁盘中运行的精简版 Red Hat 7.3,但我可以添加任何需要的工具来使其正常工作(只要它们与 2.4 系列配合得很好)。

如果一些背景有助于澄清我正在尝试做的事情:从冷启动,一旦在 Linux 中,我使用 GPIO 对 FPGA 进行编程。FPGA 的一部分一旦被编程,就实现了一个简单的 PCI 设备。目前,在对 FPGA 进行编程后,我重新启动系统,Linux 会在启动后识别设备并为其加载驱动程序。

而不是需要重新启动,我想简单地要求内核在启动期间执行任何操作以查找 PCI 设备(我将内核配置为自行查找 PCI 设备,而不是向 BIOS 询问该信息,所以 BIOS 不需要知道这个设备(我希望))。

我相信 Linux 能够在编程后但在重新启动之前看到设备,因为scanpci在我编程后会显示设备,就像lspci -H 1. 我只需要一种方法让它进入/proc/pci、配置和启用。

4

4 回答 4

4

下面的命令将帮助用户重新扫描它完整的根集线器。

echo "1" > /sys/class/pci_bus/0000\:00/rescan
于 2017-04-04T17:19:30.780 回答
3

如果您不知道如何重做 PCI 扫描,您可以使用 kexec 加速重新启动。如果你还没有,你可以在 LKML 上问这个。

卸载/重新加载模块没有帮助,是吗?

于 2009-12-05T19:40:09.867 回答
2

http://www.linuxjournal.com/article/5633建议您应该能够使用pcihpfs.

如果这不起作用,也许驱动程序不支持热插拔?

于 2009-12-01T17:29:39.853 回答
1

如果您在使用其他 PCI 设备时重新配置它们的地址,可能会导致系统崩溃。

更好的方法是只配置新卡。如果你的内核支持 Cardus 设备,它已经知道如何配置新插入的 PCI 设备(这就是 Cardbus)。你只需要弄清楚如何让内核去做......

内核模块应该可以做到这一点。即使您无法获得内置的热插拔代码,您也应该能够通过调用pci_bus_write_config_dword()和朋友来设置 pci 资源。可能还有一些 IRQ 路由设置要做。

于 2009-12-10T15:02:24.773 回答