You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
vfio-guide-2/README.md

199 lines
7.3 KiB
Markdown

# Single GPU passthrough with QEMU and VFIO
<!-- AKA Passthrough VGA on first slot -->
6 years ago
6 years ago
![Windows 10 1709](/Screenshots/Windows 10 QEMU single GPU info.png)*Windows 10 1709*
6 years ago
6 years ago
## ToC
6 years ago
1. [What this does](#what-this-does)
2. [What you need](#what-you-need)
3. [My system](#my-system)
4. [Configure](#configure)
5. [About peripherals](#about-peripherals)
6. [Known problems](#known-problems)
7. [TODO](#todo)
6 years ago
## What this does
In one command it kills X, frees the GPU from drivers and console, detaches the GPU from the host, starts the VM with the GPU, waits until the VM is off, reattaches the GPU to the host and starts lightdm.
6 years ago
## What you need
* An IOMMU enabled motherboard. Check your motherboard manual.
* CPU support for AMD-v/VT-x and AMD-Vi/VT-d (AMD/Intel). And virtualization support enabled on BIOS.
* One GPU that supports UEFI and its BIOS. All GPUs from 2012 and later should support this.
* QEMU, OVMF UEFI and VIRTIO drivers for Windows.
* [Optional] HDD only for Windows
## My system
```
6 years ago
[Hardware]
CPU: AMD Ryzen 5 2600
Motherboard: Gigabyte AB350M-Gaming 3 rev1.1
Motherboard BIOS: F23d
RAM: 16GB
GPU: Gigabyte Nvidia GeForce GTX 770
GPU model: GV-N770OC-2GD
GPU BIOS: 80.04.C3.00.0F
GPU codename: GK104
[Software]
Linux Distro: ArchLinux
Linux Kernel: 4.17.11 vanilla
Nvidia divers: 396.45-2
QEMU version: 2.12.0-2
OVMF version: r24021
[Guests]
Windows: Windows 10 Pro 1709 x64
6 years ago
MacOS: MacOS High Sierra 10.13.3
```
## Configure
1. Clone this repository
```bash
git clone https://gitlab.com/YuriAlek/vfio.git
```
6 years ago
2. Enable vfio at boot. Edit `/etc/mkinitcpio.conf`.
```
MODULES=(... vfio_pci vfio vfio_iommu_type1 vfio_virqfd ...)
HOOKS=(... modconf ...)
```
6 years ago
3. [Regenerate the initramfs](https://wiki.archlinux.org/index.php/Mkinitcpio#Image_creation_and_activation)
```bash
sudo mkinitcpio -p linux
```
4. Reboot the system to load the vfio drivers
6 years ago
5. [Optional] [Download virtio drivers](https://pve.proxmox.com/wiki/Windows_VirtIO_Drivers)
```
wget -o virtio-win.iso "https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso"
```
6 years ago
6. Get the GPU BIOS [Source](https://www.youtube.com/watch?v=1IP-h9IKof0). [You can download the bios](https://www.techpowerup.com/vgabios/). If you do so, download a HEX editor and skip to step 4.
6 years ago
1. Boot the host into Windows.
6 years ago
2. [Download and install GPU-Z](https://www.techpowerup.com/gpuz/).
3. [Download and install a HEX editor](https://github.com/bwrsandman/Bless).
6 years ago
3. [Open GPU-Z and backup the GPU BIOS](/Screenshots/vBIOS.png). Right next to the `Bios Version`; in my case `80.04.C3.00.0F`, there is an icon for backup. A file named `GK104.rom` will be created [Your file name may vary].
6 years ago
4. Open the ROM (`GK104.rom`) in the HEX editor.
6 years ago
5. [After a bunch of `00` there is a `55` or `U` in HEX, delete everything before the `55`](/Screenshots/Hex vBIOS.png), and save. I strongly recommend not to overwrite the original ROM.
7. Get the iommu groups needed for the VM (GPU, GPU audio and USB controller)
```bash
chmod +x scripts/iommu.sh
bash scripts/iommu.sh
6 years ago
-------------------------
# GPU
IOMMU group 13
6 years ago
06:00.0 VGA compatible controller [0300]: NVIDIA Corporation GK104 [GeForce GTX 770] [10de:1184] (rev a1)
06:00.1 Audio device [0403]: NVIDIA Corporation GK104 HDMI Audio Controller [10de:0e0a] (rev a1)
# USB 3.0 Controller
IOMMU group 16
6 years ago
07:00.3 USB controller [0c03]: Advanced Micro Devices, Inc. [AMD] USB 3.0 Host controller [1022:145f]
# SATA Controller
IOMMU group 18
6 years ago
08:00.2 SATA controller [0106]: Advanced Micro Devices, Inc. [AMD] FCH SATA Controller [AHCI mode] [1022:7901] (rev 51)
```
6 years ago
8. [Optional] Create the image for the VM. Only if not using a physical hard drive.
```
qemu-img create -f raw windows.raw 60G
```
6 years ago
9. Edit the script `windows-install.sh` and `windows.sh` to convenience. Things you may have to edit:
1. PCI devices
2. User
6 years ago
3. Location of HDD, ISO, vBIOS and OVMF image
4. The Desktop Environment, Display Manager, Window Manager, etc.
5. QEMU options like RAM and CPU
6. Kernel modules
6 years ago
<!--
Check the guides [IOMMU][], [other guide, may be important][]
6 years ago
-->
10. Start the VM
```
sudo scripts/windows-install.sh
```
6 years ago
11. When installing Windows, in the section `Where do you want to install Windows?` there will be no hard drives to install to; to fix it:
1. Load driver
2. Browse
3. CD Drive (E:) virtio-win-0.1.1
4. vioscsi
5. w10
6. amd64
7. ok
8. Load driver `Red Hat VirtIO SCSI pass-through controller (E:\vioscsi\w10\amd64\vioscsi.inf)`
9. Next
10. Select the `Unallocated Space`
11. Proceed as normal.
6 years ago
12. Let Windows find the drivers for the GPU (if Windows has network) or [download the updated ones from NVIDIA](https://www.nvidia.com/Download/index.aspx?lang=en-us).
12. Once installed Windows, run the VM with
```
sudo scripts/windows.sh
```
6 years ago
### For the sake of convenience
6 years ago
```bash
6 years ago
sudo ln -s scripts/qemu@.service /usr/lib/systemd/system/
6 years ago
```
6 years ago
```bash
alias windows="sudo systemctl start qemu@windows.service"
alias macos="sudo systemctl start qemu@macos-hs.service"
```
To start the Windows VM
```
windows
```
To start the MacOS VM
6 years ago
```
6 years ago
macos
6 years ago
```
## About peripherals
For audio I use an USB sound card.
6 years ago
For internet I use network.sh
6 years ago
For USB I simply passthrough an USB 3.0 controller.
## Known problems
### Race condition
6 years ago
There is something somewhere that makes it crash. That's why there is so many `sleep`
### Root
QEMU should never be run as root. If you must launch it in a script as root, you should use the `-runas` option to make QEMU drop root privileges.
6 years ago
6 years ago
### MacOS does not like USB hubs, therefore anything connected to a hub will be ignored by MacOS
6 years ago
## TODO
- [x] Unbind GPU without `virsh`
6 years ago
- [x] Update macos script
6 years ago
- [ ] Network
6 years ago
- [ ] Audio
6 years ago
- [ ] IOMMU
- [ ] Troubleshooting
6 years ago
- [ ] Extract the vBIOS in Linux
6 years ago
- [ ] Try if is necessary to edit `/etc/mkinitcpio.conf`
6 years ago
- [ ] How to edit the `windows.sh` script
- [ ] Fix the race condition
- [ ] Create scripts for install and use (Without DVD images)
- [ ] Try to run the VM as user
6 years ago
- [ ] ???
6 years ago
6 years ago
<!--
And you must supply QEMU with the Full GPU's ROM extracted extracted using a tool called "nvagetbios" , which you can find in a package called "envytools"
-->
6 years ago
<!-- Links -->
[Xen Wiki]: https://wiki.xen.org/wiki/VTd_HowTo
[IOMMU Hardware]:https://en.wikipedia.org/wiki/List_of_IOMMU-supporting_hardware
[archwiki-url]: https://wiki.archlinux.org/index.php/Main_page
[qemu_archwiki]: https://wiki.archlinux.org/index.php/QEMU
[kvm-archwiki]: https://wiki.archlinux.org/index.php/KVM
[pci_passthrough-archwiki]: https://wiki.archlinux.org/index.php/PCI_passthrough_via_OVMF
[libvirt_archwiki]: https://wiki.archlinux.org/index.php/Libvirt