4

我有一个可能有问题的硬件和一个可能有问题的用户空间驱动程序,它依赖于 vfio-pci 内核驱动程序。我想在不处理硬件的情况下测试驱动程序。

我想理想的解决方案是这样的:运行我的整个堆栈,除了硬件(应用程序、用户空间驱动程序、VFIO 驱动程序)并拦截 VFIO 驱动程序决定发送到硬件的所有内容。然后我可以验证硬件是否获得了正确的信息——重置发生在预期的时间,DMA 将到达正确的地址,等等。

我想我正在寻找类似模拟设备的东西,它可以让我在 vfio-pci 下运行用户空间代码,而不是运行硬件。这样的事情存在吗?

4

1 回答 1

1

使用 Qemu,模拟设备变得非常容易。我经常用它来做一些 Linux 内核研究。在 Archlinux 上,qemu-arch-extra自带了一堆机器:

$ qemu-system-arm -machine help
Supported machines are:
[..]
cubieboard           cubietech cubieboard
emcraft-sf2          SmartFusion2 SOM kit from Emcraft (M2S010)
highbank             Calxeda Highbank (ECX-1000)
imx25-pdk            ARM i.MX25 PDK board (ARM926)
integratorcp         ARM Integrator/CP (ARM926EJ-S)
kzm                  ARM KZM Emulation Baseboard (ARM1136)
lm3s6965evb          Stellaris LM3S6965EVB
lm3s811evb           Stellaris LM3S811EVB
mainstone            Mainstone II (PXA27x)
midway               Calxeda Midway (ECX-2000)
[and more...]

您的任务的一个好方法是为 Qemu 编写一个模拟的 PCI 设备,并在那里进行测试。

鉴于有很多关于使用和扩展 Qemu 的好材料,对此确实没有太多解释。一个快速的谷歌搜索显示了几个很好的资源。这个答案有一些非常有用的提示,这是一个不错的教程。

于 2018-02-04T21:34:37.763 回答