ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

c – backtrace_symbols无法打印导致信号的函数

2019-07-28 17:04:44  阅读:415  来源: 互联网

标签:c macos stack-trace callstack signal-handling


我正在为我的C应用程序实现一个简单的崩溃记录器:

static void handler(int, siginfo_t * info, void *) {
    void *array[1000];

    switch (info->si_signo) {
    case SIGILL:
        Logger() << "Received SIGILL";
        break;
    case SIGSEGV:
        Logger() << "Received SIGSEGV";
        break;
    case SIGBUS:
        Logger() << "Received SIGBUS";
        break;
    case SIGSYS:
        Logger() << "Received SIGSYS";
        break;
    default:
        break;
    }

    // get void*'s for all entries on the stack
    const size_t size = backtrace(array, 1000);

    // print out all the frames
    char ** symbols = backtrace_symbols(array, size);
    for(size_t i = 0; i < size; ++i)
    {
        Logger() << symbols[i];
    }

    free(symbols);
    exit(EXIT_FAILURE);
}

struct sigaction SignalAction;
SignalAction.sa_flags = SA_SIGINFO;
SignalAction.sa_sigaction = handler;
sigemptyset(&SignalAction.sa_mask);
sigaction(SIGSEGV, &SignalAction, NULL);
sigaction(SIGBUS, &SignalAction, NULL);
sigaction(SIGILL, &SignalAction, NULL);

我还没有在Linux上测试它,但是在OS X上,我感兴趣的特定跟踪项目,thatr引起信号的那个,没有被打印(条目号2):

: " Received SIGSEGV" 
: " 0   App                       0x0000000100253d15 _ZL7handleriP9__siginfoPv + 229" 
: " 1   libsystem_platform.dylib  0x00007fff8ff0f5aa _sigtramp + 26" 
: " 2   ???                       0x000000000000000c 0x0 + 12" 
: " 3   App                       0x000000010000dfa7 _ZN11CMainWindow13initShortcutsEv + 231" 
: " 4   App                       0x000000010000d059 _ZN11CMainWindowC2EP7QWidget + 1001" 
: " 5   App                       0x00000001000091d9 main + 6217" 
: " 6   App                       0x00000001000070a5 _start + 227" 
: " 7   App                       0x0000000100006fc1 start + 33" 

为什么会发生这种情况,我可以解决这个问题吗?

P. S.这是一个调试版本.没有实际的段错误,它是用raise(SIGSEGV)模拟的. raise是从一个方法调用的,而这个方法又是从MainWindow :: initShortcuts调用的.

解决方法:

2号入口有非常特殊的地址.它是0x000000000000000c,你必须知道有中断描述表.根据http://en.wikipedia.org/wiki/Interrupt_Descriptor_Table,它可能是Stack Fault.

然而正如Ken指出的那样,做你正在做的事情是不好的.这就像试图记住当你的主动脉被撕裂时撞到你的汽车牌照.你能做到但是为了什么?

也许不要尝试学习如何使用strace http://en.wikipedia.org/wiki/Strace.

标签:c,macos,stack-trace,callstack,signal-handling
来源: https://codeday.me/bug/20190728/1563942.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有