Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754542AbbBTKQf (ORCPT ); Fri, 20 Feb 2015 05:16:35 -0500 Received: from cantor2.suse.de ([195.135.220.15]:47603 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754426AbbBTKQe (ORCPT ); Fri, 20 Feb 2015 05:16:34 -0500 From: Petr Mladek To: Ingo Molnar Cc: Masami Hiramatsu , "David S. Miller" , Anil S Keshavamurthy , Ananth NMavinakayanahalli , Frederic Weisbecker , Steven Rostedt , Jiri Kosina , linux-kernel@vger.kernel.org, Petr Mladek Subject: [PATCH 2/2] kprobes/x86: Check for invalid ftrace location in __recover_probed_insn() Date: Fri, 20 Feb 2015 11:16:42 +0100 Message-Id: <1424427402-11795-3-git-send-email-pmladek@suse.cz> X-Mailer: git-send-email 1.8.5.6 In-Reply-To: <1424427402-11795-1-git-send-email-pmladek@suse.cz> References: <20150218212205.GA26334@gmail.com> <1424427402-11795-1-git-send-email-pmladek@suse.cz> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1459 Lines: 37 __recover_probed_insn() should always be called from an address where an instructions starts. The check for ftrace_location() might help to discover a potential inconsistency. Something goes terribly wrong when an address inside the ftrace location is checked. Let's BUG() in this case. Suggested-by: Masami Hiramatsu Signed-off-by: Petr Mladek Acked-by: Masami Hiramatsu --- arch/x86/kernel/kprobes/core.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/arch/x86/kernel/kprobes/core.c b/arch/x86/kernel/kprobes/core.c index 2f464b56766a..124577dcf768 100644 --- a/arch/x86/kernel/kprobes/core.c +++ b/arch/x86/kernel/kprobes/core.c @@ -228,6 +228,12 @@ __recover_probed_insn(kprobe_opcode_t *buf, unsigned long addr) kp = get_kprobe((void *)addr); faddr = ftrace_location(addr); /* + * Addresses inside the ftrace location are refused by + * arch_check_ftrace_location(). Something went terribly wrong + * if such an address is checked here. + */ + BUG_ON(faddr && faddr != addr); + /* * Use the current code if it is not modified by Kprobe * and it cannot be modified by ftrace. */ -- 1.8.5.6 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/