测试使用 VFIO 的用户空间驱动程序



我有一个可能有问题的硬件和一个可能有缺陷的用户空间驱动程序,它依赖于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 的好材料。快速的谷歌搜索显示了几个很好的资源。这个答案有一些非常有用的提示,这里有一个不错的教程。

相关内容

  • 没有找到相关文章

最新更新