robot-piglet d18b988a03 Intermediate changes 2 months ago
..
LICENSE 73b89de717 YT-19210: expose YQL shared library for YT. 1 year ago
README.md 226ad6e44d Intermediate changes 3 months ago
atomic.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
backtrace-supported.h dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
backtrace.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
backtrace.h dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
config-armv7a.h 73b89de717 YT-19210: expose YQL shared library for YT. 1 year ago
config-linux.h fba7383e19 Update contrib/libs/backtrace to 2024-05-01 6 months ago
config-osx.h 73b89de717 YT-19210: expose YQL shared library for YT. 1 year ago
config.h 21c16c520b Update contrib/libs/backtrace to 2023-11-30 11 months ago
dwarf.c 27b7ec6ec1 Update contrib/libs/backtrace to 2024-07-16 3 months ago
elf.c 5a45964796 Update contrib/libs/backtrace to 2024-07-18 3 months ago
fileline.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
filenames.h 73b89de717 YT-19210: expose YQL shared library for YT. 1 year ago
internal.h 5a45964796 Update contrib/libs/backtrace to 2024-07-18 3 months ago
macho.c 27b7ec6ec1 Update contrib/libs/backtrace to 2024-07-16 3 months ago
mmap.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
mmapio.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
posix.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
print.c 5a45964796 Update contrib/libs/backtrace to 2024-07-18 3 months ago
simple.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
sort.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
state.c dd3740bc9a Update contrib/libs/backtrace to 2024-07-12 3 months ago
ya.make d18b988a03 Intermediate changes 2 months ago

README.md

libbacktrace

A C library that may be linked into a C/C++ program to produce symbolic backtraces

Initially written by Ian Lance Taylor iant@golang.org.

This is version 1.0. It is likely that this will always be version 1.0.

The libbacktrace library may be linked into a program or library and used to produce symbolic backtraces. Sample uses would be to print a detailed backtrace when an error occurs or to gather detailed profiling information.

In general the functions provided by this library are async-signal-safe, meaning that they may be safely called from a signal handler. That said, on systems that use dl_iterate_phdr, such as GNU/Linux, gitthe first call to a libbacktrace function will call dl_iterate_phdr, which is not in general async-signal-safe. Therefore, programs that call libbacktrace from a signal handler should ensure that they make an initial call from outside of a signal handler. Similar considerations apply when arranging to call libbacktrace from within malloc; dl_iterate_phdr can also call malloc, so make an initial call to a libbacktrace function outside of malloc before trying to call libbacktrace functions within malloc.

The libbacktrace library is provided under a BSD license. See the source files for the exact license text.

The public functions are declared and documented in the header file backtrace.h, which should be #include'd by a user of the library.

Building libbacktrace will generate a file backtrace-supported.h, which a user of the library may use to determine whether backtraces will work. See the source file backtrace-supported.h.in for the macros that it defines.

As of July 2024, libbacktrace supports ELF, PE/COFF, Mach-O, and XCOFF executables with DWARF debugging information. In other words, it supports GNU/Linux, *BSD, macOS, Windows, and AIX. The library is written to make it straightforward to add support for other object file and debugging formats.

The library relies on the C++ unwind API defined at https://itanium-cxx-abi.github.io/cxx-abi/abi-eh.html This API is provided by GCC and clang.