BFD неизвестная команда при использовании gaddr2line
Я пытаюсь использовать gaddr2line
распечатать более красивую версию символов обратной трассировки. Я просто получаю адреса от backtrace()
затем кормить их gaddr2line
выполнив его с помощью popen
, С помощью addr2line
под linux работает нормально, но я почему-то получаю странные ошибки при использовании gaddr2line
на OS X. При попытке это на Mac OS я продолжаю получать BFD: ... : unknown load command ...
Я видел некоторые посты, в которых упоминается GDB, поэтому я попытался установить его с помощью homebrew, но это не помогло.
Вот мой код:
// set to the maximum possible path size
char exe_path[4096];
// Used to check if an error occured while setting up command
bool error = false;
// Check if we are running on Mac OS or not, and select appropriate command
char* command;
#ifdef __APPLE__
// Check if 'gaddr2line' function is available, if not exit
if( !system( "which gaddr2line > /dev/null 2>&1" ) ) {
command = "gaddr2line -Cfspe";
pid_t pid = getpid();
int path_length = proc_pidpath( pid, exe_path, sizeof( exe_path ) );
if( path_length <= 0 ) {
writeLog( SIMPLOG_LOGGER, "Unable to get execution path. Defaulting to standard backtrace." );
error = true;
}
exe_path[path_length] = 0;
} else {
writeLog( SIMPLOG_LOGGER, "Function 'gaddr2line' unavailable. Defaulting to standard backtrace. Please install package 'binutils' for better stacktrace output." );
error = true;
}
#endif
Вот вывод:
gaddr2line -Cfspe /Users/nate/git/SimpleLogger/build/test 7408927
BFD: /Users/nate/git/SimpleLogger/build/test: unknown load command 0x2a
BFD: /Users/nate/git/SimpleLogger/build/test: unknown load command 0x28
BFD: /Users/nate/git/SimpleLogger/build/test: unknown load command 0x29
BFD: /Users/nate/git/SimpleLogger/build/test: unknown load command 0x2b