X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/acc4596bfe40a4bf7f59d5b94bc5643f86806dda..adb4bdd154d3cf3594d0640d36bde50f5019181b:/src/xbt/backtrace.cpp diff --git a/src/xbt/backtrace.cpp b/src/xbt/backtrace.cpp index f897e12adb..349ed1163b 100644 --- a/src/xbt/backtrace.cpp +++ b/src/xbt/backtrace.cpp @@ -1,29 +1,83 @@ -/* Copyright (c) 2005-2016. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2005-2020. The SimGrid Team. All rights reserved. */ -#include - -#include -#include +/* This program is free software; you can redistribute it and/or modify it + * under the terms of the license (GNU LGPL) which comes with this package. */ #include "src/internal_config.h" -extern "C" { +#include +#include +#include +#include + +#include +#include +#include + +// Try to detect and use the C++ itanium ABI for name demangling: +#ifdef __GXX_ABI_VERSION +#include +#endif -XBT_LOG_NEW_DEFAULT_SUBCATEGORY(xbt_backtrace, xbt, "Backtrace"); +#if HAVE_BOOST_STACKTRACE_BACKTRACE +#define BOOST_STACKTRACE_USE_BACKTRACE +#include +#elif HAVE_BOOST_STACKTRACE_ADDR2LINE +#define BOOST_STACKTRACE_USE_ADDR2LINE +#include +#endif +/** @brief show the backtrace of the current point (lovely while debugging) */ +void xbt_backtrace_display_current() +{ + simgrid::xbt::Backtrace().display(); } -/** @brief show the backtrace of the current point (lovely while debuging) */ -void xbt_backtrace_display_current(void) +namespace simgrid { +namespace xbt { + +std::unique_ptr> demangle(const char* name) { - const std::size_t size = 10; - xbt_backtrace_location_t bt[size]; - size_t used = xbt_backtrace_current(bt, size); - xbt_backtrace_display(bt, used); +#ifdef __GXX_ABI_VERSION + int status; + std::unique_ptr> res(abi::__cxa_demangle(name, nullptr, nullptr, &status), + &std::free); + if (res != nullptr) + return res; + // We did not manage to resolve this. Probably because this is not a mangled symbol: +#endif + // Return the symbol: + return std::unique_ptr>(xbt_strdup(name), &xbt_free_f); } -#if HAVE_BACKTRACE && HAVE_EXECINFO_H && HAVE_POPEN && defined(ADDR2LINE) -# include "src/xbt/backtrace_linux.cpp" +class BacktraceImpl { +#if HAVE_BOOST_STACKTRACE_BACKTRACE || HAVE_BOOST_STACKTRACE_ADDR2LINE + const boost::stacktrace::stacktrace st = boost::stacktrace::stacktrace(); #else -# include "src/xbt/backtrace_dummy.cpp" + const char st[1] = ""; // fallback value #endif +public: + std::string resolve() const + { + std::stringstream ss; + ss << st; + return ss.str(); + } +}; + +Backtrace::Backtrace() : impl_(std::make_shared()) {} + +std::string Backtrace::resolve() const +{ + return impl_->resolve(); +} + +void Backtrace::display() const +{ + std::string backtrace = resolve(); + std::fprintf(stderr, "Backtrace (displayed in actor %s):\n%s\n", xbt_procname(), + backtrace.empty() ? "(backtrace not set -- did you install Boost.Stacktrace?)" : backtrace.c_str()); +} + +} // namespace xbt +} // namespace simgrid