Configurer l'accélération matérielle pour Android Emulator

L'émulateur opère de manière optimale s'il peut utiliser le matériel de votre ordinateur, tel que le processeur, le GPU et le modem, au lieu de fonctionner comme un logiciel pur. L'utilisation du matériel sous-jacent afin d'améliorer les performances est ce que l'on appelle l'accélération matérielle.

L'émulateur exploite l'accélération matérielle pour optimiser votre expérience de deux manières :

  • L'accélération graphique pour améliorer le rendu à l'écran
  • L'accélération de la machine virtuelle (VM) pour augmenter la vitesse d'exécution

L'accélération matérielle est activée par défaut sur la plupart des ordinateurs. Si elle ne l'est pas sur le vôtre, cette page décrit comment configurer l'accélération graphique et l'accélération de la machine virtuelle (VM) afin de démultiplier les performances de l'émulateur.

Configurer l'accélération graphique

L'accélération graphique utilise le matériel de votre ordinateur (généralement le GPU) pour accélérer le rendu à l'écran. Les appareils Android ont recours à OpenGL for Embedded Systems (OpenGL ES ou GLES) pour le rendu des graphismes 2D et 3D à l'écran.

Lorsque vous créez un appareil virtuel Android (AVD) dans AVD Manager, vous pouvez spécifier si l'émulateur doit utiliser l'accélération matérielle ou logicielle pour émuler le GPU de l'AVD. L'accélération matérielle, qui est généralement plus rapide, est recommandée. Toutefois, vous devrez peut-être recourir à l'accélération logicielle si votre ordinateur utilise des pilotes graphiques non compatibles avec l'émulateur.

