diff options
author | Roland McGrath <roland@redhat.com> | 2008-01-30 07:30:53 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:30:53 -0500 |
commit | dc802c2d2e66e2d1544e023bfd4be6cdee48d57b (patch) | |
tree | f3b2f58da24d67e70fee9c9e0ef2146c12ea13c2 /include/linux | |
parent | d9771e8c50020bb1b4ca9eca9c188874ff126aa4 (diff) |
ptrace: arch_has_block_step
This defines the new macro arch_has_block_step() in linux/ptrace.h, a
default for when asm/ptrace.h does not define it. This is the analog
of arch_has_single_step() for step-until-branch on machines that have
it. It declares the new user_enable_block_step function, which goes
with the existing user_enable_single_step and user_disable_single_step.
This is not used yet, but paves the way to harmonize on this interface
for the arch-specific calls on all machines.
Signed-off-by: Roland McGrath <roland@redhat.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/ptrace.h | 37 |
1 files changed, 33 insertions, 4 deletions
diff --git a/include/linux/ptrace.h b/include/linux/ptrace.h index 8f06c6fb22a5..1febc541dda5 100644 --- a/include/linux/ptrace.h +++ b/include/linux/ptrace.h | |||
@@ -155,7 +155,8 @@ int generic_ptrace_pokedata(struct task_struct *tsk, long addr, long data); | |||
155 | * | 155 | * |
156 | * This can only be called when arch_has_single_step() has returned nonzero. | 156 | * This can only be called when arch_has_single_step() has returned nonzero. |
157 | * Set @task so that when it returns to user mode, it will trap after the | 157 | * Set @task so that when it returns to user mode, it will trap after the |
158 | * next single instruction executes. | 158 | * next single instruction executes. If arch_has_block_step() is defined, |
159 | * this must clear the effects of user_enable_block_step() too. | ||
159 | */ | 160 | */ |
160 | static inline void user_enable_single_step(struct task_struct *task) | 161 | static inline void user_enable_single_step(struct task_struct *task) |
161 | { | 162 | { |
@@ -166,15 +167,43 @@ static inline void user_enable_single_step(struct task_struct *task) | |||
166 | * user_disable_single_step - cancel user-mode single-step | 167 | * user_disable_single_step - cancel user-mode single-step |
167 | * @task: either current or a task stopped in %TASK_TRACED | 168 | * @task: either current or a task stopped in %TASK_TRACED |
168 | * | 169 | * |
169 | * Clear @task of the effects of user_enable_single_step(). This can | 170 | * Clear @task of the effects of user_enable_single_step() and |
170 | * be called whether or not user_enable_single_step() was ever called | 171 | * user_enable_block_step(). This can be called whether or not either |
171 | * on @task, and even if arch_has_single_step() returned zero. | 172 | * of those was ever called on @task, and even if arch_has_single_step() |
173 | * returned zero. | ||
172 | */ | 174 | */ |
173 | static inline void user_disable_single_step(struct task_struct *task) | 175 | static inline void user_disable_single_step(struct task_struct *task) |
174 | { | 176 | { |
175 | } | 177 | } |
176 | #endif /* arch_has_single_step */ | 178 | #endif /* arch_has_single_step */ |
177 | 179 | ||
180 | #ifndef arch_has_block_step | ||
181 | /** | ||
182 | * arch_has_block_step - does this CPU support user-mode block-step? | ||
183 | * | ||
184 | * If this is defined, then there must be a function declaration or inline | ||
185 | * for user_enable_block_step(), and arch_has_single_step() must be defined | ||
186 | * too. arch_has_block_step() should evaluate to nonzero iff the machine | ||
187 | * supports step-until-branch for user mode. It can be a constant or it | ||
188 | * can test a CPU feature bit. | ||
189 | */ | ||
190 | #define arch_has_single_step() (0) | ||
191 | |||
192 | /** | ||
193 | * user_enable_block_step - step until branch in user-mode task | ||
194 | * @task: either current or a task stopped in %TASK_TRACED | ||
195 | * | ||
196 | * This can only be called when arch_has_block_step() has returned nonzero, | ||
197 | * and will never be called when single-instruction stepping is being used. | ||
198 | * Set @task so that when it returns to user mode, it will trap after the | ||
199 | * next branch or trap taken. | ||
200 | */ | ||
201 | static inline void user_enable_block_step(struct task_struct *task) | ||
202 | { | ||
203 | BUG(); /* This can never be called. */ | ||
204 | } | ||
205 | #endif /* arch_has_block_step */ | ||
206 | |||
178 | #endif | 207 | #endif |
179 | 208 | ||
180 | #endif | 209 | #endif |