2017-03-28 23:21:43 +08:00
|
|
|
.. _index:
|
|
|
|
|
|
|
|
=======================
|
|
|
|
libunwind LLVM Unwinder
|
|
|
|
=======================
|
|
|
|
|
|
|
|
Overview
|
|
|
|
========
|
|
|
|
|
|
|
|
libunwind is an implementation of the interface defined by the HP libunwind
|
|
|
|
project. It was contributed by Apple as a way to enable clang++ to port to
|
|
|
|
platforms that do not have a system unwinder. It is intended to be a small and
|
|
|
|
fast implementation of the ABI, leaving off some features of HP's libunwind
|
|
|
|
that never materialized (e.g. remote unwinding).
|
|
|
|
|
|
|
|
The unwinder has two levels of API. The high level APIs are the `_Unwind_*`
|
|
|
|
functions which implement functionality required by `__cxa_*` exception
|
2017-09-17 04:52:05 +08:00
|
|
|
functions. The low level APIs are the `unw_*` functions which are an interface
|
2017-03-28 23:21:43 +08:00
|
|
|
defined by the old HP libunwind project.
|
|
|
|
|
|
|
|
Getting Started with libunwind
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 2
|
|
|
|
|
|
|
|
BuildingLibunwind
|
|
|
|
|
|
|
|
Current Status
|
|
|
|
--------------
|
|
|
|
|
|
|
|
libunwind is a production-quality unwinder, with platform support for DWARF
|
|
|
|
unwind info, SjLj, and ARM EHABI.
|
|
|
|
|
|
|
|
The low level libunwind API was designed to work either in-process (aka local)
|
|
|
|
or to operate on another process (aka remote), but only the local path has been
|
|
|
|
implemented. Remote unwinding remains as future work.
|
|
|
|
|
|
|
|
Platform and Compiler Support
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
libunwind is known to work on the following platforms:
|
|
|
|
|
2017-11-16 15:16:36 +08:00
|
|
|
============ ======================== ============ ========================
|
|
|
|
OS Arch Compilers Unwind Info
|
|
|
|
============ ======================== ============ ========================
|
|
|
|
Any i386, x86_64, ARM Clang SjLj
|
|
|
|
Bare Metal ARM Clang, GCC EHABI
|
|
|
|
FreeBSD i386, x86_64, ARM64 Clang DWARF CFI
|
|
|
|
iOS ARM Clang SjLj
|
|
|
|
Linux ARM Clang, GCC EHABI
|
|
|
|
Linux i386, x86_64, ARM64 Clang, GCC DWARF CFI
|
[Docs] Modernize references to macOS
Summary:
This updates all places in documentation that refer to "Mac OS X", "OS X", etc.
to instead use the modern name "macOS" when no specific version number is
mentioned.
If a specific version is mentioned, this attempts to use the OS name at the time
of that version:
* Mac OS X for 10.0 - 10.7
* OS X for 10.8 - 10.11
* macOS for 10.12 - present
Reviewers: JDevlieghere
Subscribers: mgorny, christof, arphaman, cfe-commits, lldb-commits, libcxx-commits, llvm-commits
Tags: #clang, #lldb, #libc, #llvm
Differential Revision: https://reviews.llvm.org/D62654
llvm-svn: 362113
2019-05-31 00:46:22 +08:00
|
|
|
macOS i386, x86_64 Clang, GCC DWARF CFI
|
2017-11-16 15:16:36 +08:00
|
|
|
NetBSD x86_64 Clang, GCC DWARF CFI
|
|
|
|
Windows i386, x86_64, ARM, ARM64 Clang DWARF CFI
|
|
|
|
============ ======================== ============ ========================
|
2017-03-28 23:21:43 +08:00
|
|
|
|
|
|
|
The following minimum compiler versions are strongly recommended.
|
|
|
|
|
|
|
|
* Clang 3.5 and above
|
|
|
|
* GCC 4.7 and above.
|
|
|
|
|
|
|
|
Anything older *may* work.
|
|
|
|
|
|
|
|
Notes and Known Issues
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
* TODO
|
|
|
|
|
2017-04-04 03:23:11 +08:00
|
|
|
|
2017-03-28 23:21:43 +08:00
|
|
|
Getting Involved
|
|
|
|
================
|
|
|
|
|
2020-03-23 05:42:03 +08:00
|
|
|
First please review our `Developer's Policy <https://llvm.org/docs/DeveloperPolicy.html>`__
|
|
|
|
and `Getting started with LLVM <https://llvm.org/docs/GettingStarted.html>`__.
|
2017-03-28 23:21:43 +08:00
|
|
|
|
|
|
|
**Bug Reports**
|
|
|
|
|
|
|
|
If you think you've found a bug in libunwind, please report it using
|
2022-02-06 05:03:51 +08:00
|
|
|
the `LLVM bug tracker`_. If you're not sure, you
|
2022-03-23 22:10:20 +08:00
|
|
|
can ask for support on the `Runtimes forum`_ or on IRC.
|
|
|
|
Please use the tag "libunwind" for new threads.
|
2017-03-28 23:21:43 +08:00
|
|
|
|
|
|
|
**Patches**
|
|
|
|
|
|
|
|
If you want to contribute a patch to libunwind, the best place for that is
|
2020-03-23 05:42:03 +08:00
|
|
|
`Phabricator <https://llvm.org/docs/Phabricator.html>`_. Please include [libunwind] in the subject and
|
2022-03-23 22:10:20 +08:00
|
|
|
add `cfe-commits` as a subscriber. Also make sure you are subscribed to the `cfe-commits mailing list`_.
|
2017-03-28 23:21:43 +08:00
|
|
|
|
|
|
|
**Discussion and Questions**
|
|
|
|
|
2022-03-23 22:10:20 +08:00
|
|
|
Send discussions and questions to the `Runtimes forum`_. Please add the tag "libunwind" to your post.
|
2017-03-28 23:21:43 +08:00
|
|
|
|
|
|
|
|
|
|
|
Quick Links
|
|
|
|
===========
|
2020-03-23 05:42:03 +08:00
|
|
|
* `LLVM Homepage <https://llvm.org/>`_
|
2022-03-23 22:10:20 +08:00
|
|
|
* `LLVM Bug Tracker <https://github.com/llvm/llvm-project/labels/libunwind/>`_
|
|
|
|
* `cfe-dev Mailing List <http://lists.llvm.org/mailman/listinfo/cfe-dev>`_
|
|
|
|
* `cfe-commits Mailing List <http://lists.llvm.org/mailman/listinfo/cfe-commits>`_
|
|
|
|
* `Runtimes Forum <https://discourse.llvm.org/tags/c/runtimes>`_
|
2021-02-01 15:24:21 +08:00
|
|
|
* `Browse libunwind Sources <https://github.com/llvm/llvm-project/blob/main/libunwind/>`_
|