欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談在linux kernel中打印函數(shù)調(diào)用的堆棧的方法

 更新時間:2016年12月24日 10:15:08   投稿:jingxian  
下面小編就為大家?guī)硪黄獪\談在linux kernel中打印函數(shù)調(diào)用的堆棧的方法。小編覺得挺不錯的?,F(xiàn)在就分享給大家。也給大家做個參考。一起跟隨小編過來看看吧

在Linux內(nèi)核調(diào)試中,經(jīng)常用到的打印函數(shù)調(diào)用堆棧的方法非常簡單,只需在需要查看堆棧的函數(shù)中加入:

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應(yīng)用程序調(diào)試中,使用的方法是:

backtrace
backtrace_symbols

可以在函數(shù)中加入如下代碼:

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]);

以上就是小編為大家?guī)淼臏\談在linux kernel中打印函數(shù)調(diào)用的堆棧的方法全部內(nèi)容了,希望大家多多支持腳本之家~

相關(guān)文章

最新評論