File perf-bpf-Avoid-memory-leak-from-perf_env__insert_btf.patch of Package perf
111
1
From: Ian Rogers <irogers@google.com>
2
Date: Thu, 11 Nov 2021 23:45:25 -0800
3
Subject: perf bpf: Avoid memory leak from perf_env__insert_btf()
4
Git-commit: 4924b1f7c46711762fd0e65c135ccfbcfd6ded1f
5
Patch-mainline: v5.16-rc1
6
References: git-fixes
7
8
perf_env__insert_btf() doesn't insert if a duplicate BTF id is
9
encountered and this causes a memory leak. Modify the function to return
10
a success/error value and then free the memory if insertion didn't
11
happen.
12
13
v2. Adds a return -1 when the insertion error occurs in
14
perf_env__fetch_btf. This doesn't affect anything as the result is
15
never checked.
16
17
Fixes: 3792cb2ff43b1b19 ("perf bpf: Save BTF in a rbtree in perf_env")
18
Signed-off-by: Ian Rogers <irogers@google.com>
19
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
20
Cc: Alexei Starovoitov <ast@kernel.org>
21
Cc: Andrii Nakryiko <andrii@kernel.org>
22
Cc: Daniel Borkmann <daniel@iogearbox.net>
23
Cc: Jiri Olsa <jolsa@redhat.com>
24
Cc: John Fastabend <john.fastabend@gmail.com>
25
Cc: KP Singh <kpsingh@kernel.org>
26
Cc: Mark Rutland <mark.rutland@arm.com>
27
Cc: Martin KaFai Lau <kafai@fb.com>
28
Cc: Namhyung Kim <namhyung@kernel.org>
29
Cc: Peter Zijlstra <peterz@infradead.org>
30
Cc: Song Liu <songliubraving@fb.com>
31
Cc: Stephane Eranian <eranian@google.com>
32
Cc: Tiezhu Yang <yangtiezhu@loongson.cn>
33
Cc: Yonghong Song <yhs@fb.com>
34
Cc: bpf@vger.kernel.org
35
Cc: netdev@vger.kernel.org
36
Link: http://lore.kernel.org/lkml/20211112074525.121633-1-irogers@google.com
37
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
38
Signed-off-by: Tony Jones <tonyj@suse.de>
39
---
40
tools/perf/util/bpf-event.c | 6 +++++-
41
tools/perf/util/env.c | 5 ++++-
42
tools/perf/util/env.h | 2 +-
43
3 files changed, 10 insertions(+), 3 deletions(-)
44
45
diff --git a/tools/perf/util/bpf-event.c b/tools/perf/util/bpf-event.c
46
index 4d3b4cdce176..d49cdff8fb39 100644
47
--- a/tools/perf/util/bpf-event.c
48
+++ b/tools/perf/util/bpf-event.c
49
50
node->data_size = data_size;
51
memcpy(node->data, data, data_size);
52
53
- perf_env__insert_btf(env, node);
54
+ if (!perf_env__insert_btf(env, node)) {
55
+ /* Insertion failed because of a duplicate. */
56
+ free(node);
57
+ return -1;
58
+ }
59
return 0;
60
}
61
62
diff --git a/tools/perf/util/env.c b/tools/perf/util/env.c
63
index 17f1dd0680b4..b9904896eb97 100644
64
--- a/tools/perf/util/env.c
65
+++ b/tools/perf/util/env.c
66
67
return node;
68
}
69
70
-void perf_env__insert_btf(struct perf_env *env, struct btf_node *btf_node)
71
+bool perf_env__insert_btf(struct perf_env *env, struct btf_node *btf_node)
72
{
73
struct rb_node *parent = NULL;
74
__u32 btf_id = btf_node->id;
75
struct btf_node *node;
76
struct rb_node **p;
77
+ bool ret = true;
78
79
down_write(&env->bpf_progs.lock);
80
p = &env->bpf_progs.btfs.rb_node;
81
82
p = &(*p)->rb_right;
83
} else {
84
pr_debug("duplicated btf %u\n", btf_id);
85
+ ret = false;
86
goto out;
87
}
88
}
89
90
env->bpf_progs.btfs_cnt++;
91
out:
92
up_write(&env->bpf_progs.lock);
93
+ return ret;
94
}
95
96
struct btf_node *perf_env__find_btf(struct perf_env *env, __u32 btf_id)
97
diff --git a/tools/perf/util/env.h b/tools/perf/util/env.h
98
index 1383876f72b3..163e5ec503a2 100644
99
--- a/tools/perf/util/env.h
100
+++ b/tools/perf/util/env.h
101
102
struct bpf_prog_info_node *info_node);
103
struct bpf_prog_info_node *perf_env__find_bpf_prog_info(struct perf_env *env,
104
__u32 prog_id);
105
-void perf_env__insert_btf(struct perf_env *env, struct btf_node *btf_node);
106
+bool perf_env__insert_btf(struct perf_env *env, struct btf_node *btf_node);
107
struct btf_node *perf_env__find_btf(struct perf_env *env, __u32 btf_id);
108
109
int perf_env__numa_node(struct perf_env *env, int cpu);
110
111