diff options
author | Ian Rogers <irogers@google.com> | 2024-02-29 07:20:48 +0100 |
---|---|---|
committer | Namhyung Kim <namhyung@kernel.org> | 2024-03-01 03:06:00 +0100 |
commit | ec42d3d56819688537ec7ee37ce97f695fb8e6d7 (patch) | |
tree | 8a05182638b73f6c18f6ab99b14ab20357d860c9 /tools/perf | |
parent | libperf evlist: Avoid out-of-bounds access (diff) | |
download | linux-ec42d3d56819688537ec7ee37ce97f695fb8e6d7.tar.xz linux-ec42d3d56819688537ec7ee37ce97f695fb8e6d7.zip |
perf map: Fix map reference count issues
The find will get the map, ensure puts are done on all paths.
Signed-off-by: Ian Rogers <irogers@google.com>
Acked-by: Namhyung Kim <namhyung@kernel.org>
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
Link: https://lore.kernel.org/r/20240229062048.558799-1-irogers@google.com
Diffstat (limited to 'tools/perf')
-rw-r--r-- | tools/perf/util/maps.c | 14 | ||||
-rw-r--r-- | tools/perf/util/probe-event.c | 4 |
2 files changed, 8 insertions, 10 deletions
diff --git a/tools/perf/util/maps.c b/tools/perf/util/maps.c index 53aea6d2ef93..ce13145a9f8e 100644 --- a/tools/perf/util/maps.c +++ b/tools/perf/util/maps.c @@ -611,14 +611,14 @@ struct symbol *maps__find_symbol(struct maps *maps, u64 addr, struct map **mapp) struct symbol *result = NULL; /* Ensure map is loaded before using map->map_ip */ - if (map != NULL && map__load(map) >= 0) { - if (mapp) - *mapp = map; - + if (map != NULL && map__load(map) >= 0) result = map__find_symbol(map, map__map_ip(map, addr)); - if (!mapp) - map__put(map); - } + + if (mapp) + *mapp = map; + else + map__put(map); + return result; } diff --git a/tools/perf/util/probe-event.c b/tools/perf/util/probe-event.c index be71abe8b9b0..2a0ad9ecf0a2 100644 --- a/tools/perf/util/probe-event.c +++ b/tools/perf/util/probe-event.c @@ -2274,9 +2274,7 @@ static int find_perf_probe_point_from_map(struct probe_trace_point *tp, ret = pp->function ? 0 : -ENOMEM; out: - if (map && !is_kprobe) { - map__put(map); - } + map__put(map); return ret; } |