2015-10-16 12:42:26 -07:00
|
|
|
#include <stdlib.h>
|
2015-08-25 21:59:01 -07:00
|
|
|
#include <px4_log.h>
|
2015-10-19 09:48:27 +02:00
|
|
|
#ifdef __PX4_POSIX
|
2015-10-16 12:42:26 -07:00
|
|
|
#include <execinfo.h>
|
2015-10-19 09:48:27 +02:00
|
|
|
#endif
|
2015-08-25 21:59:01 -07:00
|
|
|
|
|
|
|
|
__EXPORT int __px4_log_level_current = PX4_LOG_LEVEL_AT_RUN_TIME;
|
|
|
|
|
|
2015-10-19 09:48:27 +02:00
|
|
|
__EXPORT const char *__px4_log_level_str[_PX4_LOG_LEVEL_PANIC + 1] = { "INFO", "DEBUG", "WARN", "ERROR", "PANIC" };
|
2016-06-09 12:51:04 +02:00
|
|
|
__EXPORT const char *__px4_log_level_color[_PX4_LOG_LEVEL_PANIC + 1] =
|
2016-06-09 13:16:04 +02:00
|
|
|
{ PX4_ANSI_COLOR_RESET, PX4_ANSI_COLOR_GREEN, PX4_ANSI_COLOR_YELLOW, PX4_ANSI_COLOR_RED, PX4_ANSI_COLOR_RED };
|
2015-10-16 12:42:26 -07:00
|
|
|
|
|
|
|
|
void px4_backtrace()
|
|
|
|
|
{
|
2015-10-19 09:48:27 +02:00
|
|
|
#ifdef __PX4_POSIX
|
2015-10-16 12:42:26 -07:00
|
|
|
void *buffer[10];
|
|
|
|
|
char **callstack;
|
|
|
|
|
int bt_size;
|
|
|
|
|
int idx;
|
|
|
|
|
|
|
|
|
|
bt_size = backtrace(buffer, 10);
|
|
|
|
|
callstack = backtrace_symbols(buffer, bt_size);
|
|
|
|
|
|
2015-10-19 09:48:27 +02:00
|
|
|
PX4_INFO("Backtrace: %d", bt_size);
|
2015-10-16 12:42:26 -07:00
|
|
|
|
2015-10-19 09:48:27 +02:00
|
|
|
for (idx = 0; idx < bt_size; idx++) {
|
2015-10-16 12:42:26 -07:00
|
|
|
PX4_INFO("%s", callstack[idx]);
|
2015-10-19 09:48:27 +02:00
|
|
|
}
|
2015-10-16 12:42:26 -07:00
|
|
|
|
|
|
|
|
free(callstack);
|
2015-10-19 09:48:27 +02:00
|
|
|
#endif
|
2015-10-16 12:42:26 -07:00
|
|
|
}
|