BIOSとPCIパススルーを備えたLinux KVM uefi

BIOSとPCIパススルーを備えたLinux KVM uefi

Linux kvmシステムを設定しようとしています。いくつかの奇妙な問題が発生しました。少し背景。ホストはuefi h170ボードです。つまり、kvmを使用する前にホストOSをインストールするために使用する必要があるため、MSI Radeon R7 240がuefiをサポートしていることがわかります。

seabiosを使用すると、pciパススルーが正しく機能します。実際、Radeonカードにマウス、キーボード、モニターを使用して完全なWindowsインストールを実行しました。

ところが映像で同じマシンを作ってvirt-manager映像を配信すれば動作しませんね。

virt-manageruefiまたはcliを介してuefiを使用している場合、ビデオパススルーは機能しません。

私の作業文字列は次のとおりです。 (たとえ2つのネットワークカードを使用することになりましたが!?)

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

CLIバージョンでビデオROMの修正の問題を手動で指定します。 virshでは、以下のように適切なバージョンを含むROMを定義できます。

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

コマンドラインから

romfile=/path/to/your/rom/romfile.rom PCIパススルーデバイスの最後に追加

関連情報