80a56cc3ee
Now the ARM port implements pointer encryption for jmpbufs, gdb needs a SystemTap probe point in longjmp to determine the target PC of a call to longjmp. This patch implements the probe point in longjmp and a similar probe point in setjmp. In order to have all the appropriate registers available to pass to the probe this reorders the layout of jmpbuf, putting the sp and lr registers at the start rather than the end, allowing them to be read and written sequentially. Tested on armv7, no new failures in the glibc testsuite and confirmed that this fixes the gdb.base/longjmp.exp failures in the gdb testsuite. ChangeLog: 2014-02-25 Will Newton <will.newton@linaro.org> * sysdeps/arm/__longjmp.S: Include stap-probe.h. (__longjmp): Restore sp and lr before restoring callee saved registers. Add longjmp and longjmp_target SystemTap probe point. * sysdeps/arm/bits/setjmp.h (__jmp_buf): Update comment. * sysdeps/arm/include/bits/setjmp.h (__JMP_BUF_SP): Define to zero to match jmpbuf layout. * sysdeps/arm/setjmp.S: Include stap-probe.h. (__sigsetjmp): Save sp and lr before saving callee saved registers. Add setjmp SystemTap probe point.
37 lines
1.4 KiB
C
37 lines
1.4 KiB
C
/* Copyright (C) 2004-2014 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
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
/* Define the machine-dependent type `jmp_buf'. ARM EABI version. */
|
|
|
|
#ifndef _BITS_SETJMP_H
|
|
#define _BITS_SETJMP_H 1
|
|
|
|
#if !defined _SETJMP_H && !defined _PTHREAD_H
|
|
# error "Never include <bits/setjmp.h> directly; use <setjmp.h> instead."
|
|
#endif
|
|
|
|
#ifndef __ASSEMBLER__
|
|
/* The exact set of registers saved may depend on the particular core
|
|
in use, as some coprocessor registers may need to be saved. The C
|
|
Library ABI requires that the buffer be 8-byte aligned, and
|
|
recommends that the buffer contain 64 words. The first 26 words
|
|
are occupied by sp, lr, v1-v6, sl, fp, and d8-d15. */
|
|
typedef int __jmp_buf[64] __attribute__((__aligned__ (8)));
|
|
#endif
|
|
|
|
#endif
|