gcc/libbacktrace
GCC Administrator a922de0a7a Daily bump.
2024-07-18 00:18:58 +00:00
..
aclocal.m4
alloc.c
allocfail.c
allocfail.sh
atomic.c
backtrace-supported.h.in
backtrace.c
backtrace.h
btest.c libbacktrace: don't fail if symbol size is unknown 2024-07-11 17:58:17 -07:00
ChangeLog Daily bump. 2024-07-18 00:18:58 +00:00
ChangeLog.jit
config.h.in
configure libbacktrace: fix testsuite for clang 2024-07-11 16:12:47 -07:00
configure.ac libbacktrace: fix testsuite for clang 2024-07-11 16:12:47 -07:00
dwarf.c libbacktrace: support FDPIC 2024-07-15 17:28:28 -07:00
edtest2.c
edtest.c libbacktrace: fix testsuite for clang 2024-07-11 16:12:47 -07:00
elf.c libbacktrace: support FDPIC 2024-07-15 17:28:28 -07:00
fileline.c
filetype.awk
install-debuginfo-for-buildid.sh.in
instrumented_alloc.c
internal.h libbacktrace: support FDPIC 2024-07-15 17:28:28 -07:00
macho.c libbacktrace: support FDPIC 2024-07-15 17:28:28 -07:00
Makefile.am libbacktrace: update xcoff.c for base_address changes 2024-07-16 21:27:05 -07:00
Makefile.in libbacktrace: update xcoff.c for base_address changes 2024-07-16 21:27:05 -07:00
mmap.c
mmapio.c
mtest.c libbacktrace: don't fail if symbol size is unknown 2024-07-11 17:58:17 -07:00
nounwind.c
pecoff.c libbacktrace: support FDPIC 2024-07-15 17:28:28 -07:00
posix.c
print.c
read.c
README libbacktrace: add notes about dl_iterate_phdr to README 2024-07-17 17:03:30 -07:00
simple.c
sort.c
state.c
stest.c
test_format.c
testlib.c
testlib.h
ttest.c
unittest.c
unknown.c
xcoff.c libbacktrace: update xcoff.c for base_address changes 2024-07-16 21:27:05 -07:00
xztest.c
zstdtest.c
ztest.c

The libbacktrace library
Initially written by Ian Lance Taylor <iant@golang.org>

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,
the 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.