x86, ptrace: new ptrace BTS API
[linux-2.6/mini2440.git] / include / asm-x86 / ptrace-abi.h
blobcf2fe4633ee52f385a7212d4ff545bd26f170ffc
1 #ifndef _ASM_X86_PTRACE_ABI_H
2 #define _ASM_X86_PTRACE_ABI_H
4 #ifdef __i386__
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
25 #else /* __i386__ */
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__ */
55 /* top of stack page */
56 #define FRAME_SIZE 168
58 #endif /* !__i386__ */
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
68 #define PTRACE_OLDSETOPTIONS 21
70 /* only useful for access 32bit programs / kernels */
71 #define PTRACE_GET_THREAD_AREA 25
72 #define PTRACE_SET_THREAD_AREA 26
74 #ifdef __x86_64__
75 # define PTRACE_ARCH_PRCTL 30
76 #else
77 # define PTRACE_SYSEMU 31
78 # define PTRACE_SYSEMU_SINGLESTEP 32
79 #endif
81 #define PTRACE_SINGLEBLOCK 33 /* resume execution until next branch */
83 /* configuration/status structure used in PTRACE_BTS_CONFIG and
84 PTRACE_BTS_STATUS commands.
86 struct ptrace_bts_config {
87 /* requested or actual size of BTS buffer in bytes */
88 unsigned long size;
89 /* bitmask of below flags */
90 unsigned long flags;
93 #define PTRACE_BTS_O_TRACE 0x1 /* branch trace */
94 #define PTRACE_BTS_O_SCHED 0x2 /* scheduling events w/ jiffies */
95 #define PTRACE_BTS_O_SIGNAL 0x4 /* send SIG? on buffer overflow
96 instead of wrapping around */
97 #define PTRACE_BTS_O_CUT_SIZE 0x8 /* cut requested size to max available
98 instead of failing */
100 #define PTRACE_BTS_CONFIG 40
101 /* Configure branch trace recording.
102 DATA is ignored, ADDR points to a struct ptrace_bts_config.
103 A new buffer is allocated, iff the size changes.
105 #define PTRACE_BTS_STATUS 41
106 /* Return the current configuration.
107 DATA is ignored, ADDR points to a struct ptrace_bts_config
108 that will contain the result.
110 #define PTRACE_BTS_SIZE 42
111 /* Return the number of available BTS records.
112 DATA and ADDR are ignored.
114 #define PTRACE_BTS_GET 43
115 /* Get a single BTS record.
116 DATA defines the index into the BTS array, where 0 is the newest
117 entry, and higher indices refer to older entries.
118 ADDR is pointing to struct bts_struct (see asm/ds.h).
120 #define PTRACE_BTS_CLEAR 44
121 /* Clear the BTS buffer.
122 DATA and ADDR are ignored.
124 #define PTRACE_BTS_DRAIN 45
125 /* Read all available BTS records and clear the buffer.
126 DATA is ignored. ADDR points to an array of struct bts_struct of
127 suitable size.
128 BTS records are read from oldest to newest.
129 Returns number of BTS records drained.
132 #endif