Android native 程序如何得到函数的 call graph ?

2014-12-02 13:28:26 +08:00
 dawn009
调试一个C语言程序的bug,想得到运行时的完整 call graph。

思路:
加上 gcc 的编译参数 -finstrument-functions,在每个函数调用时得到其内存地址,然后通过 dladdr() 得到函数名,输出log。

但是实验失败,dladdr 返回 null。

通过实验,发现在编译成共享库的情况下可以成功,可是我需要的是独立运行的二进制文件而不是共享库。

情况1:
编译成共享库,Android.mk 中用 BUILD_SHARED_LIBRARY。这种情况下dladdr可以得到函数名。

问题在于情况2:
编译成独立运行的二进制文件,Android.mk 中用 BUILD_EXECUTABLE。这时dladdr取不到函数名。

有人知道该怎么解决吗?
6687 次点击
所在节点    Android
4 条回复
pright
2014-12-02 16:35:09 +08:00
为啥不直接用CallStack?
pright
2014-12-02 16:53:29 +08:00
哦,是C么。。那可以试试用backtrace(system/core/include/corkscrew/backtrace.h)。CallStack也是这个实现的。
dawn009
2014-12-03 12:58:31 +08:00
5.0里似乎把libcorkscrew 换成了 libbacktrace,并且换成了 c++ 代码。

我最后用 nm 导出符号表,自己计算偏移量搞定了。
pright
2014-12-03 15:41:17 +08:00
改成c++其实也可以自己写个函数包一下给C调,看调用栈的时候就跳过自己写的函数就行

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/150897

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX