Re: [PATCH 09/18] tracing: Add indexing of arguments for function based events

From: Steven Rostedt
Date: Thu Feb 08 2018 - 10:43:53 EST


On Thu, 8 Feb 2018 19:59:24 +0900
Namhyung Kim <namhyung@xxxxxxxxxx> 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