This patch contains the following cleanups for the asm/ptrace.h
userspace headers:
- include/asm-generic/Kbuild.asm already lists ptrace.h, remove
the superfluous listings in the Kbuild files of the following
architectures:
- cris
- frv
- powerpc
- x86
- don't expose function prototypes and macros to userspace:
- arm
- blackfin
- cris
- mn10300
- parisc
- remove #ifdef CONFIG_'s around #define's:
- blackfin
- m68knommu
- sh: AFAIK __SH5__ should work in both kernel and userspace,
no need to leak CONFIG_SUPERH64 to userspace
- xtensa: cosmetical change to remove empty
#ifndef __ASSEMBLY__ #else #endif
from the userspace headers
Not changed by this patch is the fact that the following architectures
have a different struct pt_regs depending on CONFIG_ variables:
- h8300
- m68knommu
- mips
This does not work in userspace.
Signed-off-by: Adrian Bunk <bunk@kernel.org>
Cc: <linux-arch@vger.kernel.org>
Cc: Roland McGrath <roland@redhat.com>
Cc: Oleg Nesterov <oleg@tv-sign.ru>
Acked-by: Greg Ungerer <gerg@uclinux.org>
Acked-by: Paul Mundt <lethal@linux-sh.org>
Acked-by: Grant Grundler <grundler@parisc-linux.org>
Acked-by: Jesper Nilsson <jesper.nilsson@axis.com>
Acked-by: Chris Zankel <chris@zankel.net>
Acked-by: David Howells <dhowells@redhat.com>
Acked-by: Paul Mackerras <paulus@samba.org>
Acked-by: Russell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
58 lines
1.7 KiB
C
58 lines
1.7 KiB
C
#ifndef _PARISC_PTRACE_H
|
|
#define _PARISC_PTRACE_H
|
|
|
|
/* written by Philipp Rumpf, Copyright (C) 1999 SuSE GmbH Nuernberg
|
|
** Copyright (C) 2000 Grant Grundler, Hewlett-Packard
|
|
*/
|
|
|
|
#include <linux/types.h>
|
|
|
|
/* This struct defines the way the registers are stored on the
|
|
* stack during a system call.
|
|
*
|
|
* N.B. gdb/strace care about the size and offsets within this
|
|
* structure. If you change things, you may break object compatibility
|
|
* for those applications.
|
|
*/
|
|
|
|
struct pt_regs {
|
|
unsigned long gr[32]; /* PSW is in gr[0] */
|
|
__u64 fr[32];
|
|
unsigned long sr[ 8];
|
|
unsigned long iasq[2];
|
|
unsigned long iaoq[2];
|
|
unsigned long cr27;
|
|
unsigned long pad0; /* available for other uses */
|
|
unsigned long orig_r28;
|
|
unsigned long ksp;
|
|
unsigned long kpc;
|
|
unsigned long sar; /* CR11 */
|
|
unsigned long iir; /* CR19 */
|
|
unsigned long isr; /* CR20 */
|
|
unsigned long ior; /* CR21 */
|
|
unsigned long ipsw; /* CR22 */
|
|
};
|
|
|
|
/*
|
|
* The numbers chosen here are somewhat arbitrary but absolutely MUST
|
|
* not overlap with any of the number assigned in <linux/ptrace.h>.
|
|
*
|
|
* These ones are taken from IA-64 on the assumption that theirs are
|
|
* the most correct (and we also want to support PTRACE_SINGLEBLOCK
|
|
* since we have taken branch traps too)
|
|
*/
|
|
#define PTRACE_SINGLEBLOCK 12 /* resume execution until next branch */
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
#define task_regs(task) ((struct pt_regs *) ((char *)(task) + TASK_REGS))
|
|
|
|
/* XXX should we use iaoq[1] or iaoq[0] ? */
|
|
#define user_mode(regs) (((regs)->iaoq[0] & 3) ? 1 : 0)
|
|
#define user_space(regs) (((regs)->iasq[1] != 0) ? 1 : 0)
|
|
#define instruction_pointer(regs) ((regs)->iaoq[0] & ~3)
|
|
unsigned long profile_pc(struct pt_regs *);
|
|
extern void show_regs(struct pt_regs *);
|
|
#endif
|
|
|
|
#endif
|