mirror of
https://github.com/torvalds/linux.git
synced 2024-12-11 05:33:09 +00:00
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: Ian 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.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
34b29bd61d
commit
1981da1fe2
@ -1797,7 +1797,6 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
|
||||
struct extra_kernel_map *xm,
|
||||
struct build_id *bid)
|
||||
{
|
||||
struct map *map;
|
||||
enum dso_space_type dso_space;
|
||||
bool is_kernel_mmap;
|
||||
const char *mmap_name = machine->mmap_name;
|
||||
@ -1823,8 +1822,8 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
|
||||
}
|
||||
if (xm->name[0] == '/' ||
|
||||
(!is_kernel_mmap && xm->name[0] == '[')) {
|
||||
map = machine__addnew_module_map(machine, xm->start,
|
||||
xm->name);
|
||||
struct map *map = machine__addnew_module_map(machine, xm->start, xm->name);
|
||||
|
||||
if (map == NULL)
|
||||
goto out_problem;
|
||||
|
||||
@ -1833,6 +1832,7 @@ static int machine__process_kernel_mmap_event(struct machine *machine,
|
||||
if (build_id__is_defined(bid))
|
||||
dso__set_build_id(map__dso(map), bid);
|
||||
|
||||
map__put(map);
|
||||
} else if (is_kernel_mmap) {
|
||||
const char *symbol_name = xm->name + strlen(mmap_name);
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user