Ben Gainey
1e24ce402c
perf db-export: Fix missing reference count get in call_path_from_sample()
...
The addr_location map and maps fields in the inner loop were missing
calls to map__get()/maps__get(). The subsequent addr_location__exit()
call in each loop puts the map/maps fields causing use-after-free
aborts.
This issue reproduces on at least arm64 and x86_64 with something
simple like `perf record -g ls` followed by `perf script -s script.py`
with the following script:
perf_db_export_mode = True
perf_db_export_calls = False
perf_db_export_callchains = True
def sample_table(*args):
print(f'sample_table({args})')
def call_path_table(*args):
print(f'call_path_table({args}')
Committer testing:
This test, just introduced by Ian Rogers, now passes, not segfaulting
anymore:
# perf test "perf script tests"
95: perf script tests : Ok
#
Fixes: 0dd5041c9a0eaf8c ("perf addr_location: Add init/exit/copy functions")
Signed-off-by: Ben Gainey <ben.gainey@arm.com>
Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Tested-by: Ian Rogers <irogers@google.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: https://lore.kernel.org/r/20231207140911.3240408-1-ben.gainey@arm.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2024-01-04 18:29:17 -03:00
..
2023-06-21 08:53:31 -06:00
2023-10-25 10:02:55 -07:00
2023-06-12 18:18:13 -03:00
2022-10-15 10:13:16 -03:00
2023-12-23 10:56:05 -03:00
2023-10-17 12:40:50 -07:00
2023-08-16 08:48:06 -03:00
2023-08-16 08:46:45 -03:00
2023-11-27 10:21:27 -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
2023-12-23 22:40:13 -03:00
2023-12-23 22:40:13 -03:00
2023-12-23 22:40:17 -03:00
2023-12-23 22:40:17 -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
2023-10-17 12:40:50 -07:00
2023-12-12 14:55:13 -03:00
2023-11-27 10:21:27 -03:00
2023-12-07 17:18:06 -03:00
2023-12-07 17:18:06 -03:00
2023-11-09 13:49:33 -03:00
2023-01-04 10:52:07 -03:00
2023-12-12 14:55:13 -03:00
2023-01-10 10:51:39 -03:00
2022-04-01 16:19:35 -03:00
2023-09-18 15:38:46 -07:00
2022-10-31 11:06:46 -03:00
2023-12-20 14:56:10 -03:00
2022-01-12 17:01:38 -08:00
2022-10-27 16:37:26 -03:00
2023-10-25 13:38:33 -07:00
2024-01-03 17:54:54 -03:00
2024-01-03 17:54:54 -03: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-09-12 17:50:36 -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-10-25 13:38:50 -07:00
2023-10-25 13:38:50 -07:00
2023-12-23 22:39:18 -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
2021-03-23 17:13:43 -03:00
2023-10-27 19:26:13 -07:00
2023-10-25 13:39:32 -07:00
2019-08-14 10:48:39 -03:00
2020-04-16 12:19:08 -03:00
2023-09-12 17:32:00 -03:00
2023-09-12 17:32:00 -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
2019-08-31 22:24:10 -03:00
2019-08-31 22:24:10 -03:00
2023-11-28 14:25:06 -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
2023-12-12 14:55:13 -03:00
2023-05-27 09:38:25 -03:00
2023-12-12 14:55:13 -03:00
2023-02-19 08:03:12 -03:00
2023-04-04 09:39:56 -03:00
2023-11-27 10:21:27 -03:00
2023-10-17 12:40:50 -07: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
2023-10-25 10:02:11 -07:00
2022-07-25 18:10:43 -03:00
2024-01-04 18:29:17 -03:00
2021-05-25 10:07:17 -03:00
2023-12-20 14:53:20 -03:00
2023-12-20 14:53:20 -03:00
2023-11-10 09:03:54 -03:00
2023-11-10 09:03:54 -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
2021-03-30 12:45:59 -03:00
2021-02-17 15:15:06 -03:00
2019-09-20 09:19:20 -03:00
2023-10-30 13:46:27 -07:00
2021-08-11 09:35:44 -03:00
2023-12-23 22:39:42 -03:00
2023-12-23 22:39:42 -03:00
2023-04-17 18:47:55 -03:00
2019-11-19 19:12:26 -03:00
2023-12-23 10:42:50 -03:00
2023-12-23 10:42:50 -03:00
2023-12-23 10:56:05 -03:00
2024-01-03 17:54:54 -03:00
2024-01-03 17:54:54 -03:00
2023-11-09 13:49:32 -03:00
2023-07-28 19:01:16 -03:00
2022-10-04 08:55:20 -03:00
2023-12-18 21:23:28 -03:00
2023-12-14 19:13:10 -03: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
2023-12-12 14:01:47 -03:00
2023-12-06 09:45:58 -03:00
2020-11-30 09:48:07 -03:00
2023-01-23 10:00:47 -03:00
2023-09-15 16:46:40 -07:00
2023-08-17 14:12:14 -03:00
2023-08-17 14:12:14 -03:00
2023-09-12 17:46:50 -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
2023-12-14 18:56:34 -03: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
2022-11-09 20:45:14 -08:00
2023-09-11 10:31:02 -03:00
2024-01-03 17:54:54 -03:00
2023-05-23 12:20:14 -03:00
2023-06-12 18:18:14 -03:00
2023-12-13 13:56:09 -03:00
2022-10-15 10:13:16 -03:00
2023-10-25 13:39:58 -07:00
2023-12-23 22:39:42 -03:00
2023-06-12 15:57:53 -03:00
2023-09-29 23:59:08 -07:00
2023-10-17 12:40:50 -07: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-10-12 10:01:56 -07:00
2020-05-28 10:03:27 -03:00
2023-03-21 10:06:05 -03:00
2023-09-12 17:31:59 -03:00
2021-03-23 17:13:43 -03:00
2023-09-12 17:32:00 -03:00
2023-08-22 16:53:32 -03:00
2023-12-20 15:02:02 -03:00
2023-10-25 13:38:09 -07:00
2023-10-25 13:39:58 -07:00
2023-10-25 13:39:58 -07:00
2023-12-06 13:01:42 -03:00
2023-12-18 21:34:51 -03:00
2023-12-20 15:02:36 -03:00
2023-12-20 15:02:17 -03:00
2020-11-04 09:42:40 -03:00
2019-08-31 19:10:40 -03:00
2023-12-05 15:48:52 -03:00
2023-08-25 10:22:16 -03:00
2019-09-20 09:19:22 -03:00
2023-12-05 10:15:10 -08:00
2023-06-16 09:56:36 -03:00
2023-11-28 14:25:06 -03:00
2023-11-28 14:25:06 -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
2023-11-09 13:47:50 -03:00
2023-11-27 10:21:27 -03:00
2023-09-11 10:26:36 -03:00
2023-10-12 10:01:55 -07:00
2023-10-12 10:01:55 -07:00
2020-12-17 14:36:16 -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
2023-12-12 14:55:13 -03:00
2021-06-01 10:32:00 -03:00
2023-11-09 13:47:50 -03:00
2023-08-16 08:49:10 -03:00
2023-08-16 08:52:45 -03:00
2019-09-20 09:19:20 -03:00
2023-01-02 12:34:06 -03:00
2023-09-12 17:32:00 -03:00
2022-11-24 10:04:52 -03:00
2023-11-27 10:21:27 -03:00
2023-11-27 10:21:27 -03:00
2023-04-06 21:40:28 -03:00
2023-09-12 17:47:00 -03:00
2023-09-29 22:50:42 -07:00
2023-08-29 14:16:14 -03:00
2020-10-01 12:10:56 -03:00
2023-09-12 17:32:00 -03:00
2023-08-29 14:16:14 -03:00
2023-12-18 21:35:07 -03: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-11-10 09:04:21 -03:00
2023-11-10 09:03:54 -03:00
2020-05-28 10:03:27 -03:00
2023-10-27 19:23:52 -07:00
2023-10-17 12:40:50 -07:00
2023-12-12 14:55:13 -03:00
2023-03-13 14:52:14 -03:00
2023-10-25 10:02:11 -07:00
2023-10-25 10:02:11 -07:00
2023-10-25 13:35:35 -07:00
2023-10-25 13:35:35 -07:00
2023-11-15 12:51:53 -05:00
2022-10-31 11:06:41 -03:00
2023-11-27 15:38:37 -03:00
2021-09-10 18:15:21 -03:00
2021-09-10 18:15:21 -03:00
2023-11-09 13:47:50 -03:00
2023-11-09 13:49:32 -03:00
2022-12-14 11:16:12 -03:00
2023-08-03 17:01:28 -03: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
2023-12-23 22:39:43 -03:00
2023-12-23 22:39:42 -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
2023-06-15 21:54:02 -03:00
2023-06-14 18:19:06 -03:00
2023-12-14 18:24:38 -03:00
2024-01-03 17:55:01 -03:00
2023-12-14 18:24:38 -03:00
2023-12-14 18:24:38 -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
2023-09-12 17:32:00 -03:00
2023-09-12 17:32:00 -03:00
2023-10-12 10:01:56 -07:00
2019-08-29 17:38:31 -03:00
2023-12-23 22:39:43 -03:00
2023-06-23 21:47:20 -07:00
2023-12-06 13:01:42 -03:00
2023-12-06 09:46:15 -03:00
2023-12-20 14:51:44 -03:00
2023-12-06 13:01:46 -03:00
2023-02-01 21:51:51 -03:00
2023-12-18 21:35:12 -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
2022-11-16 12:17:15 -03: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
2023-12-20 14:55:30 -03:00
2023-11-09 13:49:32 -03:00
2019-10-15 08:36:22 -03:00
2019-10-15 08:36:22 -03:00
2022-06-23 11:54:22 -03:00
2023-12-18 21:34:39 -03:00
2023-12-07 16:47:55 -03:00
2023-02-19 08:07:24 -03:00
2023-02-19 08:07:24 -03:00
2023-10-12 10:01:57 -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
2023-12-14 19:08:48 -03:00
2022-04-09 12:34:29 -03:00
2023-12-20 14:41:29 -03: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
2023-12-20 14:49:11 -03:00
2019-09-20 09:19:20 -03:00
2023-11-28 14:25:06 -03:00