mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 22:50:41 +00:00
[PATCH] Split i386 and x86_64 ptrace.h
The use of SEGMENT_RPL_MASK in the i386 ptrace.h introduced by x86-allow-a-kernel-to-not-be-in-ring-0.patch broke the UML build, as UML includes the underlying architecture's ptrace.h, but has no easy access to the x86 segment definitions. Rather than kludging around this, as in the past, this patch splits the userspace-usable parts, which are the bits that UML needs, of ptrace.h into ptrace-abi.h, which is included back into ptrace.h. Thus, there is no net effect on i386. As a side-effect, this creates a ptrace header which is close to being usable in /usr/include. x86_64 is also treated in this way for consistency. There was some trailing whitespace there, which is cleaned up. Signed-off-by: Jeff Dike <jdike@addtoit.com> Cc: David Woodhouse <dwmw2@infradead.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
b1fc0b1f21
commit
70e0eb8ef1
@ -3,6 +3,7 @@ include include/asm-generic/Kbuild.asm
|
|||||||
header-y += boot.h
|
header-y += boot.h
|
||||||
header-y += debugreg.h
|
header-y += debugreg.h
|
||||||
header-y += ldt.h
|
header-y += ldt.h
|
||||||
|
header-y += ptrace-abi.h
|
||||||
header-y += ucontext.h
|
header-y += ucontext.h
|
||||||
|
|
||||||
unifdef-y += mtrr.h
|
unifdef-y += mtrr.h
|
||||||
|
39
include/asm-i386/ptrace-abi.h
Normal file
39
include/asm-i386/ptrace-abi.h
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
#ifndef I386_PTRACE_ABI_H
|
||||||
|
#define I386_PTRACE_ABI_H
|
||||||
|
|
||||||
|
#define EBX 0
|
||||||
|
#define ECX 1
|
||||||
|
#define EDX 2
|
||||||
|
#define ESI 3
|
||||||
|
#define EDI 4
|
||||||
|
#define EBP 5
|
||||||
|
#define EAX 6
|
||||||
|
#define DS 7
|
||||||
|
#define ES 8
|
||||||
|
#define FS 9
|
||||||
|
#define GS 10
|
||||||
|
#define ORIG_EAX 11
|
||||||
|
#define EIP 12
|
||||||
|
#define CS 13
|
||||||
|
#define EFL 14
|
||||||
|
#define UESP 15
|
||||||
|
#define SS 16
|
||||||
|
#define FRAME_SIZE 17
|
||||||
|
|
||||||
|
/* Arbitrarily choose the same ptrace numbers as used by the Sparc code. */
|
||||||
|
#define PTRACE_GETREGS 12
|
||||||
|
#define PTRACE_SETREGS 13
|
||||||
|
#define PTRACE_GETFPREGS 14
|
||||||
|
#define PTRACE_SETFPREGS 15
|
||||||
|
#define PTRACE_GETFPXREGS 18
|
||||||
|
#define PTRACE_SETFPXREGS 19
|
||||||
|
|
||||||
|
#define PTRACE_OLDSETOPTIONS 21
|
||||||
|
|
||||||
|
#define PTRACE_GET_THREAD_AREA 25
|
||||||
|
#define PTRACE_SET_THREAD_AREA 26
|
||||||
|
|
||||||
|
#define PTRACE_SYSEMU 31
|
||||||
|
#define PTRACE_SYSEMU_SINGLESTEP 32
|
||||||
|
|
||||||
|
#endif
|
@ -1,24 +1,7 @@
|
|||||||
#ifndef _I386_PTRACE_H
|
#ifndef _I386_PTRACE_H
|
||||||
#define _I386_PTRACE_H
|
#define _I386_PTRACE_H
|
||||||
|
|
||||||
#define EBX 0
|
#include <asm/ptrace-abi.h>
|
||||||
#define ECX 1
|
|
||||||
#define EDX 2
|
|
||||||
#define ESI 3
|
|
||||||
#define EDI 4
|
|
||||||
#define EBP 5
|
|
||||||
#define EAX 6
|
|
||||||
#define DS 7
|
|
||||||
#define ES 8
|
|
||||||
#define FS 9
|
|
||||||
#define GS 10
|
|
||||||
#define ORIG_EAX 11
|
|
||||||
#define EIP 12
|
|
||||||
#define CS 13
|
|
||||||
#define EFL 14
|
|
||||||
#define UESP 15
|
|
||||||
#define SS 16
|
|
||||||
#define FRAME_SIZE 17
|
|
||||||
|
|
||||||
/* this struct defines the way the registers are stored on the
|
/* this struct defines the way the registers are stored on the
|
||||||
stack during a system call. */
|
stack during a system call. */
|
||||||
@ -41,22 +24,6 @@ struct pt_regs {
|
|||||||
int xss;
|
int xss;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Arbitrarily choose the same ptrace numbers as used by the Sparc code. */
|
|
||||||
#define PTRACE_GETREGS 12
|
|
||||||
#define PTRACE_SETREGS 13
|
|
||||||
#define PTRACE_GETFPREGS 14
|
|
||||||
#define PTRACE_SETFPREGS 15
|
|
||||||
#define PTRACE_GETFPXREGS 18
|
|
||||||
#define PTRACE_SETFPXREGS 19
|
|
||||||
|
|
||||||
#define PTRACE_OLDSETOPTIONS 21
|
|
||||||
|
|
||||||
#define PTRACE_GET_THREAD_AREA 25
|
|
||||||
#define PTRACE_SET_THREAD_AREA 26
|
|
||||||
|
|
||||||
#define PTRACE_SYSEMU 31
|
|
||||||
#define PTRACE_SYSEMU_SINGLESTEP 32
|
|
||||||
|
|
||||||
#ifdef __KERNEL__
|
#ifdef __KERNEL__
|
||||||
|
|
||||||
#include <asm/vm86.h>
|
#include <asm/vm86.h>
|
||||||
|
@ -11,6 +11,7 @@ header-y += debugreg.h
|
|||||||
header-y += ldt.h
|
header-y += ldt.h
|
||||||
header-y += msr.h
|
header-y += msr.h
|
||||||
header-y += prctl.h
|
header-y += prctl.h
|
||||||
|
header-y += ptrace-abi.h
|
||||||
header-y += setup.h
|
header-y += setup.h
|
||||||
header-y += sigcontext32.h
|
header-y += sigcontext32.h
|
||||||
header-y += ucontext.h
|
header-y += ucontext.h
|
||||||
|
51
include/asm-x86_64/ptrace-abi.h
Normal file
51
include/asm-x86_64/ptrace-abi.h
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
#ifndef _X86_64_PTRACE_ABI_H
|
||||||
|
#define _X86_64_PTRACE_ABI_H
|
||||||
|
|
||||||
|
#if defined(__ASSEMBLY__) || defined(__FRAME_OFFSETS)
|
||||||
|
#define R15 0
|
||||||
|
#define R14 8
|
||||||
|
#define R13 16
|
||||||
|
#define R12 24
|
||||||
|
#define RBP 32
|
||||||
|
#define RBX 40
|
||||||
|
/* arguments: interrupts/non tracing syscalls only save upto here*/
|
||||||
|
#define R11 48
|
||||||
|
#define R10 56
|
||||||
|
#define R9 64
|
||||||
|
#define R8 72
|
||||||
|
#define RAX 80
|
||||||
|
#define RCX 88
|
||||||
|
#define RDX 96
|
||||||
|
#define RSI 104
|
||||||
|
#define RDI 112
|
||||||
|
#define ORIG_RAX 120 /* = ERROR */
|
||||||
|
/* end of arguments */
|
||||||
|
/* cpu exception frame or undefined in case of fast syscall. */
|
||||||
|
#define RIP 128
|
||||||
|
#define CS 136
|
||||||
|
#define EFLAGS 144
|
||||||
|
#define RSP 152
|
||||||
|
#define SS 160
|
||||||
|
#define ARGOFFSET R11
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
|
|
||||||
|
/* top of stack page */
|
||||||
|
#define FRAME_SIZE 168
|
||||||
|
|
||||||
|
#define PTRACE_OLDSETOPTIONS 21
|
||||||
|
|
||||||
|
/* Arbitrarily choose the same ptrace numbers as used by the Sparc code. */
|
||||||
|
#define PTRACE_GETREGS 12
|
||||||
|
#define PTRACE_SETREGS 13
|
||||||
|
#define PTRACE_GETFPREGS 14
|
||||||
|
#define PTRACE_SETFPREGS 15
|
||||||
|
#define PTRACE_GETFPXREGS 18
|
||||||
|
#define PTRACE_SETFPXREGS 19
|
||||||
|
|
||||||
|
/* only useful for access 32bit programs */
|
||||||
|
#define PTRACE_GET_THREAD_AREA 25
|
||||||
|
#define PTRACE_SET_THREAD_AREA 26
|
||||||
|
|
||||||
|
#define PTRACE_ARCH_PRCTL 30 /* arch_prctl for child */
|
||||||
|
|
||||||
|
#endif
|
@ -1,40 +1,9 @@
|
|||||||
#ifndef _X86_64_PTRACE_H
|
#ifndef _X86_64_PTRACE_H
|
||||||
#define _X86_64_PTRACE_H
|
#define _X86_64_PTRACE_H
|
||||||
|
|
||||||
#if defined(__ASSEMBLY__) || defined(__FRAME_OFFSETS)
|
#include <asm/ptrace-abi.h>
|
||||||
#define R15 0
|
|
||||||
#define R14 8
|
|
||||||
#define R13 16
|
|
||||||
#define R12 24
|
|
||||||
#define RBP 32
|
|
||||||
#define RBX 40
|
|
||||||
/* arguments: interrupts/non tracing syscalls only save upto here*/
|
|
||||||
#define R11 48
|
|
||||||
#define R10 56
|
|
||||||
#define R9 64
|
|
||||||
#define R8 72
|
|
||||||
#define RAX 80
|
|
||||||
#define RCX 88
|
|
||||||
#define RDX 96
|
|
||||||
#define RSI 104
|
|
||||||
#define RDI 112
|
|
||||||
#define ORIG_RAX 120 /* = ERROR */
|
|
||||||
/* end of arguments */
|
|
||||||
/* cpu exception frame or undefined in case of fast syscall. */
|
|
||||||
#define RIP 128
|
|
||||||
#define CS 136
|
|
||||||
#define EFLAGS 144
|
|
||||||
#define RSP 152
|
|
||||||
#define SS 160
|
|
||||||
#define ARGOFFSET R11
|
|
||||||
#endif /* __ASSEMBLY__ */
|
|
||||||
|
|
||||||
/* top of stack page */
|
#ifndef __ASSEMBLY__
|
||||||
#define FRAME_SIZE 168
|
|
||||||
|
|
||||||
#define PTRACE_OLDSETOPTIONS 21
|
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
|
||||||
|
|
||||||
struct pt_regs {
|
struct pt_regs {
|
||||||
unsigned long r15;
|
unsigned long r15;
|
||||||
@ -45,7 +14,7 @@ struct pt_regs {
|
|||||||
unsigned long rbx;
|
unsigned long rbx;
|
||||||
/* arguments: non interrupts/non tracing syscalls only save upto here*/
|
/* arguments: non interrupts/non tracing syscalls only save upto here*/
|
||||||
unsigned long r11;
|
unsigned long r11;
|
||||||
unsigned long r10;
|
unsigned long r10;
|
||||||
unsigned long r9;
|
unsigned long r9;
|
||||||
unsigned long r8;
|
unsigned long r8;
|
||||||
unsigned long rax;
|
unsigned long rax;
|
||||||
@ -54,32 +23,18 @@ struct pt_regs {
|
|||||||
unsigned long rsi;
|
unsigned long rsi;
|
||||||
unsigned long rdi;
|
unsigned long rdi;
|
||||||
unsigned long orig_rax;
|
unsigned long orig_rax;
|
||||||
/* end of arguments */
|
/* end of arguments */
|
||||||
/* cpu exception frame or undefined */
|
/* cpu exception frame or undefined */
|
||||||
unsigned long rip;
|
unsigned long rip;
|
||||||
unsigned long cs;
|
unsigned long cs;
|
||||||
unsigned long eflags;
|
unsigned long eflags;
|
||||||
unsigned long rsp;
|
unsigned long rsp;
|
||||||
unsigned long ss;
|
unsigned long ss;
|
||||||
/* top of stack page */
|
/* top of stack page */
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Arbitrarily choose the same ptrace numbers as used by the Sparc code. */
|
|
||||||
#define PTRACE_GETREGS 12
|
|
||||||
#define PTRACE_SETREGS 13
|
|
||||||
#define PTRACE_GETFPREGS 14
|
|
||||||
#define PTRACE_SETFPREGS 15
|
|
||||||
#define PTRACE_GETFPXREGS 18
|
|
||||||
#define PTRACE_SETFPXREGS 19
|
|
||||||
|
|
||||||
/* only useful for access 32bit programs */
|
|
||||||
#define PTRACE_GET_THREAD_AREA 25
|
|
||||||
#define PTRACE_SET_THREAD_AREA 26
|
|
||||||
|
|
||||||
#define PTRACE_ARCH_PRCTL 30 /* arch_prctl for child */
|
|
||||||
|
|
||||||
#if defined(__KERNEL__) && !defined(__ASSEMBLY__)
|
#if defined(__KERNEL__) && !defined(__ASSEMBLY__)
|
||||||
#define user_mode(regs) (!!((regs)->cs & 3))
|
#define user_mode(regs) (!!((regs)->cs & 3))
|
||||||
#define user_mode_vm(regs) user_mode(regs)
|
#define user_mode_vm(regs) user_mode(regs)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user