Linux 4.1.18
[linux/fpc-iii.git] / arch / x86 / include / uapi / asm / ptrace.h
blobbc16115af39b9e66c048b5e0237180f505535b77
1 #ifndef _UAPI_ASM_X86_PTRACE_H
2 #define _UAPI_ASM_X86_PTRACE_H
4 #include <linux/compiler.h> /* For __user */
5 #include <asm/ptrace-abi.h>
6 #include <asm/processor-flags.h>
9 #ifndef __ASSEMBLY__
11 #ifdef __i386__
12 /* this struct defines the way the registers are stored on the
13 stack during a system call. */
15 #ifndef __KERNEL__
17 struct pt_regs {
18 long ebx;
19 long ecx;
20 long edx;
21 long esi;
22 long edi;
23 long ebp;
24 long eax;
25 int xds;
26 int xes;
27 int xfs;
28 int xgs;
29 long orig_eax;
30 long eip;
31 int xcs;
32 long eflags;
33 long esp;
34 int xss;
37 #endif /* __KERNEL__ */
39 #else /* __i386__ */
41 #ifndef __KERNEL__
43 struct pt_regs {
45 * C ABI says these regs are callee-preserved. They aren't saved on kernel entry
46 * unless syscall needs a complete, fully filled "struct pt_regs".
48 unsigned long r15;
49 unsigned long r14;
50 unsigned long r13;
51 unsigned long r12;
52 unsigned long rbp;
53 unsigned long rbx;
54 /* These regs are callee-clobbered. Always saved on kernel entry. */
55 unsigned long r11;
56 unsigned long r10;
57 unsigned long r9;
58 unsigned long r8;
59 unsigned long rax;
60 unsigned long rcx;
61 unsigned long rdx;
62 unsigned long rsi;
63 unsigned long rdi;
65 * On syscall entry, this is syscall#. On CPU exception, this is error code.
66 * On hw interrupt, it's IRQ number:
68 unsigned long orig_rax;
69 /* Return frame for iretq */
70 unsigned long rip;
71 unsigned long cs;
72 unsigned long eflags;
73 unsigned long rsp;
74 unsigned long ss;
75 /* top of stack page */
78 #endif /* __KERNEL__ */
79 #endif /* !__i386__ */
83 #endif /* !__ASSEMBLY__ */
85 #endif /* _UAPI_ASM_X86_PTRACE_H */