Re: [PATCH v2] perf libunwind: Fixup conversion perf_sample->user_regs to a pointer

From: Ian Rogers
Date: Mon Mar 17 2025 - 12:09:59 EST


On Fri, Mar 14, 2025 at 6:12 PM Namhyung Kim <namhyung@xxxxxxxxxx> wrote:
>
> On Wed, Mar 12, 2025 at 08:31:21PM -0700, Ian Rogers wrote:
> > From: Arnaldo Carvalho de Melo <acme@xxxxxxxxxx>
> >
> > The dc6d2bc2d893a878 ("perf sample: Make user_regs and intr_regs optional") misses
> > the changes to a file, resulting in this problem:
> >
> > $ make LIBUNWIND=1 -C tools/perf O=/tmp/build/perf-tools-next install-bin
> > <SNIP>
> > CC /tmp/build/perf-tools-next/util/unwind-libunwind-local.o
> > CC /tmp/build/perf-tools-next/util/unwind-libunwind.o
> > <SNIP>
> > util/unwind-libunwind-local.c: In function ‘access_mem’:
> > util/unwind-libunwind-local.c:582:56: error: ‘ui->sample->user_regs’ is a pointer; did you mean to use ‘->’?
> > 582 | if (__write || !stack || !ui->sample->user_regs.regs) {
> > | ^
> > | ->
> > util/unwind-libunwind-local.c:587:38: error: passing argument 2 of ‘perf_reg_value’ from incompatible pointer type [-Wincompatible-pointer-types]
> > 587 | ret = perf_reg_value(&start, &ui->sample->user_regs,
> > | ^~~~~~~~~~~~~~~~~~~~~~
> > | |
> > | struct regs_dump **
> > <SNIP>
> > ⬢ [acme@toolbox perf-tools-next]$ git bisect bad
> > dc6d2bc2d893a878e7b58578ff01b4738708deb4 is the first bad commit
> > commit dc6d2bc2d893a878e7b58578ff01b4738708deb4 (HEAD)
> > Author: Ian Rogers <irogers@xxxxxxxxxx>
> > Date: Mon Jan 13 11:43:45 2025 -0800
> >
> > perf sample: Make user_regs and intr_regs optional
> >
> > Detected using:
> >
> > make -C tools/perf build-test
> >
> > Fixes: dc6d2bc2d893a878 ("perf sample: Make user_regs and intr_regs optional")
> > Cc: Adrian Hunter <adrian.hunter@xxxxxxxxx>
> > Cc: Alexander Shishkin <alexander.shishkin@xxxxxxxxxxxxxxx>
> > Cc: Andi Kleen <ak@xxxxxxxxxxxxxxx>
> > Cc: Charlie Jenkins <charlie@xxxxxxxxxxxx>
> > Cc: Ian Rogers <irogers@xxxxxxxxxx>
> > Cc: Ingo Molnar <mingo@xxxxxxxxxx>
> > Cc: James Clark <james.clark@xxxxxxxxxx>
> > Cc: John Garry <john.g.garry@xxxxxxxxxx>
> > Cc: Kan Liang <kan.liang@xxxxxxxxxxxxxxx>
> > Cc: Leo Yan <leo.yan@xxxxxxxxx>
> > Cc: Mark Rutland <mark.rutland@xxxxxxx>
> > Cc: Michael Petlan <mpetlan@xxxxxxxxxx>
> > Cc: Namhyung Kim <namhyung@xxxxxxxxxx>
> > Cc: Peter Zijlstra <peterz@xxxxxxxxxxxxx>
> > Cc: Tavian Barnes <tavianator@xxxxxxxxxxxxxx>
> > Cc: Veronika Molnarova <vmolnaro@xxxxxxxxxx>
> > Cc: coresight@xxxxxxxxxxxxxxxx
> > Cc: linux-arm-kernel@xxxxxxxxxxxxxxxxxxx
> > Signed-off-by: Arnaldo Carvalho de Melo <acme@xxxxxxxxxx>
> > Reviewed-by: Ian Rogers <irogers@xxxxxxxxxx>
>
> I think you need to add your own Signed-off-by in this case.
> I'll change it for you, ok?

Sure.

Thanks,
Ian