Riccardo Mancini
67069a1f0f
perf env: Fix memory leak of bpf_prog_info_linear member
...
ASan reported a memory leak caused by info_linear not being deallocated.
The info_linear was allocated during in perf_event__synthesize_one_bpf_prog().
This patch adds the corresponding free() when bpf_prog_info_node
is freed in perf_env__purge_bpf().
$ sudo ./perf record -- sleep 5
[ perf record: Woken up 1 times to write data ]
[ perf record: Captured and wrote 0.025 MB perf.data (8 samples) ]
=================================================================
==297735==ERROR: LeakSanitizer: detected memory leaks
Direct leak of 7688 byte(s) in 19 object(s) allocated from:
#0 0x4f420f in malloc (/home/user/linux/tools/perf/perf+0x4f420f)
#1 0xc06a74 in bpf_program__get_prog_info_linear /home/user/linux/tools/lib/bpf/libbpf.c:11113:16
#2 0xb426fe in perf_event__synthesize_one_bpf_prog /home/user/linux/tools/perf/util/bpf-event.c:191:16
#3 0xb42008 in perf_event__synthesize_bpf_events /home/user/linux/tools/perf/util/bpf-event.c:410:9
#4 0x594596 in record__synthesize /home/user/linux/tools/perf/builtin-record.c:1490:8
#5 0x58c9ac in __cmd_record /home/user/linux/tools/perf/builtin-record.c:1798:8
#6 0x58990b in cmd_record /home/user/linux/tools/perf/builtin-record.c:2901:8
#7 0x7b2a20 in run_builtin /home/user/linux/tools/perf/perf.c:313:11
#8 0x7b12ff in handle_internal_command /home/user/linux/tools/perf/perf.c:365:8
#9 0x7b2583 in run_argv /home/user/linux/tools/perf/perf.c:409:2
#10 0x7b0d79 in main /home/user/linux/tools/perf/perf.c:539:3
#11 0x7fa357ef6b74 in __libc_start_main /usr/src/debug/glibc-2.33-8.fc34.x86_64/csu/../csu/libc-start.c:332:16
Signed-off-by: Riccardo Mancini <rickyman7@gmail.com >
Acked-by: Ian Rogers <irogers@google.com >
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com >
Cc: Alexei Starovoitov <ast@kernel.org >
Cc: Andrii Nakryiko <andrii@kernel.org >
Cc: Daniel Borkmann <daniel@iogearbox.net >
Cc: Jiri Olsa <jolsa@redhat.com >
Cc: John Fastabend <john.fastabend@gmail.com >
Cc: KP Singh <kpsingh@kernel.org >
Cc: Mark Rutland <mark.rutland@arm.com >
Cc: Martin KaFai Lau <kafai@fb.com >
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Peter Zijlstra <peterz@infradead.org >
Cc: Song Liu <songliubraving@fb.com >
Cc: Yonghong Song <yhs@fb.com >
Link: http://lore.kernel.org/lkml/20210602224024.300485-1-rickyman7@gmail.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com >
2021-06-04 10:26:20 -03:00
..
2021-04-07 16:23:20 -03:00
2021-03-23 17:46:44 -03:00
2020-01-14 12:02:19 -03:00
2021-03-23 17:13:43 -03:00
2020-11-12 17:55:41 -03:00
2021-05-19 10:31:04 -03:00
2021-03-23 17:13:43 -03:00
2021-03-23 17:13:43 -03:00
2019-11-28 08:08:38 -03:00
2019-11-28 08:08:38 -03:00
2021-04-20 08:40:20 -03:00
2021-03-06 16:42:31 -03:00
2019-03-11 11:56:02 -03:00
2021-02-16 11:52:00 -03:00
2021-04-23 15:34:32 -03:00
2021-02-18 16:11:19 -03:00
2021-04-07 16:18:49 -03:00
2020-03-09 21:43:25 -03:00
2021-06-01 10:56:27 -03:00
2021-04-29 10:30:58 -03:00
2019-02-19 16:11:56 -03:00
2019-02-19 16:11:56 -03:00
2021-03-16 10:01:44 -03:00
2020-05-05 16:35:29 -03:00
2021-03-23 17:13:43 -03:00
2020-11-04 09:42:40 -03:00
2020-06-09 12:40:04 -03:00
2019-09-20 09:19:20 -03:00
2020-05-28 10:03:27 -03:00
2021-05-10 09:01:00 -03:00
2021-02-18 16:41:40 -03:00
2021-02-18 16:41:40 -03:00
2019-08-29 17:38:32 -03:00
2019-08-26 11:58:29 -03:00
2019-07-09 10:13:27 -03:00
2021-03-23 17:13:43 -03:00
2021-03-23 17:13:43 -03:00
2020-10-14 13:34:26 -03:00
2019-08-14 10:48:39 -03:00
2020-04-16 12:19:08 -03:00
2021-02-08 16:39:14 -03:00
2020-09-28 09:18:06 -03:00
2020-08-06 09:33:57 -03:00
2020-08-06 09:33:57 -03:00
2020-05-28 10:03:26 -03:00
2019-08-31 22:24:10 -03:00
2019-08-31 22:24:10 -03:00
2019-07-09 10:13:26 -03:00
2019-05-15 16:36:49 -03:00
2021-04-29 10:30:58 -03:00
2021-01-20 14:34:21 -03:00
2019-10-15 12:05:18 -03:00
2019-09-25 09:51:49 -03:00
2020-05-28 10:03:27 -03:00
2020-05-28 10:03:27 -03:00
2019-02-06 10:00:39 -03:00
2020-12-24 10:05:28 -03:00
2020-12-24 10:05:28 -03:00
2019-08-22 17:16:57 -03:00
2020-05-28 10:03:27 -03:00
2021-03-23 17:13:43 -03:00
2021-03-23 17:13:43 -03:00
2021-04-29 10:30:58 -03:00
2021-04-29 10:30:58 -03:00
2021-04-29 10:30:58 -03:00
2021-04-20 14:46:48 -03:00
2020-11-27 08:37:15 -03:00
2021-02-18 16:12:51 -03:00
2019-07-29 18:34:42 -03:00
2021-01-20 14:34:20 -03:00
2021-01-20 14:34:20 -03:00
2021-03-23 17:13:43 -03:00
2021-03-30 12:45:59 -03:00
2021-02-17 15:15:06 -03:00
2019-09-20 09:19:20 -03:00
2020-11-27 08:36:53 -03:00
2021-03-23 17:13:43 -03:00
2020-10-14 11:28:52 -03:00
2019-11-19 19:12:26 -03:00
2021-06-01 10:11:24 -03:00
2021-03-23 17:13:43 -03:00
2021-03-01 14:47:50 -03:00
2021-06-04 10:26:20 -03:00
2020-11-04 09:42:41 -03:00
2021-02-08 17:09:11 -03:00
2021-05-21 16:41:37 -03:00
2021-04-29 10:30:59 -03:00
2021-04-29 10:30:59 -03:00
2021-04-29 10:30:59 -03:00
2021-05-21 16:50:17 -03:00
2021-04-15 16:33:57 -03:00
2020-05-28 10:03:24 -03:00
2021-01-20 14:34:21 -03:00
2020-05-28 10:03:24 -03:00
2021-06-04 10:04:20 -03:00
2021-06-04 10:04:20 -03:00
2020-11-30 09:48:07 -03:00
2019-08-15 12:25:55 -03:00
2020-11-16 14:09:18 -03:00
2021-03-23 17:13:43 -03:00
2020-06-22 16:28:09 -03:00
2020-11-16 14:09:18 -03:00
2019-11-28 08:08:38 -03:00
2019-11-28 08:08:38 -03:00
2020-05-29 16:51:38 -03:00
2019-11-29 12:20:45 -03:00
2019-09-25 16:26:41 -03:00
2019-08-26 11:58:29 -03:00
2019-07-09 10:13:26 -03:00
2020-11-03 08:26:55 -03:00
2020-11-27 14:19:33 -03:00
2021-03-23 17:13:43 -03:00
2020-08-06 09:35:06 -03:00
2019-07-09 10:13:26 -03:00
2021-04-29 10:30:59 -03:00
2021-04-29 10:30:59 -03:00
2020-05-05 16:35:30 -03:00
2019-06-05 17:36:37 +02:00
2021-05-19 10:35:31 -03:00
2019-06-05 17:36:37 +02:00
2021-02-08 17:02:00 -03:00
2021-02-08 17:02:00 -03:00
2021-04-20 08:40:20 -03:00
2021-04-20 08:40:20 -03:00
2021-02-03 13:10:44 -03:00
2021-04-29 10:31:00 -03:00
2020-05-28 10:03:27 -03:00
2019-09-20 10:28:26 -03:00
2021-03-23 17:13:43 -03:00
2021-03-23 17:13:43 -03:00
2019-08-29 17:38:32 -03:00
2019-09-20 09:19:20 -03:00
2021-03-23 17:13:43 -03:00
2021-02-18 16:14:33 -03:00
2020-12-19 17:52:24 -03:00
2021-04-23 16:03:09 -03:00
2021-03-23 17:13:43 -03:00
2019-11-26 11:07:46 -03:00
2020-11-04 09:42:40 -03:00
2019-08-31 19:10:40 -03:00
2021-02-08 16:25:00 -03:00
2021-04-06 13:32:03 -03:00
2019-09-20 09:19:22 -03:00
2021-04-08 14:24:14 -03:00
2021-04-08 14:23:39 -03:00
2020-03-12 11:32:46 -03:00
2020-01-06 11:46:09 -03:00
2021-02-03 13:10:44 -03:00
2021-02-03 13:10:44 -03:00
2020-04-30 10:48:32 -03:00
2020-05-28 10:03:27 -03:00
2019-08-31 19:10:19 -03:00
2021-04-29 10:30:59 -03:00
2021-04-29 10:30:59 -03:00
2021-05-21 07:47:56 -03:00
2021-04-29 10:30:59 -03:00
2021-05-19 14:23:23 -03:00
2021-04-29 10:30:59 -03:00
2020-12-17 14:36:16 -03:00
2019-05-15 16:36:49 -03:00
2020-08-14 09:15:47 -03:00
2020-08-14 09:15:47 -03:00
2019-08-31 22:24:10 -03:00
2019-08-31 22:24:10 -03:00
2021-06-01 10:32:00 -03:00
2021-06-01 10:32:00 -03:00
2021-02-08 16:25:00 -03:00
2019-10-10 09:29:33 -03:00
2021-02-18 16:24:43 -03:00
2019-09-20 09:19:20 -03:00
2019-05-28 18:37:44 -03:00
2021-05-19 10:30:37 -03:00
2020-05-29 16:51:38 -03:00
2021-04-29 10:30:59 -03:00
2021-04-29 10:30:59 -03:00
2021-04-29 10:30:59 -03:00
2021-04-29 10:30:59 -03:00
2020-10-01 12:10:56 -03:00
2021-03-23 17:13:43 -03:00
2019-11-18 19:09:23 -03:00
2020-12-28 09:53:28 -03:00
2019-11-18 19:08:02 -03:00
2021-06-01 10:11:24 -03:00
2020-09-18 09:20:47 -03:00
2020-05-28 10:03:27 -03:00
2021-04-29 10:30:59 -03:00
2021-04-29 10:30:58 -03:00
2019-01-25 15:12:10 +01:00
2019-06-05 17:37:04 +02:00
2019-01-25 15:12:10 +01:00
2021-05-10 09:00:59 -03:00
2021-01-20 14:34:20 -03:00
2019-07-09 14:59:11 -03:00
2019-07-09 14:59:11 -03:00
2019-09-20 09:19:20 -03:00
2020-04-16 12:19:15 -03:00
2021-03-23 17:13:43 -03:00
2021-04-08 14:24:14 -03:00
2020-11-30 15:15:30 -03:00
2020-11-30 15:15:30 -03:00
2021-05-10 09:01:00 -03:00
2021-04-29 10:30:59 -03:00
2019-07-09 10:13:26 -03:00
2021-01-20 14:34:21 -03:00
2020-11-30 14:56:52 -03:00
2020-05-05 16:35:29 -03:00
2021-03-26 08:50:00 -03:00
2021-03-26 08:49:54 -03:00
2019-10-11 10:57:00 -03:00
2019-10-11 10:57:00 -03:00
2019-11-28 08:08:38 -03:00
2019-02-06 10:00:38 -03:00
2020-01-30 11:55:26 +01:00
2021-06-04 10:05:23 -03:00
2021-04-20 08:40:20 -03:00
2021-03-09 09:03:40 -03:00
2021-04-20 08:40:20 -03:00
2019-08-31 19:10:19 -03:00
2021-03-23 17:13:43 -03:00
2020-10-14 13:34:26 -03:00
2020-10-14 13:34:26 -03:00
2019-07-09 10:13:26 -03:00
2021-03-23 17:13:43 -03:00
2021-02-17 15:15:06 -03:00
2021-02-17 15:15:06 -03:00
2019-07-09 10:13:26 -03:00
2019-01-25 15:12:10 +01:00
2019-09-20 09:19:21 -03:00
2019-08-29 17:38:31 -03:00
2021-02-08 17:09:11 -03:00
2021-03-08 11:17:51 -03:00
2021-06-04 10:06:27 -03:00
2020-10-14 08:46:42 -03:00
2021-02-18 16:38:31 -03:00
2020-11-03 08:30:34 -03:00
2019-08-31 22:24:05 -03:00
2021-03-29 10:39:10 -03:00
2020-04-03 09:37:55 -03:00
2021-03-01 14:49:28 -03:00
2020-05-29 16:50:26 -03:00
2021-01-20 14:25:28 -03:00
2021-04-29 10:30:58 -03:00
2019-08-29 08:36:12 -03:00
2019-08-29 08:36:12 -03:00
2020-05-05 16:35:29 -03:00
2021-03-25 08:59:10 -03:00
2020-04-18 09:05:01 -03:00
2020-04-18 09:05:01 -03:00
2019-10-15 08:36:22 -03:00
2019-10-15 08:36:22 -03:00
2020-07-10 08:20:01 -03:00
2020-05-05 16:35:30 -03:00
2020-05-05 16:35:29 -03:00
2020-09-17 15:47:58 -03:00
2020-09-17 15:47:58 -03:00
2021-02-03 13:13:53 -03:00
2019-11-05 08:39:27 -03:00
2021-03-06 16:54:26 -03:00
2019-08-29 17:38:32 -03:00
2019-09-20 09:19:20 -03:00
2019-11-05 08:39:27 -03:00
2019-08-29 17:38:32 -03:00
2021-04-29 10:31:00 -03:00
2021-04-29 10:31:00 -03:00
2021-03-15 11:36:54 -03:00
2021-03-15 11:36:54 -03:00
2021-02-18 14:20:32 -03:00
2021-03-23 17:13:43 -03:00
2019-11-26 11:07:46 -03:00
2019-11-26 11:07:46 -03:00
2019-09-20 09:19:20 -03:00
2020-04-16 12:19:08 -03:00
2020-09-10 11:55:37 -03:00
2019-08-31 19:10:19 -03:00
2021-03-24 10:38:56 -03:00
2019-09-20 09:19:20 -03:00
2020-09-01 12:15:21 -03:00