写了一个简单的C程序,放在Android代码树的external/helloworld目录下,Android.mk是这么写的:
在Android代码树下执行
$ mmm external/helloworld
成功。然后启动emulator,并执行
$ adb push out/target/product/generic/system/binworld /data
把helloworld传到emulator 的/data目录下。
然后就是gdbserver/gdb,可是当我启动gdb之后,总是提示读不到debugging信息:
(gdb) file out/target/product/generic/system/bin/helloworld
Reading symbols from out/target/product/generic/system/bin/helloworld...(no debugging symbols found)...done.
于是,后面的调试总是失败:
(gdb) target remote :12345
Remote debugging using :12345
warning: Unable to find dynamic linker breakpoint function.
GDB will be unable to debug shared library initializers
and track explicitly loaded dynamic code.
Cannot access memory at address 0x0
0xa9702658 in ?? ()
求高人指点。
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE_TAGS := optional
LOCAL_MODULE := helloworld
LOCAL_CFLAGS += -ggdb
LOCAL_SRC_FILES := $(call all-subdir-c-files)
include $(BUILD_EXECUTABLE)
在Android代码树下执行
$ mmm external/helloworld
成功。然后启动emulator,并执行
$ adb push out/target/product/generic/system/binworld /data
把helloworld传到emulator 的/data目录下。
然后就是gdbserver/gdb,可是当我启动gdb之后,总是提示读不到debugging信息:
(gdb) file out/target/product/generic/system/bin/helloworld
Reading symbols from out/target/product/generic/system/bin/helloworld...(no debugging symbols found)...done.
于是,后面的调试总是失败:
(gdb) target remote :12345
Remote debugging using :12345
warning: Unable to find dynamic linker breakpoint function.
GDB will be unable to debug shared library initializers
and track explicitly loaded dynamic code.
Cannot access memory at address 0x0
0xa9702658 in ?? ()
求高人指点。