Commit 1981da1f authored by Ian Rogers's avatar Ian Rogers Committed by Arnaldo Carvalho de Melo

perf machine: Don't leak module maps

machine__addnew_module_map requires a put on its result. Add this and
narrow the scope of map to make the correctness more obvious. This
leak was caught with leak sanitizer and the reference count checker.
Signed-off-by: default avatarIan Rogers <irogers@google.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Ali Saidi <alisaidi@amazon.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Athira Rajeev <atrajeev@linux.vnet.ibm.com>
Cc: Brian Robbins <brianrob@linux.microsoft.com>
Cc: Changbin Du <changbin.du@huawei.com>
Cc: Dmitrii Dolgov <9erthalion6@gmail.com>
Cc: Fangrui Song <maskray@google.com>
Cc: German Gomez <german.gomez@arm.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Ivan Babrou <ivan@cloudflare.com>
Cc: James Clark <james.clark@arm.com>
Cc: Jing Zhang <renyu.zj@linux.alibaba.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: John Garry <john.g.garry@oracle.com>
Cc: K Prateek Nayak <kprateek.nayak@amd.com>
Cc: Kan Liang <kan.liang@linux.intel.com>
Cc: Leo Yan <leo.yan@linaro.org>
Cc: Liam Howlett <liam.howlett@oracle.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Miguel Ojeda <ojeda@kernel.org>
Cc: Mike Leach <mike.leach@linaro.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Naveen N. Rao <naveen.n.rao@linux.vnet.ibm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Ravi Bangoria <ravi.bangoria@amd.com>
Cc: Sean Christopherson <seanjc@google.com>
Cc: Steinar H. Gunderson <sesse@google.com>
Cc: Suzuki Poulouse <suzuki.poulose@arm.com>
Cc: Wenyu Liu <liuwenyu7@huawei.com>
Cc: Will Deacon <will@kernel.org>
Cc: Yang Jihong <yangjihong1@huawei.com>
Cc: Ye Xingchen <ye.xingchen@zte.com.cn>
Cc: Yuan Can <yuancan@huawei.com>
Cc: coresight@lists.linaro.org
Cc: linux-arm-kernel@lists.infradead.org
Link: https://lore.kernel.org/r/20230608232823.4027869-20-irogers@google.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 34b29bd6
...@@ -1797,7 +1797,6 @@ static int machine__process_kernel_mmap_event(struct machine *machine, ...@@ -1797,7 +1797,6 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
struct extra_kernel_map *xm, struct extra_kernel_map *xm,
struct build_id *bid) struct build_id *bid)
{ {
struct map *map;
enum dso_space_type dso_space; enum dso_space_type dso_space;
bool is_kernel_mmap; bool is_kernel_mmap;
const char *mmap_name = machine->mmap_name; const char *mmap_name = machine->mmap_name;
...@@ -1823,8 +1822,8 @@ static int machine__process_kernel_mmap_event(struct machine *machine, ...@@ -1823,8 +1822,8 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
} }
if (xm->name[0] == '/' || if (xm->name[0] == '/' ||
(!is_kernel_mmap && xm->name[0] == '[')) { (!is_kernel_mmap && xm->name[0] == '[')) {
map = machine__addnew_module_map(machine, xm->start, struct map *map = machine__addnew_module_map(machine, xm->start, xm->name);
xm->name);
if (map == NULL) if (map == NULL)
goto out_problem; goto out_problem;
...@@ -1833,6 +1832,7 @@ static int machine__process_kernel_mmap_event(struct machine *machine, ...@@ -1833,6 +1832,7 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
if (build_id__is_defined(bid)) if (build_id__is_defined(bid))
dso__set_build_id(map__dso(map), bid); dso__set_build_id(map__dso(map), bid);
map__put(map);
} else if (is_kernel_mmap) { } else if (is_kernel_mmap) {
const char *symbol_name = xm->name + strlen(mmap_name); const char *symbol_name = xm->name + strlen(mmap_name);
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment