mirror of https://gitee.com/openkylin/linux.git
kprobes/x86: Just return error for sanity check failure instead of using BUG_ON
Return an error from __copy_instruction() and use printk() to give us a more productive message, since this is just an error case which we can handle and also the BUG_ON() never tells us why and what happened. This is related to the following bug-report: https://bugzilla.redhat.com/show_bug.cgi?id=910649 Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Cc: Frank Ch. Eigler <fche@redhat.com> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: yrl.pp-manager.tt@hitachi.com Link: http://lkml.kernel.org/r/20130404104230.22862.85242.stgit@mhiramat-M0-7522 Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
324670b620
commit
8101376dc5
|
@ -353,7 +353,11 @@ int __kprobes __copy_instruction(u8 *dest, u8 *src)
|
||||||
* have given.
|
* have given.
|
||||||
*/
|
*/
|
||||||
newdisp = (u8 *) src + (s64) insn.displacement.value - (u8 *) dest;
|
newdisp = (u8 *) src + (s64) insn.displacement.value - (u8 *) dest;
|
||||||
BUG_ON((s64) (s32) newdisp != newdisp); /* Sanity check. */
|
if ((s64) (s32) newdisp != newdisp) {
|
||||||
|
pr_err("Kprobes error: new displacement does not fit into s32 (%llx)\n", newdisp);
|
||||||
|
pr_err("\tSrc: %p, Dest: %p, old disp: %x\n", src, dest, insn.displacement.value);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
disp = (u8 *) dest + insn_offset_displacement(&insn);
|
disp = (u8 *) dest + insn_offset_displacement(&insn);
|
||||||
*(s32 *) disp = (s32) newdisp;
|
*(s32 *) disp = (s32) newdisp;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue