1 #ifndef _X86_64_PTRACE_H
2 #define _X86_64_PTRACE_H
4 #if defined(__ASSEMBLY__) || defined(__FRAME_OFFSETS)
11 /* arguments: interrupts/non tracing syscalls only save upto here*/
21 #define ORIG_RAX 120 /* = ERROR */
22 /* end of arguments */
23 /* cpu exception frame or undefined in case of fast syscall. */
30 #endif /* __ASSEMBLY__ */
32 /* top of stack page */
33 #define FRAME_SIZE 168
35 #define PTRACE_OLDSETOPTIONS 21
37 /* Dummy values for ptrace */
50 /* arguments: non interrupts/non tracing syscalls only save upto here*/
60 unsigned long orig_rax
;
61 /* end of arguments */
62 /* cpu exception frame or undefined */
68 /* top of stack page */
73 /* Arbitrarily choose the same ptrace numbers as used by the Sparc code. */
74 #define PTRACE_GETREGS 12
75 #define PTRACE_SETREGS 13
76 #define PTRACE_GETFPREGS 14
77 #define PTRACE_SETFPREGS 15
78 #define PTRACE_GETFPXREGS 18
79 #define PTRACE_SETFPXREGS 19
81 #define PTRACE_GET_THREAD_AREA 25
82 #define PTRACE_SET_THREAD_AREA 26
85 #if defined(__KERNEL__) && !defined(__ASSEMBLY__)
86 #define user_mode(regs) (!!((regs)->cs & 3))
87 #define instruction_pointer(regs) ((regs)->rip)
88 void signal_fault(struct pt_regs
*regs
, void *frame
, char *where
);
100 EF_IOPL
= 0x00003000,
101 EF_IOPL_RING0
= 0x00000000,
102 EF_IOPL_RING1
= 0x00001000,
103 EF_IOPL_RING2
= 0x00002000,
104 EF_NT
= 0x00004000, /* nested task */
105 EF_RF
= 0x00010000, /* resume */
106 EF_VM
= 0x00020000, /* virtual mode */
107 EF_AC
= 0x00040000, /* alignment */
108 EF_VIF
= 0x00080000, /* virtual interrupt */
109 EF_VIP
= 0x00100000, /* virtual interrupt pending */
110 EF_ID
= 0x00200000, /* id */