2022-07-21 21:10:43 +00:00
---
title: Virtual Function I/O Mediated devices (vfio-mdev)
description: Create and Configure Virtual Function I/O Mediated devices (vfio-mdev)
published: true
2023-05-14 20:10:38 +00:00
date: 2023-05-14T20:10:36.548Z
2022-07-21 21:10:43 +00:00
tags:
editor: markdown
dateCreated: 2022-07-21T21:10:41.046Z
---
2023-05-14 20:10:38 +00:00
# Configure *vfio-mdev*
2022-07-21 21:10:43 +00:00
2023-05-14 20:10:38 +00:00
> These instructions only cover **Intel GPUs** that are compatible with *vfio-mdev* (5th to 10th generation). Since generation 11th, *vfio-mdev* has been superseded by *SR-IOV*.
2022-07-28 01:25:58 +00:00
{.is-warning}
2022-07-21 21:10:43 +00:00
2022-07-28 01:25:58 +00:00
GPUs compatible with [Virtual Function I/O Mediated devices ](https://www.kernel.org/doc/html/latest/driver-api/vfio-mediated-device.html ) (vfio-mdev) can be split into multiple virtual GPUs (vGPUs).
2022-07-21 21:10:43 +00:00
2023-05-14 20:10:38 +00:00
Then, these vGPUs can be assigned to virtual machines or containers.
2023-01-29 20:12:04 +00:00
2023-05-14 20:10:38 +00:00
Contrary to paravirtualized GPUs (e.g. *virtio-gpu* ), vGPUs can use the same driver as their parent GPU (e.g. a guest compatible with an Intel GPUs will be able to leverage an Intel-based vGPUs)
2022-07-23 10:33:07 +00:00
2023-05-27 19:34:15 +00:00
## Modify the system allocated to the GPU in the BIOS/UEFI
> Some computers allow you to modify the system memory allocated or shared with the integrated GPU, which may allow you to create more vGPUs.
{.is-info}
> For Intel integrated graphics cards only; rarely available on laptops computers.
{.is-warning}
* Before the host operating system boots up, you need to enter the BIOS/UEFI and to look for a setting called *GPU aperture size* , or *GPU shared memory* .
* Use the highest possible value.
> System memory will be reserved for the GPU, so make sure you have enough system memory to accomodate both the GPU and your operating system.
{.is-warning}
2022-07-28 01:25:58 +00:00
## Preparation
2022-07-21 21:10:43 +00:00
2022-07-28 01:25:58 +00:00
* Make sure the GRUB has been updated after [the first boot ](https://wiki.phyllo.me/getstarted/disk#update-grub-and-reboot )
2022-07-21 21:10:43 +00:00
2023-05-14 20:10:38 +00:00
## Procedure
2022-07-21 21:10:43 +00:00
2023-05-14 20:10:38 +00:00
### Create a virtual GPU
2022-07-23 10:33:07 +00:00
2023-05-14 20:10:38 +00:00
List available GPUs using the `mdevctl` software:
2022-07-21 21:10:43 +00:00
```
mdevctl types
```
```
0000:00:02.0
i915-GVTg_V5_1
Available instances: 1
Device API: vfio-pci
Description: low_gm_size: 512MB, high_gm_size: 2048MB, fence: 4, resolution: 1920x1200, weight: 16
i915-GVTg_V5_2
Available instances: 2
Device API: vfio-pci
Description: low_gm_size: 256MB, high_gm_size: 1024MB, fence: 4, resolution: 1920x1200, weight: 8
i915-GVTg_V5_4
Available instances: 5
Device API: vfio-pci
Description: low_gm_size: 128MB, high_gm_size: 512MB, fence: 4, resolution: 1920x1200, weight: 4
i915-GVTg_V5_8
Available instances: 7
Device API: vfio-pci
Description: low_gm_size: 64MB, high_gm_size: 384MB, fence: 4, resolution: 1024x768, weight: 2
```
2023-05-14 20:10:38 +00:00
> Increasing the memory allocated to the GPU in the BIOS/EFI may increase the number and kind of available instances.
2022-07-28 01:25:58 +00:00
{.is-info}
2022-07-21 21:10:43 +00:00
2022-07-24 16:37:30 +00:00
In this case, the `i915-GVTg_V5_4` kind seems to offer the best trade-offs between the available resolution and the number of available instances.
2022-07-21 21:10:43 +00:00
2022-07-27 23:53:43 +00:00
* Generate a universally unique identifier (UUID) with the following command:
2022-07-21 21:10:43 +00:00
```
uuidgen
```
```
7686131b-b229-4768-a02c-35d1dbed7c66
```
2022-07-27 23:53:43 +00:00
* Start a vGPU based on the kind `i915-GVTg_V5_4` using the previously generated UUID
2022-07-21 21:10:43 +00:00
```
sudo mdevctl start -u 7686131b-b229-4768-a02c-35d1dbed7c66 -p 0000:00:02.0 --type i915-GVTg_V5_4
```
2023-05-14 20:10:38 +00:00
* Define, or make this vGPU permanent:
2022-07-21 21:10:43 +00:00
```
sudo mdevctl define -u 7686131b-b229-4768-a02c-35d1dbed7c66
```
2023-05-14 20:10:38 +00:00
* Set the vGPU to auto-start after the host boots up:
2022-07-21 21:10:43 +00:00
```
sudo mdevctl modify -u 7686131b-b229-4768-a02c-35d1dbed7c66 --auto
` ``
2022-07-27 23:53:43 +00:00
* Finally, verify that the vGPU has successfully been created and is set to auto-start:
2022-07-21 21:10:43 +00:00
```
mdevctl list -d
```
```
7686131b-b229-4768-a02c-35d1dbed7c66 0000:00:02.0 i915-GVTg_V5_4 auto (active)
```
2023-05-14 20:10:38 +00:00
### Assign a vGPU to a virtual machine
2022-07-21 21:10:43 +00:00
2023-05-14 20:10:38 +00:00
* Add that segment to a virtual machine's definition. Make sure the provided `uuid` matches the previously generated UUID.
2022-07-21 21:10:43 +00:00
```
2023-05-14 20:10:38 +00:00
< domain type = "kvm" >
2022-07-27 23:53:43 +00:00
[...]
2023-05-14 20:10:38 +00:00
< device >
2022-07-27 23:53:43 +00:00
[...]
2022-07-21 21:23:59 +00:00
< hostdev mode = "subsystem" type = "mdev" managed = "no" model = "vfio-pci" display = "on" ramfb = "on" >
2022-07-21 21:10:43 +00:00
< source >
< address uuid = "7686131b-b229-4768-a02c-35d1dbed7c66" / >
< / source >
< address type = "pci" domain = "0x0000" bus = "0x09" slot = "0x00" function = "0x0" / >
< / hostdev >
2022-07-27 23:53:43 +00:00
[...]
2023-05-14 20:10:38 +00:00
< / device >
2022-07-27 23:53:43 +00:00
[...]
< / domain >
2022-07-21 21:10:43 +00:00
```
2023-05-14 20:10:38 +00:00
> Notice that the RAMFB is set to on, which activates Drect Memory Access Buffers (DMA-BUFs), making the output of a virtual monitor available before the guest operating system takes over.
2022-07-27 23:53:43 +00:00
{.is-info}
2023-05-14 20:10:38 +00:00
## Remove any video device or display devices
2022-07-21 21:10:43 +00:00
2022-07-27 23:53:43 +00:00
* Remove any video device such as `virtio-gpu` and set the last one to the `none` .
```
2023-05-14 20:10:38 +00:00
< domain type = "kvm" >
2022-07-27 23:53:43 +00:00
[...]
2023-05-14 20:10:38 +00:00
< device >
2022-07-27 23:53:43 +00:00
[...]
< video >
< model type = "none" / >
< / video >
[...]
2023-05-14 20:10:38 +00:00
< / device >
2022-07-27 23:53:43 +00:00
[...]
< / domain >
```
* Then starts the domain
2022-07-21 21:10:43 +00:00
2023-05-14 20:10:38 +00:00
## Configure Spice / SDL
*To-do*
## Troubleshooting
### No or low number of available instances
Increasing the memory allocated to the GPU (a.k.a. the GPU aperture size) may increase the number of available instances.
Some computers allow you to modify the memory allocated or shared with the integrated GPU, which may allow you to create more vGPUs.
* Before the host operating system boots up, enter the BIOS/UEFI and look for a setting called *GPU aperture size* , or *GPU shared memory* .
* Use the highest possible value.
> The memory will be reserved to the GPU, so make sure you have enough leftover memory to accomodate both the GPU and your operating system.
{.is-info}
2022-07-21 21:10:43 +00:00
## Resources
2022-07-24 16:37:30 +00:00
* Official page for vfio-mdev: https://www.kernel.org/doc/html/latest/driver-api/vfio-mediated-device.html
2023-05-14 20:10:38 +00:00
* Archlinux's *must-read entry* on Intel GVT-g: https://wiki.archlinux.org/title/Intel_GVT-g
2022-07-27 23:53:43 +00:00
* DMA-BUF Linux documentation: https://www.kernel.org/doc/html/latest/driver-api/dma-buf.html
2023-05-27 19:34:15 +00:00
---
*[**Go to parent page**](https://wiki.phyllo.me/)*