]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
perf build-id: Mark DSO in sample callchains
authorIan Rogers <irogers@google.com>
Thu, 24 Jul 2025 16:32:44 +0000 (09:32 -0700)
committerNamhyung Kim <namhyung@kernel.org>
Fri, 25 Jul 2025 17:37:55 +0000 (10:37 -0700)
Previously only the sample IP's map DSO would be marked hit for the
purposes of populating the build ID cache. Walk the call chain to mark
all IPs and DSOs.

Signed-off-by: Ian Rogers <irogers@google.com>
Link: https://lore.kernel.org/r/20250724163302.596743-5-irogers@google.com
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
tools/perf/util/build-id.c

index aa35dceace90c80d40ecdc1003520f98a73ddc4a..3386fa8e1e7e8b412d04c5ba96cfa35448a66899 100644 (file)
 
 static bool no_buildid_cache;
 
+static int mark_dso_hit_callback(struct callchain_cursor_node *node, void *data __maybe_unused)
+{
+       struct map *map = node->ms.map;
+
+       if (map)
+               dso__set_hit(map__dso(map));
+
+       return 0;
+}
+
 int build_id__mark_dso_hit(const struct perf_tool *tool __maybe_unused,
                           union perf_event *event,
                           struct perf_sample *sample,
-                          struct evsel *evsel __maybe_unused,
+                          struct evsel *evsel,
                           struct machine *machine)
 {
        struct addr_location al;
@@ -63,6 +73,11 @@ int build_id__mark_dso_hit(const struct perf_tool *tool __maybe_unused,
                dso__set_hit(map__dso(al.map));
 
        addr_location__exit(&al);
+
+       sample__for_each_callchain_node(thread, evsel, sample, PERF_MAX_STACK_DEPTH,
+                                       /*symbols=*/false, mark_dso_hit_callback, /*data=*/NULL);
+
+
        thread__put(thread);
        return 0;
 }