Mac e “PANIC: Programa de mecanismo de emulador ausente para a CPU 'arm'”.
Estou tentando executar um AVD que criei para a API 16 em um Galaxy Nexus:
emulator @Galaxy_Nexus_Jelly_Bean_API_16
o que dá o erro
PÂNICO: Falta o programa do mecanismo do emulador para a CPU 'arm'.
Tentativa de iniciá-lo pressionando o botão play do AVD Manager dentro do Android Studio salta algo brevemente na estação de ferramentas, mas desaparece rapidamente e nada aparece e não há mensagens de erro óbvias.
Eu olhei através de outros posts com problemas semelhantes. A maioria cita o Avast no Windows como causador do problema. Estou executando em um Mac. Eu não tenho o Avast instalado.
O AVD tem a seguinte configuração:
Name: Galaxy_Nexus_Jelly_Bean_API_16
CPU/ABI: Google APIs ARM (armeabi-v7a)
Path: /Users/prisoner/.android/avd/Galaxy_Nexus_API_16.avd
Target: google_apis [Google APIs] (API level 16)
Skin: galaxy_nexus
SD Card: 100 MB
hw.dPad: no
hw.lcd.height: 1280
runtime.network.speed: full
hw.accelerometer: yes
hw.device.name: Galaxy Nexus
vm.heapSize: 80
skin.dynamic: yes
hw.device.manufacturer: Google
hw.lcd.width: 720
hw.gps: yes
hw.initialOrientation: Portrait
image.androidVersion.api: 16
hw.audioInput: yes
image.sysdir.1: add-ons/addon-google_apis-google-16/images/armeabi-v7a/
hw.cpu.model: cortex-a8
tag.id: google_apis
showDeviceFrame: yes
hw.camera.back: virtualscene
hw.mainKeys: no
AvdId: Galaxy_Nexus_Jelly_Bean_API_16
hw.camera.front: emulated
hw.lcd.density: 320
avd.ini.displayname: Galaxy Nexus Jelly Bean API 16
hw.arc: false
hw.gpu.mode: auto
hw.device.hash2: MD5:5c288d27461585ecc73a535555e7cf61
hw.ramSize: 1024
hw.trackBall: no
PlayStore.enabled: false
fastboot.forceColdBoot: no
hw.battery: yes
hw.cpu.ncore: 4
hw.sdCard: no
tag.display: Google APIs
runtime.network.latency: none
hw.keyboard: yes
hw.sensors.proximity: yes
disk.dataPartition.size: 800M
hw.sensors.orientation: yes
avd.ini.encoding: UTF-8
hw.gpu.enabled: yes
Ambiente do Android Studio:
Android Studio 3.1.4
Build #AI-173.4907809, built on July 23, 2018
JRE: 1.8.0_152-release-1024-b01 x86_64
JVM: OpenJDK 64-Bit Server VM by JetBrains s.r.o
Mac OS X 10.12.6
Instalei tudo para esta versão do SDK disponível no SDK Manager:
Eu tenho a versão mais recente do emulador instalada. Eu tentei desinstalar e reinstalar.
oANDROID_HOME
variável de ambiente parece estar definida corretamente (corresponde aoAndroid SDK location
no Gerenciador de SDK. oemulator
O programa parece ser aquele também neste ambiente doméstico:
Mulan:~ prisoner$ echo $ANDROID_HOME /Users/prisoner/Library/Android/sdk Mulan:~ prisoner$ which emulator /Users/prisoner/Library/Android/sdk/tools/emulator
Até onde eu sei, o emulador e os emuladores específicos da arquitetura também estão sobANDROID_HOME
:
Estou perplexo sobre onde mais procurar, mensagens de erro ou o emulador que está lá, mas não pode ser encontrado pelo sistema ou como resolver o problema.
Atualização 1: Especifique o caminho explicitamente.
Tentar especificar os caminhos explicitamente também não funciona:
Mulan:~ prisoner$ /Users/prisoner/Library/Android/sdk/tools/emulator @Galaxy_Nexus_Jelly_Bean_API_16 PANIC: Missing emulator engine program for 'arm' CPU. Mulan:~ prisoner$ /Users/prisoner/Library/Android/sdk/emulator/emulator @Galaxy_Nexus_Jelly_Bean_API_16 emulator: ERROR: This AVD's configuration is missing a kernel file! Please ensure the file "kernel-qemu" is in the same location as your system image. emulator: ERROR: ANDROID_SDK_ROOT is undefined
Com certeza,ANDROID_SDK_ROOT
não está definido. Definindo-o para a mesma coisa queANDROID_HOME
faz o seguinte:
Mulan:~ prisoner$ export ANDROID_SDK_ROOT="$ANDROID_HOME" Mulan:~ prisoner$ /Users/prisoner/Library/Android/sdk/emulator/emulator @Galaxy_Nexus_Jelly_Bean_API_16 emulator: ERROR: This AVD's configuration is missing a kernel file! Please ensure the file "kernel-qemu" is in the same location as your system image. emulator: ERROR: ANDROID_SDK_ROOT is defined (/Users/prisoner/Library/Android/sdk) but cannot find kernel file in /Users/prisoner/Library/Android/sdk/system-images/ sub directories
Olhando por baixo dosystem-images
diretório, vemos um diretório para cada plataforma da API:
Mulan:~ prisoner$ ls ~/Library/Android/sdk/system-images/ android-16 android-19 android-23 android-26 android-17 android-21 android-24 android-27 android-18 android-22 android-25 android-28
Olhando logo abaixo doandroid-16
diretório, temos
./default ./default/armeabi-v7a ./default/armeabi-v7a/build.prop ./default/armeabi-v7a/kernel-qemu ./default/armeabi-v7a/NOTICE.txt ./default/armeabi-v7a/package.xml ./default/armeabi-v7a/ramdisk.img ./default/armeabi-v7a/source.properties ./default/armeabi-v7a/system.img ./default/armeabi-v7a/userdata.img ./default/mips ./default/mips/build.prop ./default/mips/kernel-qemu ./default/mips/NOTICE.txt ./default/mips/package.xml ./default/mips/ramdisk.img ./default/mips/source.properties ./default/mips/system.img ./default/mips/userdata.img ./default/x86 ./default/x86/build.prop ./default/x86/kernel-qemu ./default/x86/kernel-ranchu ./default/x86/NOTICE.txt ./default/x86/package.xml ./default/x86/ramdisk.img ./default/x86/source.properties ./default/x86/system.img ./default/x86/userdata.img ./google_apis ./google_apis/x86 ./google_apis/x86/advancedFeatures.ini ./google_apis/x86/build.prop ./google_apis/x86/kernel-qemu ./google_apis/x86/kernel-ranchu ./google_apis/x86/NOTICE.txt ./google_apis/x86/package.xml ./google_apis/x86/ramdisk.img ./google_apis/x86/source.properties ./google_apis/x86/system.img ./google_apis/x86/userdata.img