ptrace.h 4.7 KB
Newer Older
T
Thomas Gleixner 已提交
1 2 3 4 5 6
#ifndef _ASM_X86_PTRACE_H
#define _ASM_X86_PTRACE_H

#include <linux/compiler.h>	/* For __user */
#include <asm/ptrace-abi.h>

7

T
Thomas Gleixner 已提交
8 9
#ifndef __ASSEMBLY__

10 11
#ifdef __KERNEL__

M
Markus Metzger 已提交
12
/* the DS BTS struct is used for ptrace as well */
13 14 15 16 17 18 19 20
#include <asm/ds.h>

struct task_struct;
extern void ptrace_bts_take_timestamp(struct task_struct *, enum bts_qualifier);

#endif /* __KERNEL__ */


T
Thomas Gleixner 已提交
21 22 23 24
#ifdef __i386__
/* this struct defines the way the registers are stored on the
   stack during a system call. */

25 26
#ifndef __KERNEL__

T
Thomas Gleixner 已提交
27 28 29 30 31 32 33 34 35 36 37
struct pt_regs {
	long ebx;
	long ecx;
	long edx;
	long esi;
	long edi;
	long ebp;
	long eax;
	int  xds;
	int  xes;
	int  xfs;
38
	/* int  gs; */
T
Thomas Gleixner 已提交
39 40 41 42 43 44 45 46
	long orig_eax;
	long eip;
	int  xcs;
	long eflags;
	long esp;
	int  xss;
};

47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
#else /* __KERNEL__ */

struct pt_regs {
	long bx;
	long cx;
	long dx;
	long si;
	long di;
	long bp;
	long ax;
	int  ds;
	int  es;
	int  fs;
	/* int  gs; */
	long orig_ax;
	long ip;
	int  cs;
	long flags;
	long sp;
	int  ss;
};
T
Thomas Gleixner 已提交
68 69 70 71 72

#include <asm/vm86.h>
#include <asm/segment.h>

struct task_struct;
73 74 75 76

extern unsigned long
convert_ip_to_linear(struct task_struct *child, struct pt_regs *regs);

T
Thomas Gleixner 已提交
77 78 79 80 81 82 83 84 85 86 87
extern void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs, int error_code);

/*
 * user_mode_vm(regs) determines whether a register set came from user mode.
 * This is true if V8086 mode was enabled OR if the register set was from
 * protected mode with RPL-3 CS value.  This tricky test checks that with
 * one comparison.  Many places in the kernel can bypass this full check
 * if they have already ruled out V8086 mode, so user_mode(regs) can be used.
 */
static inline int user_mode(struct pt_regs *regs)
{
88
	return (regs->cs & SEGMENT_RPL_MASK) == USER_RPL;
T
Thomas Gleixner 已提交
89 90 91
}
static inline int user_mode_vm(struct pt_regs *regs)
{
92 93
	return ((regs->cs & SEGMENT_RPL_MASK) |
		(regs->flags & VM_MASK)) >= USER_RPL;
T
Thomas Gleixner 已提交
94 95 96
}
static inline int v8086_mode(struct pt_regs *regs)
{
97
	return (regs->flags & VM_MASK);
T
Thomas Gleixner 已提交
98 99
}

100 101
#define instruction_pointer(regs) ((regs)->ip)
#define frame_pointer(regs) ((regs)->bp)
J
Jan Blunck 已提交
102
#define stack_pointer(regs) ((unsigned long)(regs))
103
#define regs_return_value(regs) ((regs)->ax)
T
Thomas Gleixner 已提交
104 105 106 107 108 109

extern unsigned long profile_pc(struct pt_regs *regs);
#endif /* __KERNEL__ */

#else /* __i386__ */

110 111
#ifndef __KERNEL__

T
Thomas Gleixner 已提交
112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139
struct pt_regs {
	unsigned long r15;
	unsigned long r14;
	unsigned long r13;
	unsigned long r12;
	unsigned long rbp;
	unsigned long rbx;
/* arguments: non interrupts/non tracing syscalls only save upto here*/
	unsigned long r11;
	unsigned long r10;
	unsigned long r9;
	unsigned long r8;
	unsigned long rax;
	unsigned long rcx;
	unsigned long rdx;
	unsigned long rsi;
	unsigned long rdi;
	unsigned long orig_rax;
/* end of arguments */
/* cpu exception frame or undefined */
	unsigned long rip;
	unsigned long cs;
	unsigned long eflags;
	unsigned long rsp;
	unsigned long ss;
/* top of stack page */
};

140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168
#else /* __KERNEL__ */

struct pt_regs {
	unsigned long r15;
	unsigned long r14;
	unsigned long r13;
	unsigned long r12;
	unsigned long bp;
	unsigned long bx;
/* arguments: non interrupts/non tracing syscalls only save upto here*/
	unsigned long r11;
	unsigned long r10;
	unsigned long r9;
	unsigned long r8;
	unsigned long ax;
	unsigned long cx;
	unsigned long dx;
	unsigned long si;
	unsigned long di;
	unsigned long orig_ax;
/* end of arguments */
/* cpu exception frame or undefined */
	unsigned long ip;
	unsigned long cs;
	unsigned long flags;
	unsigned long sp;
	unsigned long ss;
/* top of stack page */
};
T
Thomas Gleixner 已提交
169 170 171

#define user_mode(regs) (!!((regs)->cs & 3))
#define user_mode_vm(regs) user_mode(regs)
172 173 174 175 176
#define v8086_mode(regs) 0	/* No V86 mode support in long mode */
#define instruction_pointer(regs) ((regs)->ip)
#define frame_pointer(regs) ((regs)->bp)
#define stack_pointer(regs) ((regs)->sp)
#define regs_return_value(regs) ((regs)->ax)
T
Thomas Gleixner 已提交
177 178 179 180 181 182 183

extern unsigned long profile_pc(struct pt_regs *regs);
void signal_fault(struct pt_regs *regs, void __user *frame, char *where);

struct task_struct;

extern unsigned long
H
Harvey Harrison 已提交
184
convert_ip_to_linear(struct task_struct *child, struct pt_regs *regs);
T
Thomas Gleixner 已提交
185 186 187

#endif /* __KERNEL__ */
#endif /* !__i386__ */
R
Roland McGrath 已提交
188 189 190

#ifdef __KERNEL__

R
Roland McGrath 已提交
191 192 193 194 195 196 197
/*
 * These are defined as per linux/ptrace.h, which see.
 */
#define arch_has_single_step()	(1)
extern void user_enable_single_step(struct task_struct *);
extern void user_disable_single_step(struct task_struct *);

198 199 200 201 202 203 204
extern void user_enable_block_step(struct task_struct *);
#ifdef CONFIG_X86_DEBUGCTLMSR
#define arch_has_block_step()	(1)
#else
#define arch_has_block_step()	(boot_cpu_data.x86 >= 6)
#endif

R
Roland McGrath 已提交
205 206 207 208 209 210 211 212
struct user_desc;
extern int do_get_thread_area(struct task_struct *p, int idx,
			      struct user_desc __user *info);
extern int do_set_thread_area(struct task_struct *p, int idx,
			      struct user_desc __user *info, int can_allocate);

#endif /* __KERNEL__ */

T
Thomas Gleixner 已提交
213 214
#endif /* !__ASSEMBLY__ */

215
#endif