From mboxrd@z Thu Jan 1 00:00:00 1970 From: Steven Rostedt Subject: Re: [PATCH 09/18] tracing: Add indexing of arguments for function based events Date: Thu, 8 Feb 2018 10:43:43 -0500 Message-ID: <20180208104343.2fa63eda@gandalf.local.home> References: <20180202230458.840252014@goodmis.org> <20180202231018.338259949@goodmis.org> <20180208105924.GB26290@sejong> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit 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 To: Namhyung Kim Return-path: In-Reply-To: <20180208105924.GB26290@sejong> Sender: linux-kernel-owner@vger.kernel.org List-Id: linux-rt-users.vger.kernel.org On Thu, 8 Feb 2018 19:59:24 +0900 Namhyung Kim wrote: > > @@ -347,6 +361,8 @@ static long long get_arg(struct func_arg *arg, unsigned long val) > > char buf[8]; > > int ret; > > > > + val += arg->index; > > + > > if (!arg->indirect) > > return val; > > So this also works without the indirect, and just add the immediate to > the value. Not sure what you are asking here. The immediate adds to the current value, where as the indirect will then look what's at that location. If the arg (val) is 0xffffffffabcd0000 u64 val+8 Will return: 0xffffffffabcd0008 u64 val[1] will return what's at location 0xffffffffabcd0008 "u64 val+8[0]" is the same as "u64 val[1]" Note: "u64 val[0]+8" will return what's at location 0xffffffffabcd0000 plus 8. -- Steve