Extract util methods
This commit is contained in:
parent
51f3c16205
commit
ee813caaf1
5 changed files with 52 additions and 20 deletions
|
@ -1,4 +1,3 @@
|
|||
#include <execinfo.h>
|
||||
#include "tracetools/tracetools.h"
|
||||
|
||||
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
||||
|
@ -9,22 +8,6 @@
|
|||
# define CONDITIONAL_TP(...)
|
||||
#endif
|
||||
|
||||
|
||||
const char * get_symbol(const void * function_ptr) {
|
||||
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
||||
// If it's actually a lambda
|
||||
if (NULL == function_ptr) {
|
||||
return "";
|
||||
}
|
||||
char ** symbols = backtrace_symbols(&function_ptr, 1);
|
||||
const char * result = symbols[0];
|
||||
free(symbols);
|
||||
return result;
|
||||
#else
|
||||
return "";
|
||||
#endif
|
||||
}
|
||||
|
||||
bool ros_trace_compile_status()
|
||||
{
|
||||
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
||||
|
@ -171,7 +154,7 @@ void TRACEPOINT(
|
|||
void TRACEPOINT(
|
||||
rclcpp_callback_register,
|
||||
const void * callback,
|
||||
const void * function_target)
|
||||
const char * function_symbol)
|
||||
{
|
||||
CONDITIONAL_TP(ros2, rclcpp_callback_register, callback, get_symbol(function_target));
|
||||
CONDITIONAL_TP(ros2, rclcpp_callback_register, callback, function_symbol);
|
||||
}
|
||||
|
|
28
tracetools/src/utils.cpp
Normal file
28
tracetools/src/utils.cpp
Normal file
|
@ -0,0 +1,28 @@
|
|||
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
||||
#include <dlfcn.h>
|
||||
#include <cxxabi.h>
|
||||
#endif
|
||||
|
||||
const char * get_symbol(void * funptr) {
|
||||
#define SYMBOL_UNKNOWN "UNKNOWN"
|
||||
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
||||
#define SYMBOL_LAMBDA "[lambda]"
|
||||
if (funptr == 0) {
|
||||
return SYMBOL_LAMBDA;
|
||||
}
|
||||
|
||||
Dl_info info;
|
||||
if (dladdr(funptr, &info) == 0) {
|
||||
return SYMBOL_UNKNOWN;
|
||||
}
|
||||
|
||||
char * demangled = nullptr;
|
||||
int status;
|
||||
demangled = abi::__cxa_demangle(info.dli_sname, NULL, 0, &status);
|
||||
// Use demangled symbol if possible
|
||||
const char * demangled_val = (status == 0 ? demangled : info.dli_sname);
|
||||
return (demangled_val != 0 ? demangled_val : SYMBOL_UNKNOWN);
|
||||
#else
|
||||
return SYMBOL_UNKNOWN;
|
||||
#endif
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue