码迷,mamicode.com
首页 > 系统相关 > 详细

在linux代码中打印函数调用的堆栈的方法

时间:2017-02-03 22:05:45      阅读:266      评论:0      收藏:0      [点我收藏+]

标签:article   应用程序   查看   size_t   printk   知识   tle   定义   target   

之前一直有这样的需求,当时问到,也没搜到方法,现在竟然既问到了,也搜到了,哎,世事真是不能强求啊!

 

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代码中打印函数调用的堆栈的方法

标签:article   应用程序   查看   size_t   printk   知识   tle   定义   target   

原文地址:http://www.cnblogs.com/catgatp/p/6363505.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!