Commit 9079a999 authored by Paul Mackerras's avatar Paul Mackerras Committed by Linus Torvalds

[PATCH] ppc64: kprobes: handle trap variants while processing probes

This patch is from Ananth N Mavinakayanahalli <ananth@in.ibm.com>.

While processing a kprobe, we were currently not handling all available trap
variants available on PowerPC.  This lead to the breakage of BUG() handling in
ppc64.
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent f0c25739
...@@ -105,8 +105,16 @@ static inline int kprobe_handler(struct pt_regs *regs) ...@@ -105,8 +105,16 @@ static inline int kprobe_handler(struct pt_regs *regs)
p = get_kprobe(addr); p = get_kprobe(addr);
if (!p) { if (!p) {
unlock_kprobes(); unlock_kprobes();
#if 0
if (*addr != BREAKPOINT_INSTRUCTION) { if (*addr != BREAKPOINT_INSTRUCTION) {
/*
* PowerPC has multiple variants of the "trap"
* instruction. If the current instruction is a
* trap variant, it could belong to someone else
*/
kprobe_opcode_t cur_insn = *addr;
if (IS_TW(cur_insn) || IS_TD(cur_insn) ||
IS_TWI(cur_insn) || IS_TDI(cur_insn))
goto no_kprobe;
/* /*
* The breakpoint instruction was removed right * The breakpoint instruction was removed right
* after we hit it. Another cpu has removed * after we hit it. Another cpu has removed
...@@ -116,7 +124,6 @@ static inline int kprobe_handler(struct pt_regs *regs) ...@@ -116,7 +124,6 @@ static inline int kprobe_handler(struct pt_regs *regs)
*/ */
ret = 1; ret = 1;
} }
#endif
/* Not one of ours: let kernel handle it */ /* Not one of ours: let kernel handle it */
goto no_kprobe; goto no_kprobe;
} }
......
...@@ -35,6 +35,11 @@ typedef unsigned int kprobe_opcode_t; ...@@ -35,6 +35,11 @@ typedef unsigned int kprobe_opcode_t;
#define BREAKPOINT_INSTRUCTION 0x7fe00008 /* trap */ #define BREAKPOINT_INSTRUCTION 0x7fe00008 /* trap */
#define MAX_INSN_SIZE 1 #define MAX_INSN_SIZE 1
#define IS_TW(instr) (((instr) & 0xfc0007fe) == 0x7c000008)
#define IS_TD(instr) (((instr) & 0xfc0007fe) == 0x7c000088)
#define IS_TDI(instr) (((instr) & 0xfc000000) == 0x08000000)
#define IS_TWI(instr) (((instr) & 0xfc000000) == 0x0c000000)
#define JPROBE_ENTRY(pentry) (kprobe_opcode_t *)((func_descr_t *)pentry) #define JPROBE_ENTRY(pentry) (kprobe_opcode_t *)((func_descr_t *)pentry)
/* Architecture specific copy of original instruction */ /* Architecture specific copy of original instruction */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment