在linux代码中打印函数调用的堆栈的方法
Posted catgatp
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在linux代码中打印函数调用的堆栈的方法相关的知识,希望对你有一定的参考价值。
之前一直有这样的需求,当时问到,也没搜到方法,现在竟然既问到了,也搜到了,哎,世事真是不能强求啊!
在Linux内核调试中,经常用到的打印函数调用堆栈的方法非常简单,只需在需要查看堆栈的函数中加入:
dump_stack();或 __backtrace();即可。
dump_stack()在~/kernel/ lib/Dump_stack.c中定义
void dump_stack(void)
{
printk(KERN_NOTICE
"This architecture does not implement dump_stack()/n");
}
__backtrace()的定义在~/kernel/arch/arm/lib/backtrace.S中
ENTRY(__backtrace)
mov r1, #0x10
mov r0, fp
在linux应用程序调试中,使用的方法是:
backtrace
backtrace_symbols
可以在函数中加入如下代码:
void *bt[20];
char **strings;
size_t sz;
sz = backtrace(bt, 20);
strings = backtrace_symbols(bt, sz);
for(i = 0; i < sz; ++i)
fprintf(stderr, "%s/n", strings[i]);
还有一个帖子总结了在各种平台和语言中打印backtrace的方法:
http://blog.csdn.net/csucrab/archive/2010/06/17/5675686.aspx
以上是关于在linux代码中打印函数调用的堆栈的方法的主要内容,如果未能解决你的问题,请参考以下文章
Linux下利用backtrace追踪函数调用堆栈以及定位段错误[转]