Вы можете получить местоположение функции C, которая вызвала сбой, с помощью Android NDK Stacktrace Analyzer .
Шаги выполняются на вики , но в основном вам нужно получить трассировку стека из logcat в файл (adb logcat > mycrash.log
), затем вывести свою библиотеку в текстовый файл, а затем запустить программу на двое из них. Вот сценарий оболочки, который я использую для выполнения лота:
#!/bin/sh
if test $# -lt 2 ; then
echo "Extract readable stack trace from Android logcat crash"
echo "Usage $0 lib.so crash.log"
exit 1
fi
of=$(mktemp)
echo "Disassemble $1"
~/tools/android-ndk-r5/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/arm-linux-androideabi-objdump -S $1 > $of
echo "Parse stack trace in $2"
~/bin/parse_stack.py $of $2
Измените пути к файлу Android NDK и parse_stack.py, как вам нужно.