backtrace_symbols() с -static и -rdynamic

Глядя на этот вопрос и этот вопрос, я вижу, что для backtrace_symbols() чтобы работать, надо скомпилировать -rdynamic флаг.

Я пробовал это в тестовой программе, и она работает, но я пишу программу, которая также скомпилирована с -static и эта страница говорит, что backtrace_symbols() не работает когда -static передается компилятору / компоновщику.

Есть ли какой-нибудь быстрый способ обойти это, или у меня никогда не будет удобочитаемой функции обратной трассировки в моей статически связанной программе?

2 ответа

Решение

Ответ уже был под рукой: он был на той же странице, на которую я ссылался в вопросе. В конце я успешно использовал libunwind,

#include <libunwind.h>
#include <stdio.h>

void do_backtrace()
{
    unw_cursor_t    cursor;
    unw_context_t   context;

    unw_getcontext(&context);
    unw_init_local(&cursor, &context);

    while (unw_step(&cursor) > 0)
    {
        unw_word_t  offset, pc;
        char        fname[64];

        unw_get_reg(&cursor, UNW_REG_IP, &pc);

        fname[0] = '\0';
        (void) unw_get_proc_name(&cursor, fname, sizeof(fname), &offset);

        printf ("%p : (%s+0x%x) [%p]\n", pc, fname, offset, pc);
    }
}

int main()
{
 do_backtrace();
 return 0;
}

Я получал ошибки компоновки, потому что я (снова) забыл поместить параметры компоновщика в конце командной строки. Я действительно не понимаю, почему g++/gcc не выводите хотя бы предупреждение при игнорировании параметров командной строки. Правильная командная строка для компиляции (-g не нужен):

g++ -static unwind.cpp -o unwind -lunwind -lunwind-x86

Если вам абсолютно необходимо скомпилировать вашу программу как статическую, вы все равно можете использовать backtrace() чтобы узнать адреса функций, а затем найти имена функций, анализируя отладочную информацию, например, используя libdwarf.

Но это не простая задача, поэтому я бы предложил использовать -rdynamic флаг.

Другие вопросы по тегам