diff options
Diffstat (limited to 'arch/powerpc/kernel/kprobes.c')
-rw-r--r-- | arch/powerpc/kernel/kprobes.c | 26 |
1 files changed, 13 insertions, 13 deletions
diff --git a/arch/powerpc/kernel/kprobes.c b/arch/powerpc/kernel/kprobes.c index cd65c367b8b6..46d2fd0e5789 100644 --- a/arch/powerpc/kernel/kprobes.c +++ b/arch/powerpc/kernel/kprobes.c | |||
@@ -259,14 +259,14 @@ void kretprobe_trampoline_holder(void) | |||
259 | */ | 259 | */ |
260 | int __kprobes trampoline_probe_handler(struct kprobe *p, struct pt_regs *regs) | 260 | int __kprobes trampoline_probe_handler(struct kprobe *p, struct pt_regs *regs) |
261 | { | 261 | { |
262 | struct kretprobe_instance *ri = NULL; | 262 | struct kretprobe_instance *ri = NULL; |
263 | struct hlist_head *head; | 263 | struct hlist_head *head; |
264 | struct hlist_node *node, *tmp; | 264 | struct hlist_node *node, *tmp; |
265 | unsigned long flags, orig_ret_address = 0; | 265 | unsigned long flags, orig_ret_address = 0; |
266 | unsigned long trampoline_address =(unsigned long)&kretprobe_trampoline; | 266 | unsigned long trampoline_address =(unsigned long)&kretprobe_trampoline; |
267 | 267 | ||
268 | spin_lock_irqsave(&kretprobe_lock, flags); | 268 | spin_lock_irqsave(&kretprobe_lock, flags); |
269 | head = kretprobe_inst_table_head(current); | 269 | head = kretprobe_inst_table_head(current); |
270 | 270 | ||
271 | /* | 271 | /* |
272 | * It is possible to have multiple instances associated with a given | 272 | * It is possible to have multiple instances associated with a given |
@@ -277,14 +277,14 @@ int __kprobes trampoline_probe_handler(struct kprobe *p, struct pt_regs *regs) | |||
277 | * We can handle this because: | 277 | * We can handle this because: |
278 | * - instances are always inserted at the head of the list | 278 | * - instances are always inserted at the head of the list |
279 | * - when multiple return probes are registered for the same | 279 | * - when multiple return probes are registered for the same |
280 | * function, the first instance's ret_addr will point to the | 280 | * function, the first instance's ret_addr will point to the |
281 | * real return address, and all the rest will point to | 281 | * real return address, and all the rest will point to |
282 | * kretprobe_trampoline | 282 | * kretprobe_trampoline |
283 | */ | 283 | */ |
284 | hlist_for_each_entry_safe(ri, node, tmp, head, hlist) { | 284 | hlist_for_each_entry_safe(ri, node, tmp, head, hlist) { |
285 | if (ri->task != current) | 285 | if (ri->task != current) |
286 | /* another task is sharing our hash bucket */ | 286 | /* another task is sharing our hash bucket */ |
287 | continue; | 287 | continue; |
288 | 288 | ||
289 | if (ri->rp && ri->rp->handler) | 289 | if (ri->rp && ri->rp->handler) |
290 | ri->rp->handler(ri, regs); | 290 | ri->rp->handler(ri, regs); |
@@ -308,12 +308,12 @@ int __kprobes trampoline_probe_handler(struct kprobe *p, struct pt_regs *regs) | |||
308 | spin_unlock_irqrestore(&kretprobe_lock, flags); | 308 | spin_unlock_irqrestore(&kretprobe_lock, flags); |
309 | preempt_enable_no_resched(); | 309 | preempt_enable_no_resched(); |
310 | 310 | ||
311 | /* | 311 | /* |
312 | * By returning a non-zero value, we are telling | 312 | * By returning a non-zero value, we are telling |
313 | * kprobe_handler() that we don't want the post_handler | 313 | * kprobe_handler() that we don't want the post_handler |
314 | * to run (and have re-enabled preemption) | 314 | * to run (and have re-enabled preemption) |
315 | */ | 315 | */ |
316 | return 1; | 316 | return 1; |
317 | } | 317 | } |
318 | 318 | ||
319 | /* | 319 | /* |