diff options
author | Markus Metzger <markus.t.metzger@intel.com> | 2008-01-30 07:31:09 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:31:09 -0500 |
commit | eee3af4a2c83a97fff107ddc445d9df6fded9ce4 (patch) | |
tree | a7e9179b82b4df9e4cf6e810c54309324589395b /include/asm-x86/thread_info_32.h | |
parent | 7796931f542518092d1fd2fb7cf1f1d96e0cd4b5 (diff) |
x86, ptrace: support for branch trace store(BTS)
Resend using different mail client
Changes to the last version:
- split implementation into two layers: ds/bts and ptrace
- renamed TIF's
- save/restore ds save area msr in __switch_to_xtra()
- make block-stepping only look at BTF bit
Signed-off-by: Markus Metzger <markus.t.metzger@intel.com>
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/asm-x86/thread_info_32.h')
-rw-r--r-- | include/asm-x86/thread_info_32.h | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/include/asm-x86/thread_info_32.h b/include/asm-x86/thread_info_32.h index 306fc80800e1..5bd508260ffb 100644 --- a/include/asm-x86/thread_info_32.h +++ b/include/asm-x86/thread_info_32.h | |||
@@ -140,6 +140,8 @@ static inline struct thread_info *current_thread_info(void) | |||
140 | #define TIF_NOTSC 20 /* TSC is not accessible in userland */ | 140 | #define TIF_NOTSC 20 /* TSC is not accessible in userland */ |
141 | #define TIF_FORCED_TF 21 /* true if TF in eflags artificially */ | 141 | #define TIF_FORCED_TF 21 /* true if TF in eflags artificially */ |
142 | #define TIF_DEBUGCTLMSR 22 /* uses thread_struct.debugctlmsr */ | 142 | #define TIF_DEBUGCTLMSR 22 /* uses thread_struct.debugctlmsr */ |
143 | #define TIF_DS_AREA_MSR 23 /* uses thread_struct.ds_area_msr */ | ||
144 | #define TIF_BTS_TRACE_TS 24 /* record scheduling event timestamps */ | ||
143 | 145 | ||
144 | #define _TIF_SYSCALL_TRACE (1<<TIF_SYSCALL_TRACE) | 146 | #define _TIF_SYSCALL_TRACE (1<<TIF_SYSCALL_TRACE) |
145 | #define _TIF_SIGPENDING (1<<TIF_SIGPENDING) | 147 | #define _TIF_SIGPENDING (1<<TIF_SIGPENDING) |
@@ -157,6 +159,8 @@ static inline struct thread_info *current_thread_info(void) | |||
157 | #define _TIF_NOTSC (1<<TIF_NOTSC) | 159 | #define _TIF_NOTSC (1<<TIF_NOTSC) |
158 | #define _TIF_FORCED_TF (1<<TIF_FORCED_TF) | 160 | #define _TIF_FORCED_TF (1<<TIF_FORCED_TF) |
159 | #define _TIF_DEBUGCTLMSR (1<<TIF_DEBUGCTLMSR) | 161 | #define _TIF_DEBUGCTLMSR (1<<TIF_DEBUGCTLMSR) |
162 | #define _TIF_DS_AREA_MSR (1<<TIF_DS_AREA_MSR) | ||
163 | #define _TIF_BTS_TRACE_TS (1<<TIF_BTS_TRACE_TS) | ||
160 | 164 | ||
161 | /* work to do on interrupt/exception return */ | 165 | /* work to do on interrupt/exception return */ |
162 | #define _TIF_WORK_MASK \ | 166 | #define _TIF_WORK_MASK \ |
@@ -166,8 +170,12 @@ static inline struct thread_info *current_thread_info(void) | |||
166 | #define _TIF_ALLWORK_MASK (0x0000FFFF & ~_TIF_SECCOMP) | 170 | #define _TIF_ALLWORK_MASK (0x0000FFFF & ~_TIF_SECCOMP) |
167 | 171 | ||
168 | /* flags to check in __switch_to() */ | 172 | /* flags to check in __switch_to() */ |
169 | #define _TIF_WORK_CTXSW_NEXT (_TIF_IO_BITMAP | _TIF_NOTSC | _TIF_DEBUG | _TIF_DEBUGCTLMSR) | 173 | #define _TIF_WORK_CTXSW \ |
170 | #define _TIF_WORK_CTXSW_PREV (_TIF_IO_BITMAP | _TIF_NOTSC | _TIF_DEBUGCTLMSR) | 174 | (_TIF_IO_BITMAP | _TIF_NOTSC | _TIF_DEBUGCTLMSR | \ |
175 | _TIF_DS_AREA_MSR | _TIF_BTS_TRACE_TS) | ||
176 | #define _TIF_WORK_CTXSW_PREV _TIF_WORK_CTXSW | ||
177 | #define _TIF_WORK_CTXSW_NEXT (_TIF_WORK_CTXSW | _TIF_DEBUG) | ||
178 | |||
171 | 179 | ||
172 | /* | 180 | /* |
173 | * Thread-synchronous status. | 181 | * Thread-synchronous status. |