Extract util methods
This commit is contained in:
parent
51f3c16205
commit
ee813caaf1
5 changed files with 52 additions and 20 deletions
|
@ -42,6 +42,7 @@ include_directories(include)
|
||||||
add_executable(${PROJECT_NAME}_status
|
add_executable(${PROJECT_NAME}_status
|
||||||
src/status.c
|
src/status.c
|
||||||
src/tracetools.c
|
src/tracetools.c
|
||||||
|
src/utils.cpp
|
||||||
)
|
)
|
||||||
target_link_libraries(${PROJECT_NAME}_status
|
target_link_libraries(${PROJECT_NAME}_status
|
||||||
${PROJECT_NAME}
|
${PROJECT_NAME}
|
||||||
|
@ -57,6 +58,7 @@ install(TARGETS
|
||||||
# Tracetools lib
|
# Tracetools lib
|
||||||
set(SOURCES
|
set(SOURCES
|
||||||
src/tracetools.c
|
src/tracetools.c
|
||||||
|
src/utils.cpp
|
||||||
)
|
)
|
||||||
if(TRACING_ENABLED)
|
if(TRACING_ENABLED)
|
||||||
list(APPEND SOURCES ${LTTNG_GENERATED})
|
list(APPEND SOURCES ${LTTNG_GENERATED})
|
||||||
|
|
|
@ -158,7 +158,7 @@ void TRACEPOINT(
|
||||||
void TRACEPOINT(
|
void TRACEPOINT(
|
||||||
rclcpp_callback_register,
|
rclcpp_callback_register,
|
||||||
const void * callback,
|
const void * callback,
|
||||||
const void * function_target);
|
const char * function_symbol);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
19
tracetools/include/tracetools/utils.hpp
Normal file
19
tracetools/include/tracetools/utils.hpp
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
#ifndef __TRACETOOLS_UTILS_H_
|
||||||
|
#define __TRACETOOLS_UTILS_H_
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
template<typename T, typename... U>
|
||||||
|
size_t get_address(std::function<T(U...)> f) {
|
||||||
|
typedef T(fnType)(U...);
|
||||||
|
fnType ** fnPointer = f.template target<fnType*>();
|
||||||
|
// Might be a lambda
|
||||||
|
if (fnPointer == nullptr) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return (size_t)*fnPointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char * get_symbol(void * funptr);
|
||||||
|
|
||||||
|
#endif /* __TRACETOOLS_UTILS_H_ */
|
|
@ -1,4 +1,3 @@
|
||||||
#include <execinfo.h>
|
|
||||||
#include "tracetools/tracetools.h"
|
#include "tracetools/tracetools.h"
|
||||||
|
|
||||||
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
||||||
|
@ -9,22 +8,6 @@
|
||||||
# define CONDITIONAL_TP(...)
|
# define CONDITIONAL_TP(...)
|
||||||
#endif
|
#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()
|
bool ros_trace_compile_status()
|
||||||
{
|
{
|
||||||
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
#if defined(WITH_LTTNG) && !defined(_WIN32)
|
||||||
|
@ -171,7 +154,7 @@ void TRACEPOINT(
|
||||||
void TRACEPOINT(
|
void TRACEPOINT(
|
||||||
rclcpp_callback_register,
|
rclcpp_callback_register,
|
||||||
const void * callback,
|
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