2012-05-26 4 views
5

Cuando intento compilar algunas muestras NDK de Android siempre sale este error:error durante la compilación de Android muestra JNI: -march no válida opción =: `ARMv5TE'

$ cd ~/Dev/Android/ndk/samples/hello-jni 
$ ~/Dev/Android/ndk/ndk-build 
Gdbserver  : [arm-linux-androideabi-4.4.3] libs/armeabi/gdbserver 
Gdbsetup  : libs/armeabi/gdb.setup 
Compile thumb : hello-jni <= hello-jni.c 
Assembler messages: 
Fatal error: invalid -march= option: `armv5te' 
make: *** [obj/local/armeabi/objs-debug/hello-jni/hello-jni.o] Error 1 

¿Qué pasa conmigo o con mi sistema?

+0

Está utilizando un compilador o una versión de compilación que no comprende ese argumento. – EJP

Respuesta

12

he encontrado una solución:

$ ln -s $NDK_PATH/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/arm-linux-androideabi-as $NDK_PATH/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/libexec/gcc/arm-linux-androideabi/4.4.3/as 

En primer lugar me encontré con el constructor con opciones para que muestre los commads siendo ejecutadas:

$ ndk-build -B V=1 

por lo que he descubierto cómo se ejecuta el compilador y pasó el mismo comando a strace

strace arm-linux-androideabi-gcc -MMD -MP -MF ./obj/local/armeabi/objs-debug/hello-jni/hello-jni.o.d -fpic -ffunction-sections -funwind-tables -fstack-protector -D__ARM_ARCH_5__ -D__ARM_ARCH_5T__ -D__ARM_ARCH_5E__ -D__ARM_ARCH_5TE__ -Wno-psabi -march=armv5te -mtune=xscale -msoft-float -mthumb -Os -fomit-frame-pointer -fno-strict-aliasing -finline-limit=64 -Ijni -DANDROID -Wa,--noexecstack -O0 -g -I/home/aleck/Dev/Android/ndk/platforms/android-8/arch-arm/usr/include -c jni/hello-jni.c -o ./obj/local/armeabi/objs-debug/hello-jni/hello-jni.o 

que revela que por alguna razón desconocida arm-linux-a ndroideabi-gcc hace una búsqueda del programa de ensamblador por el pensamiento de la norma, pero en este nombre no válido caso 'como' en lugar de 'brazo-linux-androideabi-como'

stat64("/home/aleck/Dev/Android/ndk/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/../libexec/gcc/arm-linux-androideabi/4.4.3/as", 0xbfedea68) = -1 ENOENT (No such file or directory) 
stat64("/home/aleck/Dev/Android/ndk/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/../libexec/gcc/as", 0xbfedea68) = -1 ENOENT (No such file or directory) 
stat64("/home/aleck/Dev/Android/ndk/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/../lib/gcc/arm-linux-androideabi/4.4.3/../../../../arm-linux-androideabi/bin/arm-linux-androideabi/4.4.3/as", 0xbfedea68) = -1 ENOENT (No such file or directory) 
stat64("/home/aleck/Dev/Android/ndk/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/../lib/gcc/arm-linux-androideabi/4.4.3/../../../../arm-linux-androideabi/bin/as", 0xbfedea68) = -1 ENOENT (No such file or directory) 
vfork()         = 6931 
waitpid(6931, Assembler messages: 
Fatal error: invalid -march= option: `armv5te' 

así que hice un enlace simbólico llamado 'como' en primer lugar, donde se espera que sea.

+2

¡Gracias! ¡Creo que te mereces una recompensa! – Max

Cuestiones relacionadas