-=[ VFIO PASSTHROUGH ]=-
Le VFIO 1) PASSTHROUGH consiste à décharger le pilote d’un matériel – carte graphique, USB, souris… – pour l’assigner, par exemple, à une machine virtuelle.
Cette technique suppose des pré-requis. Elle nécessite du matériel plus ou moins facile à réaliser. FIXMEIndiquer où il faut le fabriquer ?
L’intérêt du passthrough est notamment de pouvoir bénéficier de l’accélération 3D d’une carte graphique sur la machine virtuelle, ou encore d’une meilleure gestion d’une souris ou d’un clavier spécifique sur cette machine virtuelle.
Pré-requis
- Avoir activé la fonction IOMMU2) du BIOS – donc au niveau du matériel. Activer le mode « 64 bits » s’il est disponible dans le BIOS.
- Avoir activé la prise en compte du IOMMU par Linux – donc au niveau du logiciel (le système d’exploitation hôte ici).
- Avoir activé la prise en charge de la virtualisation par le processeur – cela suppose que le processeur intègre un mode de virtualisation.
- Disposer de deux cartes graphiques, ou d’une paire formée d’une Apu et d’une carte graphique.
- Disposer de deux entrées vidéo sur l’écran : une pour le système Linux hôte (Host) et une pour la machine virtuelle invitée (Guest).
- Disposer des caractéristiques techniques de son matériel. En l’occurrence, connaitre la référence des deux GPU disponibles.
Obtention des informations sur le matériel
Il existe deux types d’adresse :
- l’adresse de l’emplacement du matériel sur la carte mère ;
- l’adresse VendorID:DeviceID, ou plus souvent appelée vendeur:périphérique. Celle-ci est composée de deux parties séparées par deux points « : ».
Étape 1: Vérification de la prise en charge de IOMMU / Virtualisation processeur
Prise en Charge de IOMMU
Saisissez dans un terminal la commande suivante:
dmesg | grep "AMD-Vi\|Intel VT-d"
Vous devriez obtenir
AMD-Vi: Found IOMMU at 0000:00:00.2 cap 0x40
Qui indique que le module IOMMU a bien été trouvé
AMD-Vi: Interrupt remapping enabled
L'interruption de l'assignement du matériel est activée (Enable), sans ce paramètre on ne pourra pas faire le VFIO.
Prise en Charge de la Virtualisation
Saisissez dans un terminal la commande suivante:
lscpu | grep "Virtualization"
Devrait répondre
Virtualization : AMD-V
Tous les Pré-Requis sont donc bons.
Étape 2: Obtentions des informations
- Port PCI Express 1: Carte graphique réservée au système d'exploitation Linux. (HOST)
- Port PCI Express 2: Carte graphique pour le système d'exploitation invité . (GUEST / Windows)
Lister tout, en saisissant dans un terminal la commande suivante:
lspci -nnv | grep "VGA\|Audio\|Kernel driver in use: snd_hda_intel\|Kernel driver in use: nouveau\|Kernel driver in use: nouveaufb\|Kernel driver in use: radeon"
Nvidia inclus: : Autant ne proposer que cette ligne, non?
lspci -nnv | grep "VGA\|Audio\|Kernel driver in use: snd_hda_intel\|Kernel driver in use: nouveau\|Kernel driver in use: nvidia\|Kernel driver in use: nouveaufb\|Kernel driver in use: radeon"
La Sortie HDMI à une seconde adresse VendorID:DeviceID
Slots | Type | Désignation | VendorID:DeviceID | Kernel Driver | Notes |
---|---|---|---|---|---|
00:14.2 | Audio device | AMD/ATI Intel HDA | 1002:4383 | snd_hda_intel | Carte-mère |
01:00.0 | VGA (GPU) | GTX-260 | 10de:05e2 | nouveau | Linux (HOTE) |
02:00.0 | VGA (GPU | R9-270x (Video) | 1002:6810 | radeon | VFIO (GUEST) |
02:00.1 | Audio HDMI1 | R9-270x (HDMI) | 1002:aab0 | snd_hda_intel | VFIO (GUEST) |
02:00.1 | Audio HDMI2 | R9-270x (HDMI) | 1043:aab0 | snd_hda_intel | VFIO (GUEST) |
Ici la carte graphique est branchée en HDMI et donc les signaux Vidéo / Son ont été séparés.
On ne pourra pas interdire le pilote " snd_hda_intel" car il est présent sur la carte son lié à la fois à la carte-mère et à la sortie son inclus dans le HDMI. (Sortie HDMI)
Étape 3: Activation des Modules
- Connaitre la marque de son processeur:
lscpu | grep name
- Éditer avec les droits d'administration le fichier /etc/modules pour y supprimer le module kvm_XXX qui ne correspond pas à votre processeur.
pci_stub vfio vfio_iommu_type1 vfio_pci kvm kvm_amd kvm_intel <-- effacer cette ligne par exemple si vous avez un processeur AMD
- Mettre à jour le chargement des modules:
sudo update-initramfs -u
Étape 4: Redémarrage et vérification
Après avoir redémarré votre machine, vérifiez la bonne mise en place du vfio en saisissant dans un terminal:
lspci -v | grep "VGA\|Audio\|Kernel driver in use: snd_hda_intel\|Kernel driver in use: nouveau\|Kernel driver in use: nouveaufb\|Kernel driver in use: radeon\|Kernel driver in use: vfio-pci"
Vous devriez obtenirun tableau proche de:
Slots | Type | Désignation | VendorID:DeviceID | Kernel Driver | Notes |
---|---|---|---|---|---|
00:14.2 | Audio device | AMD/ATI Intel HDA | 1002:4383 | snd_hda_intel | Carte-mère |
01:00.0 | VGA (GPU) | GTX-260 | 10de:05e2 | nouveau | Linux (HOTE) |
02:00.0 | VGA (GPU | R9-270x (Video) | 1002:6810 | vfio-pci | VFIO (GUEST) |
02:00.1 | Audio HDMI1 | R9-270x (HDMI) | 1002:aab0 | vfio-pci | VFIO (GUEST) |
02:00.1 | Audio HDMI2 | R9-270x (HDMI) | 1043:aab0 | snd_hda_intel | VFIO (GUEST) |
Ici on peut voir que le "Kernel Driver" est "vfio-pci".
Ignorer le "Kernel Modules
VFIO
Slots | Type | Désignation | VendorID:DeviceID | Kernel Driver | Notes |
---|---|---|---|---|---|
00:14.2 | Audio device | AMD/ATI Intel HDA | 1002:4383 | snd_hda_intel | Carte-mère |
01:00.0 | VGA (GPU) | GTX-260 | 10de:05e2 | nouveau | Linux (HOTE) |
02:00.0 | VGA (GPU | R9-270x (Video) | 1002:6810 | vfio-pci | VFIO (GUEST) |
02:00.1 | Audio HDMI1 | R9-270x (HDMI) | 1002:aab0 | vfio-pci | VFIO (GUEST) |
02:00.1 | Audio HDMI2 | R9-270x (HDMI) | 1043:aab0 | Encoursderedaction | VFIO (GUEST) |
FIXMEMise en forme
Exemple
options vfio-pci ids=1002:6810,1002:aab0 ,1043:aab0 #vfio-pci ids=<ADRESSE VendorID:DeviceID><Virgule><ADRESSE VendorID:DeviceID> #Aucune Guillemet #Exemple: 1002:6810 (R9-270x - GPU ) , 1002:aab0 (R9-270x - HDMI1) , 1043:aab0 (R9-270x - HDMI2) options vfio-pci ids=1002:6810,1002:aab0,1043:aab0
Exemple
DEVICES="0000:02:00.0 0000:02:00.1" #Attention au Guillemet (Début et fin de toutes les adresse) #Chaque début d'adresse commence par __**0000:**__ (Attention au : après les 0000) #Un espace entre chaque adresse (sauf la première collé à la guillemet)
FIX IOMMU
AMD
dmesg | grep AMD-Vi
[0.251399] [Firmware Bug]: AMD-Vi: IOAPIC[9] not in IVRS table <= SouthBridge Inconnus (Erreur 9) \\ [0.251403] [Firmware Bug]: AMD-Vi: IOAPIC[10] not in IVRS table <= Northbridge Inconnus (Erreur 10) \\
L'erreur 9 correspond au SMBus et l'erreur 10 au IOMMU.
lspci | grep "SMBus\|IOMMU"
Slot | Type | Désignation | Code Erreur | Base | Erreur | Slot |
---|---|---|---|---|---|---|
00:00.2 | IOMMU | Advanced Micro Devices, Inc. [AMD/ATI] RD990 I/O Memory Management Unit | 10 | ivrs_ioapic | [10]= | 00:00.2 |
00:14.0 | SMBus | Advanced Micro Devices, Inc. [AMD/ATI] SBx00 SMBus Controller (rev 42) | 9 | ivrs_ioapic | [9]= | 00:14.0 |
ivrs_ioapic[9]=00:14.0 ivrs_ioapic[10]=00:00.2
Éditer /etc/default/grub (Modifier la ligne selon votre cas) pour remplacer la ligne
GRUB_CMDLINE_LINUX_DEFAULT="quiet splash"
par
GRUB_CMDLINE_LINUX_DEFAULT="quiet splash ivrs_ioapic[9]=00:14.0 ivrs_ioapic[10]=00:00.2"
en adaptant selon le résultat obtenu précédemment
Ensuite faire un :
update-grub
Redémarrer
Intel
Vérification Finale
dmesg | grep "Found IOMMU\|remapping\|vfio"
[ 1.597597] AMD-Vi: Found IOMMU at 0000:00:00.2 cap 0x40 [ 1.597598] AMD-Vi: Interrupt remapping enabled [ 1.597712] AMD-Vi: Lazy IO/TLB flushing enabled
FIXMEManque quelques infos. En cours
Script VFIO avec Qemu (Samba & Synergy)
Fix Synergy: (Bouton Suivant / Précédent / touch alt+gr)
Éditer le fichier synergy.conf FIXMEChemin exact
- Dans la section "screens" de la machine virtuelle ajouter en bas.
altgr = alt
- Dans la section "options" de la machine virtuelle ajouter en bas.
mousebutton(6) = keystroke(WWWBack) mousebutton(7) = keystroke(WWWForward)
Contributeurs: dexter74