glibc/sysdeps/nios2/__longjmp.S
Florian Weimer 88f4b6929c Introduce <pointer_guard.h>, extracted from <sysdep.h>
This allows us to define a generic no-op version of PTR_MANGLE and
PTR_DEMANGLE.  In the future, we can use PTR_MANGLE and PTR_DEMANGLE
unconditionally in C sources, avoiding an unintended loss of hardening
due to missing include files or unlucky header inclusion ordering.

In i386 and x86_64, we can avoid a <tls.h> dependency in the C
code by using the computed constant from <tcb-offsets.h>.  <sysdep.h>
no longer includes these definitions, so there is no cyclic dependency
anymore when computing the <tcb-offsets.h> constants.

Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
2022-10-18 17:03:55 +02:00

82 lines
2.0 KiB
ArmAsm

/* longjmp for Nios II.
Copyright (C) 2015-2022 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public License as
published by the Free Software Foundation; either version 2.1 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with the GNU C Library. If not, see
<https://www.gnu.org/licenses/>. */
#include <sysdep.h>
#include <pointer_guard.h>
#include <jmpbuf-offsets.h>
/* __longjmp(jmpbuf, val) */
ENTRY (__longjmp)
mov r2, r5
bne r5, zero, 1f
movi r2, 1
1:
#ifdef PTR_DEMANGLE
PTR_MANGLE_GUARD (r3)
ldw r5, (JB_RA*4)(r4)
ldw r6, (JB_SP*4)(r4)
PTR_DEMANGLE (r5, r5, r3)
PTR_DEMANGLE (r6, r6, r3)
#endif
cfi_def_cfa (r4, 0)
cfi_offset (r16, JB_R16*4)
cfi_offset (r17, JB_R17*4)
cfi_offset (r18, JB_R18*4)
cfi_offset (r19, JB_R19*4)
cfi_offset (r20, JB_R20*4)
cfi_offset (r21, JB_R21*4)
cfi_offset (r22, JB_R22*4)
cfi_offset (fp, JB_FP*4)
#ifdef PTR_DEMANGLE
cfi_register (ra, r5)
cfi_register (sp, r7)
#else
cfi_offset (ra, JB_RA*4)
cfi_offset (sp, JB_SP*4)
#endif
ldw r16, (JB_R16*4)(r4)
ldw r17, (JB_R17*4)(r4)
ldw r18, (JB_R18*4)(r4)
ldw r19, (JB_R19*4)(r4)
ldw r20, (JB_R20*4)(r4)
ldw r21, (JB_R21*4)(r4)
ldw r22, (JB_R22*4)(r4)
ldw fp, (JB_FP*4)(r4)
#ifdef PTR_DEMANGLE
mov ra, r5
mov sp, r6
#else
ldw ra, (JB_RA*4)(r4)
ldw sp, (JB_SP*4)(r4)
#endif
cfi_same_value (r16)
cfi_same_value (r17)
cfi_same_value (r18)
cfi_same_value (r19)
cfi_same_value (r20)
cfi_same_value (r21)
cfi_same_value (r22)
cfi_same_value (fp)
cfi_same_value (ra)
cfi_same_value (sp)
ret
END (__longjmp)