From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751946AbeBHF2T (ORCPT ); Thu, 8 Feb 2018 00:28:19 -0500 Received: from LGEAMRELO13.lge.com ([156.147.23.53]:54319 "EHLO lgeamrelo13.lge.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751175AbeBHF2Q (ORCPT ); Thu, 8 Feb 2018 00:28:16 -0500 X-Original-SENDERIP: 156.147.1.127 X-Original-MAILFROM: namhyung@kernel.org X-Original-SENDERIP: 10.177.227.17 X-Original-MAILFROM: namhyung@kernel.org Date: Thu, 8 Feb 2018 14:28:13 +0900 From: Namhyung Kim To: Steven Rostedt Cc: linux-kernel@vger.kernel.org, Linus Torvalds , Ingo Molnar , Andrew Morton , Thomas Gleixner , Peter Zijlstra , Masami Hiramatsu , Tom Zanussi , linux-rt-users@vger.kernel.org, linux-trace-users@vger.kernel.org, Arnaldo Carvalho de Melo , Clark Williams , Jiri Olsa , Daniel Bristot de Oliveira , Juri Lelli , Jonathan Corbet , Mathieu Desnoyers , Alexei Starovoitov , kernel-team@lge.com Subject: Re: [PATCH 04/18] tracing/x86: Add arch_get_func_args() function Message-ID: <20180208052813.GD24686@sejong> References: <20180202230458.840252014@goodmis.org> <20180202231017.612058326@goodmis.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20180202231017.612058326@goodmis.org> User-Agent: Mutt/1.9.3 (2018-01-21) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Steve, On Fri, Feb 02, 2018 at 06:05:02PM -0500, Steven Rostedt wrote: > From: "Steven Rostedt (VMware)" > > Add function to get the function arguments from pt_regs. > > Signed-off-by: Steven Rostedt (VMware) > --- > arch/x86/kernel/ftrace.c | 28 ++++++++++++++++++++++++++++ > 1 file changed, 28 insertions(+) > > diff --git a/arch/x86/kernel/ftrace.c b/arch/x86/kernel/ftrace.c > index 01ebcb6f263e..5e845c8cf89d 100644 > --- a/arch/x86/kernel/ftrace.c > +++ b/arch/x86/kernel/ftrace.c > @@ -46,6 +46,34 @@ int ftrace_arch_code_modify_post_process(void) > return 0; > } > > +int arch_get_func_args(struct pt_regs *regs, > + int start, int end, long *args) > +{ > +#ifdef CONFIG_X86_64 > +# define MAX_ARGS 6 > +# define INIT_REGS \ > + { regs->di, regs->si, regs->dx, \ > + regs->cx, regs->r8, regs->r9 \ > + } > +#else > +# define MAX_ARGS 3 > +# define INIT_REGS \ > + { regs->ax, regs->dx, regs->cx } > +#endif > + if (!regs) > + return MAX_ARGS; > + > + { > + long pt_args[] = INIT_REGS; > + int i; > + > + for (i = start; i <= end && i < MAX_ARGS; i++) ^^^^^^^^ I expected it being 'i < end' based on your description. Thanks, Namhyung > + args[i - start] = pt_args[i]; > + > + return i - start; > + } > +} > + > union ftrace_code_union { > char code[MCOUNT_INSN_SIZE]; > struct { > -- > 2.15.1 > >