aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sh/kernel/hw_breakpoint.c
diff options
context:
space:
mode:
authorPaul Mundt <lethal@linux-sh.org>2009-12-21 22:40:38 -0500
committerPaul Mundt <lethal@linux-sh.org>2009-12-21 22:40:38 -0500
commitb74ab703b1326aafadb5604ff6200da62c61df49 (patch)
tree82bd4c880526ba0f7ded0302f8926b65bd2ee16b /arch/sh/kernel/hw_breakpoint.c
parent6c0ee6a4bba0e21eb0fb4de5bdac03c11b74242d (diff)
sh: Don't NOTIFY_STOP for non-UBC breakpoint traps.
Presently the hw_breakpoint code is the primary notifier dispatch for breakpoint traps, although it's only UBC traps that are of particular interest there. This patches in a check to allow non-UBC generated breakpoints to pass through down the remainder of the notifier chain, giving things like kgdb a chance at getting notified. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/kernel/hw_breakpoint.c')
-rw-r--r--arch/sh/kernel/hw_breakpoint.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/arch/sh/kernel/hw_breakpoint.c b/arch/sh/kernel/hw_breakpoint.c
index 75b8c471120f..022d8ed66bd6 100644
--- a/arch/sh/kernel/hw_breakpoint.c
+++ b/arch/sh/kernel/hw_breakpoint.c
@@ -398,9 +398,18 @@ BUILD_TRAP_HANDLER(breakpoint)
398int __kprobes hw_breakpoint_exceptions_notify(struct notifier_block *unused, 398int __kprobes hw_breakpoint_exceptions_notify(struct notifier_block *unused,
399 unsigned long val, void *data) 399 unsigned long val, void *data)
400{ 400{
401 struct die_args *args = data;
402
401 if (val != DIE_BREAKPOINT) 403 if (val != DIE_BREAKPOINT)
402 return NOTIFY_DONE; 404 return NOTIFY_DONE;
403 405
406 /*
407 * If the breakpoint hasn't been triggered by the UBC, it's
408 * probably from a debugger, so don't do anything more here.
409 */
410 if (args->trapnr != 0x1e0)
411 return NOTIFY_DONE;
412
404 return hw_breakpoint_handler(data); 413 return hw_breakpoint_handler(data);
405} 414}
406 415