Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754756AbbBTNdm (ORCPT ); Fri, 20 Feb 2015 08:33:42 -0500 Received: from cantor2.suse.de ([195.135.220.15]:35520 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754265AbbBTNdl (ORCPT ); Fri, 20 Feb 2015 08:33:41 -0500 Date: Fri, 20 Feb 2015 14:34:40 +0100 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 Subject: Re: [PATCH 1/2] kprobes/x86: Use 5-byte NOP when the code might be modified by ftrace Message-ID: <20150220133440.GK5136@pathway.suse.cz> References: <20150218212205.GA26334@gmail.com> <1424427402-11795-1-git-send-email-pmladek@suse.cz> <1424427402-11795-2-git-send-email-pmladek@suse.cz> <20150220102625.GC25076@gmail.com> <54E72ABA.8050804@hitachi.com> <20150220125223.GA28882@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20150220125223.GA28882@gmail.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1651 Lines: 44 On Fri 2015-02-20 13:52:23, Ingo Molnar wrote: > > * Masami Hiramatsu wrote: > > > (2015/02/20 19:26), Ingo Molnar wrote: > > > > > > * Petr Mladek wrote: > > > > > >> can_probe() checks if the given address points to the > > >> beginning of an instruction. It analyzes all the > > >> instructions from the beginning of the function until the > > >> given address. The code might be modified by another > > >> Kprobe. In this case, the current code is read into a > > >> buffer, int3 breakpoint is replaced by the saved opcode > > >> in the buffer, and can_probe() analyzes the buffer > > >> instead. > > >> > > >> [...] > > > > > > Had to drop this patch due to build failures on 32-bit x86: > > > > > > arch/x86/kernel/kprobes/core.c:258:40: error: ‘MCOUNT_INSN_SIZE’ undeclared (first use in this function) > > > > Oops, MCOUNT_INSN_SIZE actually depends on > > CONFIG_FUNCTION_TRACER... I think we can use 5 instead of > > that since we are copying. I'll use 5 for now. > Or just make the define more widely available? It's not > like the size changes from disabling the function tracer. I would do this in a separate patch that would consolidate all NOP_ATOMIC5 users: ftrace, jump_labels, and kprobe. The number 5 is hardcoded more times in arch/x86/kernel/kprobes/core.c. I'll put it into my TODO list. Best Regards, Petr -- 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/