How to get ndk-gdb working on Android?
I'm trying to get the NDK debugger working but with no success so far.
To make sure my debug symbols are present and valid, I use the compiler options -O0 and -g, and the ndk-build parameter NDK_DEBUG=1.
The ndk-gdb script runs with out issues and launches GDB. When do a "sharedlibrary" command, I get this:
Symbols already loaded for /bla/bla/libMySharedLib.so
However when I try breaking execution or e.g. adding a segfault to test, I never get any of the symbols from that library in the call stack. The only symbols I've gotten are from libc, if I break execution while it's waiting for a mutex for instance. Also tried adding breakpoints with no luck. GDB lets me add the breakpoints, and the code runs fine, but the breakpoints are never triggered.
I'm using API level 8 as I need to support Android 2.2 (Froyo).
Solution 1:
You don't need to use -O0 or -g switches. You need to do one of following:
- put
android:debuggable="true"
to the<application>
tag inAndroidManifest.xml
file - use
NDK_DEBUG=1
after ndk-build - put
APP_OPTIM := debug
in Application.mk file
Doing anyone of these three things will automatically use -O0 and -g switches.
Can you try running gdb manually, without gdb script? It involves following steps:
- pushing
gdbserver
file to/data/local
folder on device - running your application & invoking in
adb shell
following commandgdbserver :5055 --attach PID
, where PID is your application process id. - running
adb forward tcp:5055 tcp:5055
on host - running
arm-linux-androideabi-gdb.exe
from your app folder - entering following commands in gdb
set solib-search-path obj/local/armeabi
file obj/local/armeabi/libMySharedLib.so
target remote :5055
And see if you can debug then.
If you want see symbols for other shared libraries your library is using like libc.so
, then pull them from device (from /system/lib
folder) to your obj/local/armeabi
folder.