]> www.infradead.org Git - users/willy/xarray.git/commitdiff
perf machine: Fix insertion of PERF_RECORD_KSYMBOL related kernel maps
authorNamhyung Kim <namhyung@kernel.org>
Fri, 28 Feb 2025 21:17:34 +0000 (18:17 -0300)
committerNamhyung Kim <namhyung@kernel.org>
Thu, 6 Mar 2025 07:04:07 +0000 (23:04 -0800)
This was detected at the end of a 'perf record' session when build-id
collection was enabled and thus the BPF programs put in place while the
session was running, some even put in place by perf itself were
processed and inserted, with some overlaps related to BPF trampolines
and programs took place.

Using maps__fixup_overlap_and_insert() instead of maps__insert() "fixes"
the problem, in the sense that overlaps will be dealt with and then the
consistency will be kept, but it would be interesting to fully
understand why such overlaps take place and how to deal with them when
doing symbol resolution.

Reported-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Suggested-by: Ian Rogers <irogers@google.com>
Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Reviewed-by: Ian Rogers <irogers@google.com>
Link: https://lore.kernel.org/lkml/CAP-5=fXEEMFgPF2aZhKsfrY_En+qoqX20dWfuE_ad73Uxf0ZHQ@mail.gmail.com
Link: https://lore.kernel.org/r/20250228211734.33781-7-acme@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
tools/perf/util/machine.c

index f7df01adad61ceea6ebb5874f74f80ff8e97d3d9..a81ffd2d1a054d60a73dcdc152e339f764118805 100644 (file)
@@ -718,7 +718,7 @@ static int machine__process_ksymbol_register(struct machine *machine,
 
                map__set_start(map, event->ksymbol.addr);
                map__set_end(map, map__start(map) + event->ksymbol.len);
-               err = maps__insert(machine__kernel_maps(machine), map);
+               err = maps__fixup_overlap_and_insert(machine__kernel_maps(machine), map);
                if (err) {
                        err = -ENOMEM;
                        goto out;