Matt Fleming
be8d32ebfa
perf hist: Update hist symbol when updating maps
...
commit ac01c8c4246546fd8340a232f3ada1921dc0ee48 upstream.
AddressSanitizer found a use-after-free bug in the symbol code which
manifested as 'perf top' segfaulting.
==1238389==ERROR: AddressSanitizer: heap-use-after-free on address 0x60b00c48844b at pc 0x5650d8035961 bp 0x7f751aaecc90 sp 0x7f751aaecc80
READ of size 1 at 0x60b00c48844b thread T193
#0 0x5650d8035960 in _sort__sym_cmp util/sort.c:310
#1 0x5650d8043744 in hist_entry__cmp util/hist.c:1286
#2 0x5650d8043951 in hists__findnew_entry util/hist.c:614
#3 0x5650d804568f in __hists__add_entry util/hist.c:754
#4 0x5650d8045bf9 in hists__add_entry util/hist.c:772
#5 0x5650d8045df1 in iter_add_single_normal_entry util/hist.c:997
#6 0x5650d8043326 in hist_entry_iter__add util/hist.c:1242
#7 0x5650d7ceeefe in perf_event__process_sample /home/matt/src/linux/tools/perf/builtin-top.c:845
#8 0x5650d7ceeefe in deliver_event /home/matt/src/linux/tools/perf/builtin-top.c:1208
#9 0x5650d7fdb51b in do_flush util/ordered-events.c:245
#10 0x5650d7fdb51b in __ordered_events__flush util/ordered-events.c:324
#11 0x5650d7ced743 in process_thread /home/matt/src/linux/tools/perf/builtin-top.c:1120
#12 0x7f757ef1f133 in start_thread nptl/pthread_create.c:442
#13 0x7f757ef9f7db in clone3 ../sysdeps/unix/sysv/linux/x86_64/clone3.S:81
When updating hist maps it's also necessary to update the hist symbol
reference because the old one gets freed in map__put().
While this bug was probably introduced with 5c24b67aae ("perf
tools: Replace map->referenced & maps->removed_maps with map->refcnt"),
the symbol objects were leaked until c087e9480c ("perf machine:
Fix refcount usage when processing PERF_RECORD_KSYMBOL") was merged so
the bug was masked.
Fixes: c087e9480c ("perf machine: Fix refcount usage when processing PERF_RECORD_KSYMBOL")
Reported-by: Yunzhao Li <yunzhao@cloudflare.com >
Signed-off-by: Matt Fleming (Cloudflare) <matt@readmodwrite.com >
Cc: Ian Rogers <irogers@google.com >
Cc: kernel-team@cloudflare.com
Cc: Namhyung Kim <namhyung@kernel.org >
Cc: Riccardo Mancini <rickyman7@gmail.com >
Cc: stable@vger.kernel.org # v5.13+
Link: https://lore.kernel.org/r/20240815142212.3834625-1-matt@readmodwrite.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com >
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org >
2024-10-10 11:57:52 +02:00
..
2023-06-21 08:53:31 -06:00
2024-04-27 17:11:34 +02:00
2023-06-12 18:18:13 -03:00
2022-10-15 10:13:16 -03:00
2022-10-25 17:40:48 -03:00
2024-06-12 11:12:23 +02:00
2023-08-16 08:48:06 -03:00
2023-08-16 08:46:45 -03:00
2023-08-03 17:01:28 -03:00
2023-06-12 15:57:53 -03:00
2023-06-12 15:57:53 -03:00
2022-12-05 09:29:06 -03:00
2019-11-28 08:08:38 -03:00
2023-08-23 08:41:52 -03:00
2024-10-04 16:29:24 +02:00
2024-10-04 16:29:24 +02:00
2019-03-11 11:56:02 -03:00
2022-04-09 12:34:29 -03:00
2022-10-27 16:37:26 -03:00
2023-06-12 15:57:53 -03:00
2018-01-17 10:23:31 -03:00
2024-06-21 14:38:39 +02:00
2023-02-17 11:02:44 -03:00
2024-10-04 16:29:24 +02:00
2024-10-04 16:29:24 +02:00
2023-04-04 09:39:56 -03:00
2019-01-25 15:12:09 +01:00
2023-01-04 10:52:07 -03:00
2023-04-11 09:22:25 -03:00
2023-01-10 10:51:39 -03:00
2022-04-01 16:19:35 -03:00
2022-10-31 11:06:46 -03:00
2023-04-06 22:10:17 -03:00
2022-01-12 17:01:38 -08:00
2022-10-27 16:37:26 -03:00
2023-11-20 11:59:25 +01:00
2024-01-25 15:35:54 -08:00
2024-01-25 15:35:54 -08:00
2023-08-15 16:41:48 -03:00
2023-03-15 11:08:36 -03:00
2023-03-15 11:08:36 -03:00
2023-08-03 17:01:24 -03:00
2022-10-31 11:05:41 -03:00
2022-06-28 12:05:25 -03:00
2021-11-01 18:16:40 -03:00
2023-02-02 17:18:31 -03:00
2023-02-02 17:18:31 -03:00
2023-08-16 08:37:52 -03:00
2023-08-25 10:24:10 -03:00
2022-07-20 11:07:53 -03:00
2023-05-28 10:24:14 -03:00
2019-08-29 17:38:32 -03:00
2023-02-16 09:33:45 -03:00
2019-07-09 10:13:27 -03:00
2021-03-23 17:13:43 -03:00
2024-08-11 12:47:18 +02:00
2023-06-12 15:57:54 -03:00
2019-08-14 10:48:39 -03:00
2020-04-16 12:19:08 -03:00
2023-02-03 13:54:21 -03:00
2021-07-05 14:16:57 -03:00
2020-08-06 09:33:57 -03:00
2020-08-06 09:33:57 -03:00
2023-03-14 08:29:46 -03:00
2017-11-02 11:10:55 +01:00
2019-08-31 22:24:10 -03:00
2019-08-31 22:24:10 -03:00
2019-01-25 15:12:08 +01:00
2019-07-09 10:13:26 -03:00
2019-01-25 15:12:09 +01:00
2019-05-15 16:36:49 -03:00
2023-08-15 16:41:48 -03:00
2022-10-04 08:55:21 -03:00
2019-10-15 12:05:18 -03:00
2019-09-25 09:51:49 -03:00
2022-10-27 16:37:25 -03:00
2022-10-27 16:37:25 -03:00
2019-02-06 10:00:39 -03:00
2023-05-27 09:38:25 -03:00
2023-05-27 09:38:25 -03:00
2023-05-27 09:42:38 -03:00
2023-02-19 08:03:12 -03:00
2023-04-04 09:39:56 -03:00
2023-08-15 16:41:49 -03:00
2023-06-12 18:18:13 -03:00
2023-01-19 13:26:28 -03:00
2023-06-12 15:57:53 -03:00
2021-04-29 10:30:58 -03:00
2024-03-26 18:19:43 -04:00
2022-07-25 18:10:43 -03:00
2024-01-25 15:35:55 -08:00
2021-05-25 10:07:17 -03:00
2023-01-19 13:26:49 -03:00
2021-08-03 17:03:18 -03:00
2023-03-20 12:49:58 -03:00
2023-03-14 08:29:46 -03:00
2021-03-23 17:13:43 -03:00
2017-11-02 11:10:55 +01: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
2017-11-02 11:10:55 +01:00
2023-09-29 23:55:05 -07:00
2021-08-11 09:35:44 -03:00
2023-06-23 21:47:20 -07:00
2023-06-23 21:47:20 -07:00
2023-04-17 18:47:55 -03:00
2019-11-19 19:12:26 -03:00
2018-12-28 16:33:02 -03:00
2018-12-28 16:33:02 -03:00
2023-07-11 11:41:07 -03:00
2022-11-03 09:28:46 -03:00
2023-05-01 17:19:59 +08:00
2024-01-25 15:35:54 -08:00
2024-01-25 15:35:54 -08:00
2024-06-12 11:12:15 +02:00
2023-07-28 19:01:16 -03:00
2022-10-04 08:55:20 -03:00
2024-06-12 11:12:18 +02:00
2024-06-12 11:12:18 +02:00
2020-05-28 10:03:24 -03:00
2023-06-12 15:57:54 -03:00
2023-05-12 15:21:49 -03:00
2024-03-26 18:19:44 -04:00
2023-07-01 17:57:43 -07:00
2020-11-30 09:48:07 -03:00
2023-01-23 10:00:47 -03:00
2024-06-12 11:12:31 +02:00
2023-08-17 14:12:14 -03:00
2023-08-17 14:12:14 -03:00
2023-08-17 14:12:14 -03:00
2019-01-08 13:28:13 -03:00
2019-11-28 08:08:38 -03:00
2019-11-28 08:08:38 -03:00
2023-03-13 14:52:14 -03:00
2023-06-20 22:18:58 -07:00
2024-01-25 15:35:52 -08:00
2023-05-01 17:19:59 +08:00
2023-01-02 11:51:53 -03:00
2021-08-30 10:06:16 -03:00
2019-07-09 10:13:26 -03:00
2022-11-09 20:45:14 -08:00
2023-09-11 10:31:02 -03:00
2024-01-25 15:35:54 -08:00
2023-05-23 12:20:14 -03:00
2023-06-12 18:18:14 -03:00
2015-12-14 12:30:37 -03:00
2024-01-25 15:35:52 -08:00
2022-10-15 10:13:16 -03:00
2024-10-10 11:57:52 +02:00
2024-10-04 16:29:24 +02:00
2023-06-12 15:57:53 -03:00
2019-06-05 17:36:37 +02:00
2024-06-12 11:12:23 +02: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
2022-11-24 09:40:37 -03:00
2022-11-24 09:40:37 -03:00
2021-02-03 13:10:44 -03:00
2023-06-12 15:57:54 -03:00
2020-05-28 10:03:27 -03:00
2023-03-21 10:06:05 -03:00
2022-10-31 11:06:46 -03:00
2021-03-23 17:13:43 -03:00
2017-11-02 11:10:55 +01:00
2023-04-06 21:52:37 -03:00
2023-08-22 16:53:32 -03:00
2024-10-10 11:57:41 +02:00
2022-12-14 11:16:12 -03:00
2022-02-06 09:03:06 -03:00
2023-06-23 21:47:20 -07:00
2023-06-23 21:47:20 -07:00
2024-06-12 11:12:29 +02:00
2024-06-12 11:12:29 +02:00
2020-11-04 09:42:40 -03:00
2019-08-31 19:10:40 -03:00
2024-01-25 15:35:51 -08:00
2023-08-25 10:22:16 -03:00
2017-11-02 11:10:55 +01:00
2019-09-20 09:19:22 -03:00
2023-12-13 18:45:34 +01:00
2023-06-16 09:56:36 -03:00
2022-12-05 09:29:06 -03:00
2022-10-31 11:07:14 -03:00
2022-10-04 08:55:20 -03:00
2022-10-04 08:55:20 -03:00
2023-04-17 22:22:24 -03:00
2023-04-17 18:51:57 -03:00
2022-06-28 11:45:45 -03:00
2023-04-06 21:41:00 -03:00
2022-07-20 11:07:30 -03:00
2022-12-14 11:16:12 -03:00
2017-11-02 11:10:55 +01:00
2023-09-02 08:12:15 -03:00
2023-09-02 08:12:15 -03:00
2023-08-31 16:24:55 -03:00
2023-11-20 11:59:28 +01: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
2021-08-24 15:01:31 -03:00
2023-05-28 10:24:14 -03:00
2022-04-11 16:39:49 -03:00
2022-08-10 14:30:09 -03:00
2021-06-01 10:32:00 -03:00
2024-06-12 11:12:32 +02:00
2023-08-16 08:49:10 -03:00
2023-08-16 08:52:45 -03:00
2016-11-29 12:13:27 -03:00
2019-09-20 09:19:20 -03:00
2017-11-02 11:10:55 +01:00
2023-01-02 12:34:06 -03:00
2023-06-12 22:00:03 -03:00
2022-11-24 10:04:52 -03:00
2024-06-12 11:12:32 +02:00
2024-06-12 11:12:32 +02:00
2023-04-06 21:40:28 -03:00
2023-08-24 10:38:04 -03:00
2024-08-03 08:53:52 +02:00
2023-08-29 14:16:14 -03:00
2020-10-01 12:10:56 -03:00
2017-11-07 10:30:18 +01:00
2024-03-26 18:19:51 -04:00
2023-08-29 14:16:14 -03:00
2024-06-12 11:12:13 +02:00
2023-08-07 16:40:29 -03:00
2021-07-18 09:27:37 -03:00
2019-11-18 19:08:02 -03:00
2023-04-19 16:38:43 -03:00
2021-07-18 09:31:15 -03:00
2020-05-28 10:03:27 -03:00
2017-11-02 11:10:55 +01:00
2023-08-16 08:37:52 -03:00
2024-06-12 11:12:32 +02: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
2022-12-14 15:28:18 -03:00
2023-03-13 14:52:14 -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
2017-09-21 13:28:06 -03:00
2020-04-16 12:19:15 -03:00
2018-08-08 15:26:48 -03:00
2022-10-31 11:06:41 -03:00
2018-08-03 10:34:18 -03:00
2023-08-29 14:16:14 -03:00
2021-09-10 18:15:21 -03:00
2021-09-10 18:15:21 -03:00
2023-03-20 19:27:00 -03:00
2024-10-04 16:29:23 +02:00
2022-12-14 11:16:12 -03:00
2019-07-09 10:13:26 -03:00
2024-10-10 11:57:52 +02:00
2023-06-20 17:03:43 -07:00
2023-06-20 17:03:43 -07:00
2022-04-01 16:19:35 -03:00
2023-02-19 08:03:12 -03:00
2023-02-19 08:03:12 -03:00
2024-10-04 16:29:23 +02:00
2023-03-20 19:28:21 -03:00
2019-10-11 10:57:00 -03:00
2019-10-11 10:57:00 -03:00
2021-06-08 09:36:36 -03:00
2019-02-06 10:00:38 -03:00
2024-03-26 18:19:47 -04:00
2023-06-14 18:19:06 -03:00
2024-10-04 16:29:24 +02:00
2024-08-03 08:54:27 +02:00
2023-07-24 18:23:18 -03:00
2023-06-16 10:17:45 -03:00
2019-08-31 19:10:19 -03:00
2021-03-23 17:13:43 -03:00
2021-07-09 14:04:28 -03:00
2020-10-14 13:34:26 -03:00
2023-04-06 21:41:00 -03:00
2021-03-23 17:13:43 -03:00
2024-06-12 11:13:02 +02:00
2024-06-12 11:13:02 +02:00
2019-07-09 10:13:26 -03:00
2019-01-25 15:12:10 +01:00
2023-08-29 14:13:48 -03:00
2019-08-29 17:38:31 -03:00
2024-06-12 11:12:16 +02:00
2023-06-23 21:47:20 -07:00
2023-08-11 11:27:50 -03:00
2022-12-21 14:52:40 -03:00
2024-06-12 11:12:29 +02:00
2024-06-12 11:12:29 +02:00
2023-02-01 21:51:51 -03:00
2023-08-29 14:16:14 -03:00
2022-08-19 12:26:58 -03:00
2023-06-05 11:36:17 -03:00
2020-05-29 16:50:26 -03:00
2021-01-20 14:25:28 -03:00
2023-05-27 09:38:59 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2024-03-26 18:19:46 -04:00
2022-11-16 12:17:15 -03:00
2023-08-14 11:46:51 +02:00
2021-03-25 08:59:10 -03:00
2024-10-10 11:57:41 +02:00
2024-10-10 11:57:41 +02:00
2024-10-04 16:29:24 +02:00
2019-10-15 08:36:22 -03:00
2024-10-04 16:29:23 +02:00
2023-04-10 19:22:05 -03:00
2024-06-12 11:12:16 +02:00
2023-02-19 08:07:24 -03:00
2023-02-19 08:07:24 -03:00
2023-06-23 22:30:16 -07:00
2022-12-14 11:16:12 -03:00
2022-12-14 11:16:12 -03:00
2023-03-15 10:27:07 -03:00
2022-12-14 11:16:12 -03:00
2023-06-23 22:30:16 -07:00
2023-05-02 08:36:14 -03:00
2022-08-02 16:32:26 -03:00
2019-08-29 17:38:32 -03:00
2021-04-29 10:31:00 -03:00
2022-07-25 12:28:00 -03:00
2021-03-15 11:36:54 -03:00
2021-03-15 11:36:54 -03:00
2024-01-25 15:35:53 -08:00
2022-04-09 12:34:29 -03:00
2024-01-25 15:35:53 -08:00
2023-06-12 15:57:53 -03:00
2023-08-16 08:48:06 -03:00
2023-04-10 19:20:53 -03:00
2023-04-10 19:21:31 -03:00
2023-04-10 19:22:05 -03:00
2019-08-31 19:10:19 -03:00
2017-11-02 11:10:55 +01:00
2023-06-12 15:57:53 -03:00
2017-11-02 11:10:55 +01:00
2019-09-20 09:19:20 -03:00
2020-09-01 12:15:21 -03:00