2021-11-18 05:25:01 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2015-07-19 23:23:10 +08:00
|
|
|
//
|
2019-01-19 18:56:40 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2015-07-19 23:23:10 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef ____LIBUNWIND_CONFIG_H__
|
|
|
|
#define ____LIBUNWIND_CONFIG_H__
|
|
|
|
|
2022-03-05 03:34:46 +08:00
|
|
|
#define _LIBUNWIND_VERSION 15000
|
|
|
|
|
2015-07-19 23:23:10 +08:00
|
|
|
#if defined(__arm__) && !defined(__USING_SJLJ_EXCEPTIONS__) && \
|
2022-05-07 05:26:45 +08:00
|
|
|
!defined(__ARM_DWARF_EH__) && !defined(__SEH__)
|
2017-03-31 23:28:06 +08:00
|
|
|
#define _LIBUNWIND_ARM_EHABI
|
2015-07-19 23:23:10 +08:00
|
|
|
#endif
|
|
|
|
|
2017-10-29 04:19:49 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_X86 8
|
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_X86_64 32
|
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_PPC 112
|
2018-01-17 04:54:10 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_PPC64 116
|
2017-10-29 04:19:49 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_ARM64 95
|
2017-11-02 16:16:16 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_ARM 287
|
[OR1K] Add the EPCR special-purpose register to register state.
This makes it possible to unwind hardware exception stack frames,
which necessarily save every register and so need an extra column
for storing the return address. CFI for the exception handler could
then look as follows:
.globl exception_vector
exception_vector:
.cfi_startproc
.cfi_signal_frame
.cfi_return_column 32
l.addi r1, r1, -0x100
.cfi_def_cfa_offset 0x100
l.sw 0x00(r1), r2
.cfi_offset 2, 0x00-0x100
l.sw 0x04(r1), r3
.cfi_offset 3, 0x04-0x100
l.sw 0x08(r1), r4
.cfi_offset 4, 0x08-0x100
l.mfspr r3, r0, SPR_EPCR_BASE
l.sw 0x78(r1), r3
.cfi_offset 32, 0x78-0x100
l.jal exception_handler
l.nop
l.lwz r2, 0x00(r1)
l.lwz r3, 0x04(r1)
l.lwz r4, 0x08(r1)
l.jr r9
l.nop
.cfi_endproc
This register could, of course, also be accessed by the trace
callback or personality function, if so desired.
llvm-svn: 332513
2018-05-17 03:09:48 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_OR1K 32
|
2017-12-13 05:43:36 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_MIPS 65
|
[Sparc] Add Sparc V8 support
Summary:
Adds the register class implementation for Sparc.
Adds support for DW_CFA_GNU_window_save.
Adds save and restore context functionality.
Adds getArch() function to each Registers_ class to be able to separate
between DW_CFA_AARCH64_negate_ra_state and DW_CFA_GNU_window_save which
are both represented by the same constant.
On Sparc the return address is the address of the call instruction, so
an offset needs to be added when returning to skip the call instruction
and its delay slot. If the function returns a struct it is also necessary
to skip one extra instruction on Sparc V8.
Reviewers: jyknight, mclow.lists, mstorsjo, compnerd
Reviewed By: jyknight, compnerd
Subscribers: jgorbe, mgorny, christof, llvm-commits, fedor.sergeev, JDevlieghere, ldionne, libcxx-commits
Differential Revision: https://reviews.llvm.org/D55763
llvm-svn: 351044
2019-01-14 18:15:20 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_SPARC 31
|
[libunwind] [sparc] Add SPARCv9 support
Adds libunwind support for SPARCv9 (aka sparc64). This is a rebase of @kettenis' patch D32450, which I created (with his permission) because the original review has become inactive.
The changes are of a cosmetic nature to make it fit better with the new code style, and to reuse the existing SPARCv8 code, whenever possible.
Please let me know if I posted this on the wrong place. Also, the summary of the original review is reproduced below:
> This adds unwinder support for 64-bit SPARC (aka SPARCv9). The implementation was done on OpenBSD/sparc64, so it takes StackGhost into account:
>
> https://www.usenix.org/legacy/publications/library/proceedings/sec01/full_papers/frantzen/frantzen_html/index.html
>
> Since StackGhost xor's return addresses with a random cookie before storing them on the stack, the unwinder has to do some extra work to recover those. This is done by introducing a new kRegisterInCFADecrypt "location" type that is used to implement the DW_CFA_GNU_window_save opcode. That implementation is SPARC-specific, but should work for 32-bit SPARC as well. DW_CFA_GNU_window_save is only ever generated on SPARC as far as I know.
Co-authored-by: Mark Kettenis
Reviewed By: #libunwind, thesamesam, MaskRay, Arfrever
Differential Revision: https://reviews.llvm.org/D116857
2022-02-06 05:08:26 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_SPARC64 31
|
2020-04-09 13:14:02 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_HEXAGON 34
|
[libunwind][RISCV] Add 64-bit RISC-V support
Summary:
Add unwinding support for 64-bit RISC-V.
This is from the FreeBSD implementation with the following minor
changes:
- Renamed and renumbered DWARF registers to match the RISC-V ABI [1]
- Use the ABI mneumonics in getRegisterName() instead of the exact
register names
- Include checks for __riscv_xlen == 64 to facilitate adding the 32-bit
ABI in the future.
[1] https://github.com/riscv/riscv-elf-psabi-doc/blob/master/riscv-elf.md
Patch by Mitchell Horne (mhorne)
Reviewers: lenary, luismarques, compnerd, phosek
Reviewed By: lenary, luismarques
Subscribers: arichardson, sameer.abuasal, abidh, asb, aprantl, krytarowski, simoncook, kito-cheng, christof, shiva0217, rogfer01, rkruppe, PkmX, psnobl, benna, lenary, s.egerton, luismarques, emaste, cfe-commits
Differential Revision: https://reviews.llvm.org/D68362
2019-12-17 00:35:17 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_RISCV 64
|
2020-12-26 21:50:17 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_VE 143
|
2022-05-02 20:35:29 +08:00
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER_S390X 83
|
2017-10-29 04:19:49 +08:00
|
|
|
|
2016-05-25 20:36:34 +08:00
|
|
|
#if defined(_LIBUNWIND_IS_NATIVE_ONLY)
|
[libunwind] Unwind through aarch64/Linux sigreturn frame
An AArch64 sigreturn trampoline frame can't currently be described
in a DWARF .eh_frame section, because the AArch64 DWARF spec currently
doesn't define a constant for the PC register. (PC and LR may need to
be restored to different values.)
Instead, use the same technique as libgcc or github.com/libunwind and
detect the sigreturn frame by looking for the sigreturn instructions:
mov x8, #0x8b
svc #0x0
If a sigreturn frame is detected, libunwind restores all the GPRs by
assuming that sp points at an rt_sigframe Linux kernel struct. This
behavior is a fallback mode that is only used if there is no ordinary
unwind info for sigreturn.
If libunwind can't find unwind info for a PC, it assumes that the PC is
readable, and would crash if it isn't. This could happen if:
- The PC points at a function compiled without unwind info, and which
is part of an execute-only mapping (e.g. using -Wl,--execute-only).
- The PC is invalid and happens to point to unreadable or unmapped
memory.
In the tests, ignore a failed dladdr call so that the tests can run on
user-mode qemu for AArch64, which uses a stack-allocated trampoline
instead of a vDSO.
Reviewed By: danielkiss, compnerd, #libunwind
Differential Revision: https://reviews.llvm.org/D90898
2021-01-14 08:38:36 +08:00
|
|
|
# if defined(__linux__)
|
|
|
|
# define _LIBUNWIND_TARGET_LINUX 1
|
|
|
|
# endif
|
2016-05-25 20:36:34 +08:00
|
|
|
# if defined(__i386__)
|
2017-03-31 23:28:06 +08:00
|
|
|
# define _LIBUNWIND_TARGET_I386
|
2016-05-25 20:36:34 +08:00
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 8
|
2017-10-31 03:06:34 +08:00
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 15
|
2017-10-29 04:19:49 +08:00
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_X86
|
2016-05-25 20:36:34 +08:00
|
|
|
# elif defined(__x86_64__)
|
|
|
|
# define _LIBUNWIND_TARGET_X86_64 1
|
2017-10-27 16:11:36 +08:00
|
|
|
# if defined(_WIN64)
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 54
|
Add support for SEH unwinding on Windows.
Summary:
I've tested this implementation on x86-64 to ensure that it works. All
`libc++abi` tests pass, as do all `libc++` exception-related tests. ARM
still remains to be implemented (@compnerd?).
Special thanks to KJK::Hyperion for his excellent series of articles on
how EH works on x86-64 Windows. (Seriously, check it out. It's awesome.)
I'm actually not sure if this should go in as is. I particularly don't
like that I duplicated the UnwindCursor class for this special case.
Reviewers: mstorsjo, rnk, compnerd, smeenai, javed.absar
Subscribers: mgorny, kristof.beyls, christof, chrib, cfe-commits, compnerd, llvm-commits
Differential Revision: https://reviews.llvm.org/D50564
llvm-svn: 341125
2018-08-31 05:29:00 +08:00
|
|
|
# ifdef __SEH__
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 204
|
|
|
|
# else
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 66
|
|
|
|
# endif
|
2017-10-27 16:11:36 +08:00
|
|
|
# else
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 21
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 33
|
|
|
|
# endif
|
2017-10-29 04:19:49 +08:00
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_X86_64
|
2018-01-03 06:11:30 +08:00
|
|
|
# elif defined(__powerpc64__)
|
|
|
|
# define _LIBUNWIND_TARGET_PPC64 1
|
2018-01-17 04:54:10 +08:00
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 167
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 179
|
2018-01-03 06:11:30 +08:00
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_PPC64
|
2022-01-28 05:48:38 +08:00
|
|
|
# elif defined(__powerpc__)
|
2016-05-25 20:36:34 +08:00
|
|
|
# define _LIBUNWIND_TARGET_PPC 1
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 117
|
2017-10-31 03:06:34 +08:00
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 124
|
2017-10-29 04:19:49 +08:00
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_PPC
|
2016-05-25 20:36:34 +08:00
|
|
|
# elif defined(__aarch64__)
|
|
|
|
# define _LIBUNWIND_TARGET_AARCH64 1
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 66
|
2018-12-19 04:05:59 +08:00
|
|
|
# if defined(__SEH__)
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 164
|
|
|
|
# else
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 78
|
|
|
|
# endif
|
2017-10-29 04:19:49 +08:00
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_ARM64
|
2016-05-25 20:36:34 +08:00
|
|
|
# elif defined(__arm__)
|
|
|
|
# define _LIBUNWIND_TARGET_ARM 1
|
Add support for SEH unwinding on Windows.
Summary:
I've tested this implementation on x86-64 to ensure that it works. All
`libc++abi` tests pass, as do all `libc++` exception-related tests. ARM
still remains to be implemented (@compnerd?).
Special thanks to KJK::Hyperion for his excellent series of articles on
how EH works on x86-64 Windows. (Seriously, check it out. It's awesome.)
I'm actually not sure if this should go in as is. I particularly don't
like that I duplicated the UnwindCursor class for this special case.
Reviewers: mstorsjo, rnk, compnerd, smeenai, javed.absar
Subscribers: mgorny, kristof.beyls, christof, chrib, cfe-commits, compnerd, llvm-commits
Differential Revision: https://reviews.llvm.org/D50564
llvm-svn: 341125
2018-08-31 05:29:00 +08:00
|
|
|
# if defined(__SEH__)
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 42
|
2018-08-31 22:56:55 +08:00
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 80
|
Add support for SEH unwinding on Windows.
Summary:
I've tested this implementation on x86-64 to ensure that it works. All
`libc++abi` tests pass, as do all `libc++` exception-related tests. ARM
still remains to be implemented (@compnerd?).
Special thanks to KJK::Hyperion for his excellent series of articles on
how EH works on x86-64 Windows. (Seriously, check it out. It's awesome.)
I'm actually not sure if this should go in as is. I particularly don't
like that I duplicated the UnwindCursor class for this special case.
Reviewers: mstorsjo, rnk, compnerd, smeenai, javed.absar
Subscribers: mgorny, kristof.beyls, christof, chrib, cfe-commits, compnerd, llvm-commits
Differential Revision: https://reviews.llvm.org/D50564
llvm-svn: 341125
2018-08-31 05:29:00 +08:00
|
|
|
# elif defined(__ARM_WMMX)
|
2017-10-25 16:07:19 +08:00
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 61
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 68
|
2016-07-07 18:55:39 +08:00
|
|
|
# else
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 42
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 49
|
|
|
|
# endif
|
2017-10-29 04:19:49 +08:00
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_ARM
|
2016-05-25 20:36:34 +08:00
|
|
|
# elif defined(__or1k__)
|
|
|
|
# define _LIBUNWIND_TARGET_OR1K 1
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 16
|
2017-10-31 03:06:34 +08:00
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 24
|
2017-10-29 04:19:49 +08:00
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_OR1K
|
2020-04-09 13:14:02 +08:00
|
|
|
# elif defined(__hexagon__)
|
|
|
|
# define _LIBUNWIND_TARGET_HEXAGON 1
|
|
|
|
// Values here change when : Registers.hpp - hexagon_thread_state_t change
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 18
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 24
|
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_HEXAGON
|
2017-12-13 05:43:36 +08:00
|
|
|
# elif defined(__mips__)
|
2018-05-16 06:44:56 +08:00
|
|
|
# if defined(_ABIO32) && _MIPS_SIM == _ABIO32
|
2017-12-13 05:43:36 +08:00
|
|
|
# define _LIBUNWIND_TARGET_MIPS_O32 1
|
2018-05-16 06:44:56 +08:00
|
|
|
# if defined(__mips_hard_float)
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 50
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 57
|
|
|
|
# else
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 18
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 24
|
|
|
|
# endif
|
|
|
|
# elif defined(_ABIN32) && _MIPS_SIM == _ABIN32
|
2018-02-28 05:24:02 +08:00
|
|
|
# define _LIBUNWIND_TARGET_MIPS_NEWABI 1
|
2018-05-16 06:44:56 +08:00
|
|
|
# if defined(__mips_hard_float)
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 67
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 74
|
|
|
|
# else
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 35
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 42
|
|
|
|
# endif
|
|
|
|
# elif defined(_ABI64) && _MIPS_SIM == _ABI64
|
2018-01-10 01:07:18 +08:00
|
|
|
# define _LIBUNWIND_TARGET_MIPS_NEWABI 1
|
2018-05-16 06:44:56 +08:00
|
|
|
# if defined(__mips_hard_float)
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 67
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 79
|
|
|
|
# else
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 35
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 47
|
|
|
|
# endif
|
2017-12-13 05:43:36 +08:00
|
|
|
# else
|
|
|
|
# error "Unsupported MIPS ABI and/or environment"
|
|
|
|
# endif
|
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_MIPS
|
[libunwind] [sparc] Add SPARCv9 support
Adds libunwind support for SPARCv9 (aka sparc64). This is a rebase of @kettenis' patch D32450, which I created (with his permission) because the original review has become inactive.
The changes are of a cosmetic nature to make it fit better with the new code style, and to reuse the existing SPARCv8 code, whenever possible.
Please let me know if I posted this on the wrong place. Also, the summary of the original review is reproduced below:
> This adds unwinder support for 64-bit SPARC (aka SPARCv9). The implementation was done on OpenBSD/sparc64, so it takes StackGhost into account:
>
> https://www.usenix.org/legacy/publications/library/proceedings/sec01/full_papers/frantzen/frantzen_html/index.html
>
> Since StackGhost xor's return addresses with a random cookie before storing them on the stack, the unwinder has to do some extra work to recover those. This is done by introducing a new kRegisterInCFADecrypt "location" type that is used to implement the DW_CFA_GNU_window_save opcode. That implementation is SPARC-specific, but should work for 32-bit SPARC as well. DW_CFA_GNU_window_save is only ever generated on SPARC as far as I know.
Co-authored-by: Mark Kettenis
Reviewed By: #libunwind, thesamesam, MaskRay, Arfrever
Differential Revision: https://reviews.llvm.org/D116857
2022-02-06 05:08:26 +08:00
|
|
|
#elif defined(__sparc__) && defined(__arch64__)
|
|
|
|
#define _LIBUNWIND_TARGET_SPARC64 1
|
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER \
|
|
|
|
_LIBUNWIND_HIGHEST_DWARF_REGISTER_SPARC64
|
|
|
|
#define _LIBUNWIND_CONTEXT_SIZE 33
|
|
|
|
#define _LIBUNWIND_CURSOR_SIZE 45
|
[Sparc] Add Sparc V8 support
Summary:
Adds the register class implementation for Sparc.
Adds support for DW_CFA_GNU_window_save.
Adds save and restore context functionality.
Adds getArch() function to each Registers_ class to be able to separate
between DW_CFA_AARCH64_negate_ra_state and DW_CFA_GNU_window_save which
are both represented by the same constant.
On Sparc the return address is the address of the call instruction, so
an offset needs to be added when returning to skip the call instruction
and its delay slot. If the function returns a struct it is also necessary
to skip one extra instruction on Sparc V8.
Reviewers: jyknight, mclow.lists, mstorsjo, compnerd
Reviewed By: jyknight, compnerd
Subscribers: jgorbe, mgorny, christof, llvm-commits, fedor.sergeev, JDevlieghere, ldionne, libcxx-commits
Differential Revision: https://reviews.llvm.org/D55763
llvm-svn: 351044
2019-01-14 18:15:20 +08:00
|
|
|
# elif defined(__sparc__)
|
|
|
|
#define _LIBUNWIND_TARGET_SPARC 1
|
|
|
|
#define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_SPARC
|
|
|
|
#define _LIBUNWIND_CONTEXT_SIZE 16
|
|
|
|
#define _LIBUNWIND_CURSOR_SIZE 23
|
[libunwind][RISCV] Add 64-bit RISC-V support
Summary:
Add unwinding support for 64-bit RISC-V.
This is from the FreeBSD implementation with the following minor
changes:
- Renamed and renumbered DWARF registers to match the RISC-V ABI [1]
- Use the ABI mneumonics in getRegisterName() instead of the exact
register names
- Include checks for __riscv_xlen == 64 to facilitate adding the 32-bit
ABI in the future.
[1] https://github.com/riscv/riscv-elf-psabi-doc/blob/master/riscv-elf.md
Patch by Mitchell Horne (mhorne)
Reviewers: lenary, luismarques, compnerd, phosek
Reviewed By: lenary, luismarques
Subscribers: arichardson, sameer.abuasal, abidh, asb, aprantl, krytarowski, simoncook, kito-cheng, christof, shiva0217, rogfer01, rkruppe, PkmX, psnobl, benna, lenary, s.egerton, luismarques, emaste, cfe-commits
Differential Revision: https://reviews.llvm.org/D68362
2019-12-17 00:35:17 +08:00
|
|
|
# elif defined(__riscv)
|
2021-03-02 09:27:54 +08:00
|
|
|
# define _LIBUNWIND_TARGET_RISCV 1
|
|
|
|
# if defined(__riscv_flen)
|
|
|
|
# define RISCV_FLEN __riscv_flen
|
[libunwind][RISCV] Add 64-bit RISC-V support
Summary:
Add unwinding support for 64-bit RISC-V.
This is from the FreeBSD implementation with the following minor
changes:
- Renamed and renumbered DWARF registers to match the RISC-V ABI [1]
- Use the ABI mneumonics in getRegisterName() instead of the exact
register names
- Include checks for __riscv_xlen == 64 to facilitate adding the 32-bit
ABI in the future.
[1] https://github.com/riscv/riscv-elf-psabi-doc/blob/master/riscv-elf.md
Patch by Mitchell Horne (mhorne)
Reviewers: lenary, luismarques, compnerd, phosek
Reviewed By: lenary, luismarques
Subscribers: arichardson, sameer.abuasal, abidh, asb, aprantl, krytarowski, simoncook, kito-cheng, christof, shiva0217, rogfer01, rkruppe, PkmX, psnobl, benna, lenary, s.egerton, luismarques, emaste, cfe-commits
Differential Revision: https://reviews.llvm.org/D68362
2019-12-17 00:35:17 +08:00
|
|
|
# else
|
2021-03-02 09:27:54 +08:00
|
|
|
# define RISCV_FLEN 0
|
|
|
|
# endif
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE (32 * (__riscv_xlen + RISCV_FLEN) / 64)
|
|
|
|
# if __riscv_xlen == 32
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE (_LIBUNWIND_CONTEXT_SIZE + 7)
|
|
|
|
# elif __riscv_xlen == 64
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE (_LIBUNWIND_CONTEXT_SIZE + 12)
|
|
|
|
# else
|
|
|
|
# error "Unsupported RISC-V ABI"
|
[libunwind][RISCV] Add 64-bit RISC-V support
Summary:
Add unwinding support for 64-bit RISC-V.
This is from the FreeBSD implementation with the following minor
changes:
- Renamed and renumbered DWARF registers to match the RISC-V ABI [1]
- Use the ABI mneumonics in getRegisterName() instead of the exact
register names
- Include checks for __riscv_xlen == 64 to facilitate adding the 32-bit
ABI in the future.
[1] https://github.com/riscv/riscv-elf-psabi-doc/blob/master/riscv-elf.md
Patch by Mitchell Horne (mhorne)
Reviewers: lenary, luismarques, compnerd, phosek
Reviewed By: lenary, luismarques
Subscribers: arichardson, sameer.abuasal, abidh, asb, aprantl, krytarowski, simoncook, kito-cheng, christof, shiva0217, rogfer01, rkruppe, PkmX, psnobl, benna, lenary, s.egerton, luismarques, emaste, cfe-commits
Differential Revision: https://reviews.llvm.org/D68362
2019-12-17 00:35:17 +08:00
|
|
|
# endif
|
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_RISCV
|
2020-12-26 21:50:17 +08:00
|
|
|
# elif defined(__ve__)
|
|
|
|
# define _LIBUNWIND_TARGET_VE 1
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 67
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 79
|
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_VE
|
2022-05-02 20:35:29 +08:00
|
|
|
# elif defined(__s390x__)
|
|
|
|
# define _LIBUNWIND_TARGET_S390X 1
|
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 34
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 46
|
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER _LIBUNWIND_HIGHEST_DWARF_REGISTER_S390X
|
2016-05-25 20:36:34 +08:00
|
|
|
# else
|
|
|
|
# error "Unsupported architecture."
|
|
|
|
# endif
|
|
|
|
#else // !_LIBUNWIND_IS_NATIVE_ONLY
|
2017-03-31 23:28:06 +08:00
|
|
|
# define _LIBUNWIND_TARGET_I386
|
2016-05-25 20:36:34 +08:00
|
|
|
# define _LIBUNWIND_TARGET_X86_64 1
|
|
|
|
# define _LIBUNWIND_TARGET_PPC 1
|
2018-01-03 06:11:30 +08:00
|
|
|
# define _LIBUNWIND_TARGET_PPC64 1
|
2016-05-25 20:36:34 +08:00
|
|
|
# define _LIBUNWIND_TARGET_AARCH64 1
|
|
|
|
# define _LIBUNWIND_TARGET_ARM 1
|
|
|
|
# define _LIBUNWIND_TARGET_OR1K 1
|
2017-12-13 05:43:36 +08:00
|
|
|
# define _LIBUNWIND_TARGET_MIPS_O32 1
|
2018-01-10 01:07:18 +08:00
|
|
|
# define _LIBUNWIND_TARGET_MIPS_NEWABI 1
|
[Sparc] Add Sparc V8 support
Summary:
Adds the register class implementation for Sparc.
Adds support for DW_CFA_GNU_window_save.
Adds save and restore context functionality.
Adds getArch() function to each Registers_ class to be able to separate
between DW_CFA_AARCH64_negate_ra_state and DW_CFA_GNU_window_save which
are both represented by the same constant.
On Sparc the return address is the address of the call instruction, so
an offset needs to be added when returning to skip the call instruction
and its delay slot. If the function returns a struct it is also necessary
to skip one extra instruction on Sparc V8.
Reviewers: jyknight, mclow.lists, mstorsjo, compnerd
Reviewed By: jyknight, compnerd
Subscribers: jgorbe, mgorny, christof, llvm-commits, fedor.sergeev, JDevlieghere, ldionne, libcxx-commits
Differential Revision: https://reviews.llvm.org/D55763
llvm-svn: 351044
2019-01-14 18:15:20 +08:00
|
|
|
# define _LIBUNWIND_TARGET_SPARC 1
|
[libunwind] [sparc] Add SPARCv9 support
Adds libunwind support for SPARCv9 (aka sparc64). This is a rebase of @kettenis' patch D32450, which I created (with his permission) because the original review has become inactive.
The changes are of a cosmetic nature to make it fit better with the new code style, and to reuse the existing SPARCv8 code, whenever possible.
Please let me know if I posted this on the wrong place. Also, the summary of the original review is reproduced below:
> This adds unwinder support for 64-bit SPARC (aka SPARCv9). The implementation was done on OpenBSD/sparc64, so it takes StackGhost into account:
>
> https://www.usenix.org/legacy/publications/library/proceedings/sec01/full_papers/frantzen/frantzen_html/index.html
>
> Since StackGhost xor's return addresses with a random cookie before storing them on the stack, the unwinder has to do some extra work to recover those. This is done by introducing a new kRegisterInCFADecrypt "location" type that is used to implement the DW_CFA_GNU_window_save opcode. That implementation is SPARC-specific, but should work for 32-bit SPARC as well. DW_CFA_GNU_window_save is only ever generated on SPARC as far as I know.
Co-authored-by: Mark Kettenis
Reviewed By: #libunwind, thesamesam, MaskRay, Arfrever
Differential Revision: https://reviews.llvm.org/D116857
2022-02-06 05:08:26 +08:00
|
|
|
# define _LIBUNWIND_TARGET_SPARC64 1
|
2020-04-09 13:14:02 +08:00
|
|
|
# define _LIBUNWIND_TARGET_HEXAGON 1
|
[libunwind][RISCV] Add 64-bit RISC-V support
Summary:
Add unwinding support for 64-bit RISC-V.
This is from the FreeBSD implementation with the following minor
changes:
- Renamed and renumbered DWARF registers to match the RISC-V ABI [1]
- Use the ABI mneumonics in getRegisterName() instead of the exact
register names
- Include checks for __riscv_xlen == 64 to facilitate adding the 32-bit
ABI in the future.
[1] https://github.com/riscv/riscv-elf-psabi-doc/blob/master/riscv-elf.md
Patch by Mitchell Horne (mhorne)
Reviewers: lenary, luismarques, compnerd, phosek
Reviewed By: lenary, luismarques
Subscribers: arichardson, sameer.abuasal, abidh, asb, aprantl, krytarowski, simoncook, kito-cheng, christof, shiva0217, rogfer01, rkruppe, PkmX, psnobl, benna, lenary, s.egerton, luismarques, emaste, cfe-commits
Differential Revision: https://reviews.llvm.org/D68362
2019-12-17 00:35:17 +08:00
|
|
|
# define _LIBUNWIND_TARGET_RISCV 1
|
2020-12-26 21:50:17 +08:00
|
|
|
# define _LIBUNWIND_TARGET_VE 1
|
2022-05-02 20:35:29 +08:00
|
|
|
# define _LIBUNWIND_TARGET_S390X 1
|
2018-01-17 04:54:10 +08:00
|
|
|
# define _LIBUNWIND_CONTEXT_SIZE 167
|
|
|
|
# define _LIBUNWIND_CURSOR_SIZE 179
|
2017-11-02 16:16:16 +08:00
|
|
|
# define _LIBUNWIND_HIGHEST_DWARF_REGISTER 287
|
2016-05-25 20:36:34 +08:00
|
|
|
#endif // _LIBUNWIND_IS_NATIVE_ONLY
|
|
|
|
|
2015-07-19 23:23:10 +08:00
|
|
|
#endif // ____LIBUNWIND_CONFIG_H__
|