sh: kprobes: Use trapa #0x3a for breakpoint trap.
authorPaul Mundt <lethal@linux-sh.org>
Mon, 8 Sep 2008 09:10:10 +0000 (18:10 +0900)
committerPaul Mundt <lethal@linux-sh.org>
Mon, 8 Sep 2008 09:10:10 +0000 (18:10 +0900)
Not all parts support trapa #0xff, so use something within the debug trap
range that's accessible on all parts.

Signed-off-by: Paul Mundt <lethal@linux-sh.org>
arch/sh/include/asm/kprobes.h
arch/sh/kernel/kprobes.c

index 756a5cd96378ceb2db3307650e7888fec0756bbc..6078d8e551d4960e66c0cf7da92fc266470d717a 100644 (file)
@@ -7,7 +7,7 @@
 #include <linux/ptrace.h>
 
 typedef u16 kprobe_opcode_t;
-#define BREAKPOINT_INSTRUCTION 0xc3ff
+#define BREAKPOINT_INSTRUCTION 0xc33a
 
 #define MAX_INSN_SIZE 16
 #define MAX_STACK_SIZE 64
index 81a3725e515572610a9be847705d0182ef98fc49..fdd049e9ad862e6d4e2497f9a22dae09769bbe4f 100644 (file)
@@ -525,8 +525,7 @@ int __kprobes setjmp_pre_handler(struct kprobe *p, struct pt_regs *regs)
 
 void __kprobes jprobe_return(void)
 {
-       __asm("trapa #-1\n\t" "jprobe_return_end:\n\t" "nop\n\t");
-
+       asm volatile ("trapa #0x3a\n\t" "jprobe_return_end:\n\t" "nop\n\t");
 }
 
 int __kprobes longjmp_break_handler(struct kprobe *p, struct pt_regs *regs)