Merge branches 'tracing/ftrace', 'tracing/mmiotrace' and 'linus' into tracing/core
[linux-2.6] / arch / x86 / include / asm / ptrace-abi.h
1 #ifndef _ASM_X86_PTRACE_ABI_H
2 #define _ASM_X86_PTRACE_ABI_H
3
4 #ifdef __i386__
5
6 #define EBX 0
7 #define ECX 1
8 #define EDX 2
9 #define ESI 3
10 #define EDI 4
11 #define EBP 5
12 #define EAX 6
13 #define DS 7
14 #define ES 8
15 #define FS 9
16 #define GS 10
17 #define ORIG_EAX 11
18 #define EIP 12
19 #define CS  13
20 #define EFL 14
21 #define UESP 15
22 #define SS   16
23 #define FRAME_SIZE 17
24
25 #else /* __i386__ */
26
27 #if defined(__ASSEMBLY__) || defined(__FRAME_OFFSETS)
28 #define R15 0
29 #define R14 8
30 #define R13 16
31 #define R12 24
32 #define RBP 32
33 #define RBX 40
34 /* arguments: interrupts/non tracing syscalls only save upto here*/
35 #define R11 48
36 #define R10 56
37 #define R9 64
38 #define R8 72
39 #define RAX 80
40 #define RCX 88
41 #define RDX 96
42 #define RSI 104
43 #define RDI 112
44 #define ORIG_RAX 120       /* = ERROR */
45 /* end of arguments */
46 /* cpu exception frame or undefined in case of fast syscall. */
47 #define RIP 128
48 #define CS 136
49 #define EFLAGS 144
50 #define RSP 152
51 #define SS 160
52 #define ARGOFFSET R11
53 #endif /* __ASSEMBLY__ */
54
55 /* top of stack page */
56 #define FRAME_SIZE 168
57
58 #endif /* !__i386__ */
59
60 /* Arbitrarily choose the same ptrace numbers as used by the Sparc code. */
61 #define PTRACE_GETREGS            12
62 #define PTRACE_SETREGS            13
63 #define PTRACE_GETFPREGS          14
64 #define PTRACE_SETFPREGS          15
65 #define PTRACE_GETFPXREGS         18
66 #define PTRACE_SETFPXREGS         19
67
68 #define PTRACE_OLDSETOPTIONS      21
69
70 /* only useful for access 32bit programs / kernels */
71 #define PTRACE_GET_THREAD_AREA    25
72 #define PTRACE_SET_THREAD_AREA    26
73
74 #ifdef __x86_64__
75 # define PTRACE_ARCH_PRCTL        30
76 #endif
77
78 #define PTRACE_SYSEMU             31
79 #define PTRACE_SYSEMU_SINGLESTEP  32
80
81 #define PTRACE_SINGLEBLOCK      33      /* resume execution until next branch */
82
83 #ifndef __ASSEMBLY__
84 #include <linux/types.h>
85
86 /* configuration/status structure used in PTRACE_BTS_CONFIG and
87    PTRACE_BTS_STATUS commands.
88 */
89 struct ptrace_bts_config {
90         /* requested or actual size of BTS buffer in bytes */
91         __u32 size;
92         /* bitmask of below flags */
93         __u32 flags;
94         /* buffer overflow signal */
95         __u32 signal;
96         /* actual size of bts_struct in bytes */
97         __u32 bts_size;
98 };
99 #endif /* __ASSEMBLY__ */
100
101 #define PTRACE_BTS_O_TRACE      0x1 /* branch trace */
102 #define PTRACE_BTS_O_SCHED      0x2 /* scheduling events w/ jiffies */
103 #define PTRACE_BTS_O_SIGNAL     0x4 /* send SIG<signal> on buffer overflow
104                                        instead of wrapping around */
105 #define PTRACE_BTS_O_ALLOC      0x8 /* (re)allocate buffer */
106
107 #define PTRACE_BTS_CONFIG       40
108 /* Configure branch trace recording.
109    ADDR points to a struct ptrace_bts_config.
110    DATA gives the size of that buffer.
111    A new buffer is allocated, if requested in the flags.
112    An overflow signal may only be requested for new buffers.
113    Returns the number of bytes read.
114 */
115 #define PTRACE_BTS_STATUS       41
116 /* Return the current configuration in a struct ptrace_bts_config
117    pointed to by ADDR; DATA gives the size of that buffer.
118    Returns the number of bytes written.
119 */
120 #define PTRACE_BTS_SIZE         42
121 /* Return the number of available BTS records for draining.
122    DATA and ADDR are ignored.
123 */
124 #define PTRACE_BTS_GET          43
125 /* Get a single BTS record.
126    DATA defines the index into the BTS array, where 0 is the newest
127    entry, and higher indices refer to older entries.
128    ADDR is pointing to struct bts_struct (see asm/ds.h).
129 */
130 #define PTRACE_BTS_CLEAR        44
131 /* Clear the BTS buffer.
132    DATA and ADDR are ignored.
133 */
134 #define PTRACE_BTS_DRAIN        45
135 /* Read all available BTS records and clear the buffer.
136    ADDR points to an array of struct bts_struct.
137    DATA gives the size of that buffer.
138    BTS records are read from oldest to newest.
139    Returns number of BTS records drained.
140 */
141
142 #endif /* _ASM_X86_PTRACE_ABI_H */