Linux KVM uefi 与 BIOS 和 PCI 直通

Linux KVM uefi 与 BIOS 和 PCI 直通

我正在尝试设置 Linux kvm 机器。我遇到了一些奇怪的问题。一点背景。主机是 uefi h170 板,也就是说,我知道 MSI Radeon R7 240 支持 uefi,因为在使用 kvm 之前我必须使用它安装主机操作系统。

如果我使用seabios,pci passthrough 工作正常。实际上,我通过 radeon 卡上的鼠标、键盘和显示器进行了完整的 Windows 安装。

但是,如果我用视频构建同一台机器virt-manager并传递视频,则它不起作用。

如果我通过 uefivirt-manager或 cli 使用 uefi,视频直通不起作用。

这是我的工作字符串(尽管我最终得到了两个网卡!?)

qemu-system-x86_64 -enable-kvm -M q35 -m 3072 -cpu host \
-smp 2,sockets=1,cores=2,threads=1 \
-bios /usr/share/qemu/bios.bin -vga none \
-device virtio-scsi-pci,id=scsi \
-drive file=/srv/wip.img,format=raw,id=disk,if=none,cache=directsync,aio=native \
-device scsi-hd,drive=disk \
-cdrom /home/driz/win10.iso \
-device ioh3420,bus=pcie.0,addr=1c.0,multifunction=on,port=1,chassis=1,id=root.1 \
-device vfio-pci,host=01:00.0,bus=root.1,addr=00.0,multifunction=on,x-vga=on \
-device virtio-net-pci,mac=52:54:00:ea:c8:8d \
-usb -usbdevice host:040b:2000 -usbdevice host:046d:c01e -usbdevice host:0d8c:0014 \
-boot menu=on

这是一个不起作用的测试字符串

qemu-system-x86_64 -enable-kvm -M q35 -m 3072 -cpu host \
-smp 2,sockets=1,cores=2,threads=1 \
-mem-path /dev/hugepages \
-mem-prealloc \
-drive file=/srv/ovmf-x64/OVMF_CODE-pure-efi.fd,if=pflash,format=raw,unit=0,readonly=on \
-drive file=/srv/ovmf-x64/OVMF_VARS-pure-efi.fd,if=pflash,format=raw,unit=1 \
-device i82801b11-bridge,id=pci.1,bus=pcie.0,addr=0x1e \
-device pci-bridge,chassis_nr=2,id=pci.2,bus=pci.1,addr=0x0 \
-device virtio-scsi-pci,id=scsi0,bus=pci.2,addr=0x2 \
-drive file=/srv/wip2.img,format=raw,if=none,id=drive-scsi0-0-0-0 \
-device scsi-hd,bus=scsi0.0,channel=0,scsi-id=0,lun=0,drive=drive-scsi0-0-0-0,id=scsi0-0-0-0 \
-cdrom /srv/win10.iso \
-device virtio-net-pci,mac=52:54:00:ea:c8:8d \
-device vfio-pci,host=01:00.0,multifunction=on \
-nographic \
-usb -usbdevice host:040b:2000 -usbdevice host:046d:c01e -usbdevice host:0d8c:0014 \
-device virtio-balloon-pci,id=balloon0,bus=pci.2,addr=0x4 \
-boot menu=on

我现在已经花了大约 4 天的时间来处理这个问题,并尽我所能进行研究,我的孩子们终于对延误感到不安。任何帮助表示赞赏!

答案1

手动指定视频 ROM 纠正了 CLI 版本上的问题。在 virsh 中,您可以定义 rom(使用适当的版本),如下所示

   <hostdev>
     ...
     <rom file='/etc/fake/boot.bin'/>
     ...
   </hostdev>

在命令行上

添加romfile=/path/to/your/rom/romfile.rom 到 PCI 直通设备的末尾

相关内容