我有一个可能有问题的硬件和一个可能有缺陷的用户空间驱动程序,它依赖于vfio-pci内核驱动程序。我想在不处理硬件的情况下测试驱动程序。
我想理想的解决方案是这样的:运行除硬件(应用程序、用户空间驱动程序、VFIO 驱动程序(之外的整个堆栈,并拦截 VFIO 驱动程序决定发送到硬件的所有内容。然后我可以验证硬件是否获得了正确的信息 - 重置在预期时间发生,DMA将转到正确的地址等。
我想我正在寻找类似模拟设备的东西,它可以让我在 vfio-pci 下运行用户空间代码,而不是运行硬件。这样的事情存在吗?
使用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 的好材料。快速的谷歌搜索显示了几个很好的资源。这个答案有一些非常有用的提示,这里有一个不错的教程。