Par défaut, l'émulateur choisit d'utiliser l'accélération graphique matérielle ou logicielle en fonction de la configuration de votre ordinateur. Si le matériel et les pilotes de votre GPU sont compatibles, l'émulateur utilise le GPU. Dans le cas contraire, l'émulateur opte pour l'accélération logicielle (à l'aide du processeur de votre ordinateur) pour simuler le traitement GPU.

Si vous démarrez l'émulateur à partir de la ligne de commande, vous pouvez forcer le paramètre d'accélération graphique de l'AVD correspondant à cette instance d'appareil virtuel.

Conditions requises

Pour que vous puissiez utiliser l'accélération graphique, votre environnement de développement doit disposer de la configuration suivante :

  • SDK Tools : version la plus récente recommandée (version 17 au minimum)
  • SDK Platform : dernière version recommandée (Android 4.0.3, révision 3, au minimum)

Configurer l'accélération graphique dans AVD Manager

Pour configurer l'accélération graphique d'un AVD, procédez comme suit :

  1. Ouvrez AVD Manager.
  2. Créez un AVD ou modifiez-en un.
  3. Dans la fenêtre Verify Configuration (Vérifier la configuration), recherchez la section Emulated Performance (Performances émulées).
  4. Sélectionnez une valeur pour l'option Graphics (Graphismes).
  5. Cliquez sur Terminer.

Configurer l'accélération graphique à partir de la ligne de commande

Pour spécifier un type d'accélération graphique lorsque vous exécutez un AVD à partir de la ligne de commande, incluez l'option -gpu, comme illustré dans l'exemple suivant :

emulator -avd avd_name -gpu mode [{-option [value]} ... ]

La valeur de mode peut être définie sur l'une des options suivantes :

  • auto : laissez l'émulateur choisir entre l'accélération graphique matérielle ou logicielle, en fonction de la configuration de votre ordinateur.
  • host : utilisez le GPU de votre ordinateur pour l'accélération matérielle. Cette option offre généralement la meilleure qualité graphique et les meilleures performances pour l'émulateur. Toutefois, si vos pilotes graphiques rencontrent des problèmes pour afficher OpenGL, vous devrez peut-être utiliser les options swiftshader_indirect ou angle_indirect.
  • swiftshader_indirect : utilisez une variante de SwiftShader compatible avec Quick Boot pour afficher les graphiques à l'aide de l'accélération logicielle. Cette option est une bonne alternative au mode host si votre ordinateur ne peut pas utiliser l'accélération matérielle.
  • angle_indirect : (Windows uniquement) utilisez une variante d'ANGLE Direct3D compatible avec Quick Boot pour afficher les graphiques à l'aide de l'accélération logicielle. Cette option est une bonne alternative au mode host si votre ordinateur ne peut pas utiliser l'accélération matérielle. Dans la plupart des cas, les performances d'ANGLE sont semblables à celles du mode host grâce à l'utilisation de Microsoft DirectX au lieu d'OpenGL.

    Sous Windows, les pilotes Microsoft DirectX présentent généralement moins de problèmes que les pilotes OpenGL. Cette option utilise Direct3D 11 et requiert Windows 10, Windows 8.1 ou Windows 7 SP1 avec la mise à jour de la plate-forme Windows 7.

  • guest : utilisez le rendu logiciel côté client. Cette option offre la qualité graphique et les performances les plus faibles pour l'émulateur.

Les options mode suivantes sont obsolètes :

  • swiftshader : obsolète depuis la version 27.0.2. Utilisez plutôt swiftshader_indirect.
  • angle : obsolète depuis la version 27.0.2. Utilisez plutôt angle_indirect (Windows uniquement).
  • mesa : obsolète depuis la version 25.3. Utilisez plutôt swiftshader_indirect.

Activer le rendu Skia pour l'interface utilisateur Android

Lorsque vous utilisez des images pour le niveau d'API 27 ou supérieur, l'émulateur peut afficher l'UI Android avec Skia. Skia aide l'émulateur à afficher les graphiques de manière plus fluide et plus efficace.

Pour activer le rendu Skia, utilisez les commandes suivantes dans le shell adb :

su
setprop debug.hwui.renderer skiagl
stop
start

Configurer l'accélération de la VM

L'accélération de la VM exploite le processeur de votre ordinateur pour améliorer considérablement la vitesse d'exécution de l'émulateur. Un outil appelé hyperviseur gère cette interaction à l'aide d'extensions de virtualisation fournies par ce processeur. Cette section décrit les exigences à respecter pour utiliser l'accélération de VM et explique comment configurer l'accélération de VM sur chaque système d'exploitation.

Exigences générales

Pour utiliser l'accélération de la VM avec l'émulateur, votre ordinateur doit respecter les exigences générales décrites dans cette section. Votre ordinateur doit également répondre à d'autres conditions spécifiques à votre système d'exploitation.

Exigences concernant l'environnement de développement

Pour que vous puissiez utiliser l'accélération de la VM, votre environnement de développement doit disposer de la configuration suivante :

  • SDK Tools : version 17 au minimum ; version 26.1.1 ou ultérieure recommandée
  • AVD : la version d'Android requise est décrite dans le tableau suivant.

    Architecture de processeur Exigences relatives aux images système
    X86_64 Images système x86 ou x86_64 pour Android 2.3.3 (niveau d'API 10) ou version ultérieure
    ARM64 Images système arm64-v8a pour Android 5.0 (niveau d'API 21) ou version ultérieure

Exigences concernant les extensions de virtualisation

En plus des exigences liées à l'environnement de développement, le processeur de votre ordinateur doit être compatible avec les extensions de virtualisation. Les processeurs pris en charge sont les suivants :

  • Processeurs Intel dotés de la technologie Intel Virtualization Technology (VT-x, vmx), par exemple Processeurs Intel Core iX et Intel Core Ultra
  • Processeurs AMD avec AMD-V (SVM), tels que les processeurs AMD Ryzen
  • Puce Apple

Exigences supplémentaires liées aux processeurs Intel et AMD :

La traduction d'adresse de deuxième niveau (Intel EPT ou AMD RVI) est requise pour les processeurs Intel et AMD. La plupart des processeurs Intel et AMD modernes prennent en charge la traduction d'adresse de deuxième niveau. Seuls les processeurs Intel ou AMD de première génération proposant des extensions de virtualisation n'offrent pas toujours une traduction de page de deuxième niveau.

Si vous avez un doute sur la compatibilité de votre processeur avec les extensions requises, consultez les caractéristiques spécifiques au processeur sur le site du fabricant. S'il n'est pas compatible avec ces extensions, vous ne pouvez pas utiliser l'accélération de la VM.

Restrictions

L'accélération de la VM présente les restrictions suivantes :

  • Vous ne pouvez pas exécuter un émulateur accéléré par une VM dans une autre VM, telle qu'une VM hébergée par VirtualBox, VMWare ou Docker. Un émulateur accéléré par VM doit être exécuté directement sur l'ordinateur hôte.
  • Selon votre système d'exploitation et votre hyperviseur, vous ne pouvez pas toujours exécuter de logiciel qui utilise une autre technologie de virtualisation en même temps que l'émulateur accéléré par une VM. Ces logiciels incluent, entre autres, des solutions de machine virtuelle, certains programmes antivirus et quelques solutions anti-triche. Cette situation est principalement observée sous Windows lorsque Hyper-V est désactivé. La plupart de ces logiciels peuvent coexister avec Android Emulator sans problème. Cependant, en cas de conflits, nous vous recommandons de ne pas exécuter l'émulateur accéléré par VM avec ces logiciels.

À propos des hyperviseurs

L'accélération de la VM nécessite un hyperviseur. Il s'agit d'un outil qui utilise les extensions de virtualisation fournies par le processeur de votre ordinateur.

En l'absence d'hyperviseur et d'accélération de la VM, l'émulateur doit convertir le code machine du bloc de la VM, bloc par bloc, pour se conformer à l'architecture de l'ordinateur hôte. Ce processus peut être lent. Avec un hyperviseur, lorsque la VM et l'architecture de l'ordinateur hôte correspondent, l'émulateur peut exécuter le code directement sur le processeur hôte à l'aide de l'hyperviseur. Cette amélioration augmente considérablement la vitesse et les performances de l'émulateur.

L'hyperviseur qui vous convient le mieux dépend du système d'exploitation et de la configuration de votre ordinateur. Pour en savoir plus, consultez l'une des sections suivantes :

Vérifier si un hyperviseur est installé

L'option de ligne de commande -accel-check de l'émulateur vous permet de vérifier si un hyperviseur est installé sur votre ordinateur.

Les exemples suivants montrent comment utiliser l'option accel-check de l'émulateur. Dans chaque exemple, Sdk correspond à l'emplacement du SDK Android :

Windows :

c:\Users\janedoe\AppData\Local\Android> Sdk\emulator\emulator -accel-check
accel:
0
AEHD (version 2.2) is installed and usable.
accel
Il existe plusieurs choix d'hyperviseur sous Windows. Ce que vous voyez peut donc différer de l'exemple présenté ici. Par exemple, vous pouvez voir l'un des les mots clés suivants dans le message: GVM(ancien nom d'AEHD), WHPX.

macOS :

janedoe-macbookpro:Android janedoe$ ./Sdk/emulator/emulator -accel-check
accel:
0
Hypervisor.Framework OS X Version 13.2
accel

Linux :

janedoe:~/Android$ ./Sdk/emulator/emulator -accel-check
accel:
0
KVM (version 12) is installed and usable.

Configurer l'accélération de la VM sous Windows

L'accélération de la VM sous Windows peut utiliser l'un des deux hyperviseurs suivants:

  • Windows Hypervisor Platform (WHPX)
  • Android Emulator Hypervisor Driver (AEHD)

Choisir un hyperviseur sous Windows

Cette section indique les critères permettant de déterminer quel hyperviseur utiliser. Les sections suivantes décrivent le processus permettant de configurer l'accélération de VM à l'aide de chaque hyperviseur.

Critères Hyperviseur
Vous devez exécuter Hyper-V en même temps qu'Android Emulator. Utilisez WHPX.
Vous n'avez pas besoin d'exécuter Hyper-V en même temps qu'Android Emulator. Utilisez Android Emulator Hypervisor Driver.

Configurer l'accélération de la VM à l'aide de Windows Hypervisor Platform

Pour que vous puissiez activer WHPX, votre ordinateur doit disposer de la configuration suivante :

  • Processeurs Intel : prise en charge de la technologie de virtualisation (VT-x), d'EPT (Extended Page Tables) et des fonctionnalités d'invité sans restriction (UG). VT-x doit être activé dans les paramètres BIOS de votre ordinateur.
  • Processeurs AMD : utilisation recommandée d'un processeur AMD Ryzen. La virtualisation ou la technologie SVM doit être activée dans les paramètres BIOS de votre ordinateur.
  • Android Studio 3.2 bêta 1 ou version ultérieure
  • Android Emulator 27.3.8 ou version ultérieure
  • Windows 10 ou version ultérieure

Pour installer WHPX sous Windows, procédez comme suit :

  1. Sur le bureau Windows, effectuez un clic droit sur l'icône Windows et sélectionnez Applications et fonctionnalités.
  2. Sous Paramètres associés, cliquez sur Programmes et fonctionnalités.
  3. Cliquez sur Turn Windows Features on or off (Activer ou désactiver des fonctionnalités Windows).
  4. Sélectionnez Windows Hypervisor Platform.

  5. Cliquez sur OK.

  6. Une fois l'installation terminée, redémarrez votre ordinateur.

Configurer l'accélération de la VM à l'aide d'Android Emulator Hypervisor Driver (AEHD) sous Windows

Pour que vous puissiez installer et utiliser Android Emulator Hypervisor Driver pour les processeurs AMD, votre ordinateur doit disposer de la configuration suivante :

  • Processeurs Intel ou AMD avec extension de virtualisation
  • Windows 11 ou Windows 10 64 bits (la version Windows 32 bits compatibles)

    Les utilisateurs de Windows 8.1, Windows 8 et Windows 7 peuvent continuer à utiliser AEHD 1.7 ou inférieure. Cependant, aucune assistance ne sera fournie pour ces scénarios.

  • Hyper-V doit être désactivé dans la boîte de dialogue "Windows Features" (Fonctionnalités Windows).

    Certains composants de fenêtre peuvent activer l'hyperviseur Hyper-V en activant Hyper-V dans la boîte de dialogue "Fonctionnalités Windows", par exemple Isolation de cœur proposé par Windows Defender. Dans ce cas, utilisez WHPX. à la place.

Sur les processeurs AMD, Android Emulator Hypervisor Driver peut être installé via SDK Manager dans Android Studio 4.0 Canary 5 ou version ultérieure.

Sur les processeurs Intel, Android Emulator Hypervisor Driver permet d'installer le pilote via SDK Manager dans Android Studio Flamingo ou version ultérieure.

Pour effectuer l'installation à partir de SDK Manager, procédez comme suit :

  1. Sélectionnez Tools > SDK Manager (Outils > SDK Manager).
  2. Cliquez sur l'onglet SDK Tools, puis sélectionnez Android Emulator Hypervisor Driver.
  3. Cliquez sur OK pour télécharger et installer Android Emulator Hypervisor Driver.
  4. Après l'installation, vérifiez que le pilote fonctionne correctement en exécutant la commande suivante :

    AEHD 2.1 ou version ultérieure

    sc query aehd
    

    Un message d'état inclut les informations suivantes :

    SERVICE_NAME: aehd
           ...
           STATE              : 4  RUNNING
           ...
    

    Le message d'erreur suivant signifie que l'extension de virtualisation n'est pas activée dans le BIOS ou que la fonctionnalité Hyper-V n'est pas désactivée :

    SERVICE_NAME: aehd
           ...
           STATE              : 1  STOPPED
           WIN32_EXIT_CODE    : 4294967201 (0xffffffa1)
           ...
    

    AEHD 2.0 ou version antérieure

    sc query gvm
    

    Un message d'état inclut les informations suivantes :

    SERVICE_NAME: gvm
           ...
           STATE              : 4  RUNNING
           ...
    

    Le message d'erreur suivant signifie que l'extension de virtualisation n'est pas activée dans le BIOS ou que la fonctionnalité Hyper-V n'est pas désactivée :

    SERVICE_NAME: gvm
           ...
           STATE              : 1  STOPPED
           WIN32_EXIT_CODE    : 4294967201 (0xffffffa1)
           ...
    

Vous pouvez également télécharger et installer Android Emulator Hypervisor Driver à partir de GitHub. Après avoir décompressé le package du pilote, exécutez silent_install.bat sur une ligne de commande avec des droits d'administrateur.

Pour désinstaller Android Emulator Hypervisor Driver, exécutez les commandes suivantes sur une ligne de commande lorsque vous disposez des droits d'administrateur :

AEHD 2.1 ou version ultérieure

   sc stop aehd
   sc delete aehd

AEHD 2.0 ou version antérieure

   sc stop gvm
   sc delete gvm

Configurer l'accélération de la VM sous macOS

Sous macOS, Android Emulator utilise l'API Hypervisor.Framework qui nécessite macOS v10.10 (Yosemite) ou version ultérieure. Cependant, Android Studio peut nécessiter une version supérieure pour macOS. Dans ce cas, suivez les instructions Configuration système requise pour Studio.

Configurer l'accélération de la VM sous Linux

Les systèmes Linux permettent l'accélération de la VM via le package logiciel KVM. Suivez les instructions d'installation de KVM sur un système Linux, puis vérifiez que KVM est activé. Pour les systèmes Ubuntu, découvrez comment installer le package KVM Ubuntu.

Conditions requises

L'exécution de KVM nécessite des autorisations utilisateur spécifiques. Assurez-vous de disposer des autorisations suffisantes, comme spécifié dans les instructions d'installation de KVM.

Pour que vous puissiez utiliser l'accélération de la VM sur Linux, votre ordinateur doit disposer de la configuration suivante :

  • Pour les processeurs Intel : technologie de virtualisation (VT-x), fonctionnalités Intel EM64T (Intel 64) et fonctionnalité Execute Disable (XD) Bit activées
  • Pour les processeurs AMD : prise en charge d'AMD Virtualization (AMD-V)

Vérifier si KVM est actuellement installé sous Linux

Vous pouvez vérifier si KVM est installé à l'aide de l'option de ligne de commande -accel-check de l'émulateur. Vous pouvez également installer le package cpu-checker contenant la commande kvm-ok.

L'exemple suivant montre comment utiliser la commande kvm-ok :

  1. Installez le package cpu-checker :

    sudo apt-get install cpu-checker
    egrep -c '(vmx|svm)' /proc/cpuinfo
    

    Un résultat supérieur ou égal à 1 signifie que la virtualisation est prise en charge. Un résultat égal à zéro signifie que votre processeur n'est pas compatible avec la virtualisation matérielle.

  2. Exécutez la commande kvm-ok :

    sudo kvm-ok
    

    Sortie attendue :

    INFO: /dev/kvm exists
    KVM acceleration can be used
    

    Si vous obtenez l'erreur suivante, vous pouvez toujours exécuter des machines virtuelles. Cependant, votre machine virtuelle sera plus lente sans les extensions KVM.

    INFO: Your CPU does not support KVM extensions
    KVM acceleration can NOT be used
    

Installer KVM sous Linux

Exécutez la commande suivante pour installer KVM :

Cosmic (18.10) ou version ultérieure :

sudo apt-get install qemu-kvm libvirt-daemon-system libvirt-clients bridge-utils

Lucid (10.04) ou version ultérieure :

sudo apt-get install qemu-kvm libvirt-bin ubuntu-vm-builder bridge-utils

Karmic (9.10) ou version antérieure :

sudo aptitude install kvm libvirt-bin ubuntu-vm-builder bridge-utils

Guide de désinstallation d'Intel HAXM

À partir de l'émulateur 33.x.x.x, HAXM est obsolète, car Intel cesse le développement de HAXM. Android Emulator Hypervisor Driver (AEHD) remplace Intel HAXM sur les processeurs Intel.

Il est recommandé de supprimer complètement Intel HAXM de votre système Windows, sauf si vous avez installé un autre logiciel qui dépend de HAXM et que vous choisissez pour conserver Intel HAXM et le gérer par vous-même.

Pour désinstaller Intel HAXM, procédez comme suit:

Vérifier si Intel HAXM est installé

Pour déterminer si Intel HAXM est installé sur votre système Windows, ouvrez un Windows et exécutez la commande suivante:

   sc query intelhaxm

Si Intel HAXM est installé et en cours d'exécution, le message suivant doit s'afficher dans le résultat de la commande.

Si Intel HAXM est installé, mais désactivé, le message suivant doit s'afficher dans le résultat de la commande.

Dans les deux cas, qu'Intel HAXM soit en cours d'exécution ou désactivé, il est installés. Vous devez passer à l'étape suivante pour continuer à désinstaller Intel HAXM.

Si Intel HAXM n'est pas installé, le message suivant doit s'afficher.

Désinstaller Intel HAXM à l'aide de SDK Manager depuis Android Studio

Ouvrez SDK Manager à partir d'Android Studio, puis accédez à SDK Tools. , puis accédez à "Intel x86 Emulator Accelerator (HAXM programme d'installation) - Obsolète". . Le résultat devrait ressembler à la capture d'écran suivante.

Décochez la case comme illustré dans la capture d'écran suivante.

Cliquez sur "Appliquer". et la boîte de dialogue suivante devrait s'afficher.

Une fois qu'Intel HAXM a bien été désinstallé, le résultat suivant doit s'afficher. La désinstallation est terminée. Vous pouvez arrêter ici.

En cas d'erreur, passez à l'étape suivante.

Désinstallez Intel HAXM à l'aide des paramètres de Windows.

Ouvrir les paramètres de Windows et accédez à Applications > Applications installées".

Recherchez "Intel Hardware Accelerated Execution Manager". puis cliquez sur "Désinstaller", comme illustré dans la capture d'écran suivante.

Le programme de désinstallation d'Intel HAXM devrait s'exécuter et signaler le résultat. Si le la désinstallation réussie, consultez Supprimer le package d'installation Intel HAXM. Sinon, passez à l'étape suivante.

Désinstaller à l'aide de la ligne de commande

.
  1. Arrêtez le service Intel HAXM en exécutant "sc stop intelhaxm". Vous devriez voir le résultat suivant.

  2. Supprimez le service Intel HAXM en exécutant "sc delete intelhaxm". Vous devriez voir la sortie suivante.

  3. Consultez Supprimer le package d'installation Intel HAXM.

Supprimez le package d'installation d'Intel HAXM.

Cette étape n'est requise que lorsque vous désinstallez Intel HAXM à l'aide des "paramètres" de Windows. ou de ligne de commande. Sans cette étape, le SDK Manager d'Android Studio risque continuer à indiquer qu'Intel HAXM est "installé".

Le package du programme d’installation se trouve sous <Dossier de votre SDK Android>\extras\intel. Par défaut, le SDK Android sera installé dans "C:\Users\<Your Windows User ID" >\AppData\Local\Android\Sdk". Consultez l'exemple dans la capture d'écran suivante.