Alexey Budankov
bb1835a3b8
perf session: Fix decompression of PERF_RECORD_COMPRESSED records
...
Avoid termination of trace loading in case the last record in the
decompressed buffer partly resides in the following mmaped
PERF_RECORD_COMPRESSED record.
In this case NULL value returned by fetch_mmaped_event() means to
proceed to the next mmaped record then decompress it and load compressed
events.
The issue can be reproduced like this:
$ perf record -z -- some_long_running_workload
$ perf report --stdio -vv
decomp (B): 44519 to 163000
decomp (B): 48119 to 174800
decomp (B): 65527 to 131072
fetch_mmaped_event: head=0x1ffe0 event->header_size=0x28, mmap_size=0x20000: fuzzed perf.data?
Error:
failed to process sample
...
Testing:
71: Zstd perf.data compression/decompression : Ok
$ tools/perf/perf report -vv --stdio
decomp (B): 59593 to 262160
decomp (B): 4438 to 16512
decomp (B): 285 to 880
Looking at the vmlinux_path (8 entries long)
Using vmlinux for symbols
decomp (B): 57474 to 261248
prefetch_event: head=0x3fc78 event->header_size=0x28, mmap_size=0x3fc80: fuzzed or compressed perf.data?
decomp (B): 25 to 32
decomp (B): 52 to 120
...
Fixes: 57fc032ad643 ("perf session: Avoid infinite loop when seeing invalid header.size")
Link: https://marc.info/?l=linux-kernel&m=156580812427554&w=2
Co-developed-by: Jiri Olsa <jolsa@kernel.org>
Acked-by: Jiri Olsa <jolsa@kernel.org>
Signed-off-by: Alexey Budankov <alexey.budankov@linux.intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lore.kernel.org/lkml/cf782c34-f3f8-2f9f-d6ab-145cee0d5322@linux.intel.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2019-11-19 19:31:55 -03:00
..
2019-08-28 18:14:57 -03:00
2019-09-20 09:19:20 -03:00
2019-06-25 18:31:12 -03:00
2019-08-31 22:27:52 -03:00
2019-09-20 09:19:20 -03:00
2019-11-12 08:20:53 -03:00
2019-11-12 08:20:53 -03:00
2019-11-12 08:20:53 -03:00
2019-03-11 11:56:02 -03:00
2019-09-20 09:19:21 -03:00
2019-11-06 15:43:06 -03:00
2019-11-06 15:43:06 -03:00
2019-11-07 10:14:48 -03:00
2019-11-07 10:14:48 -03:00
2019-01-25 15:12:09 +01:00
2019-01-25 15:12:09 +01:00
2019-02-19 16:11:56 -03:00
2019-02-19 16:11:56 -03:00
2019-09-20 09:19:22 -03:00
2019-09-20 09:19:22 -03:00
2019-09-25 09:51:48 -03:00
2019-07-29 18:34:42 -03:00
2019-08-31 19:10:19 -03:00
2019-09-20 09:19:20 -03:00
2019-09-20 09:19:20 -03:00
2019-11-07 09:09:18 -03:00
2019-09-25 09:51:49 -03:00
2019-07-29 18:34:42 -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
2019-06-05 17:36:37 +02:00
2019-11-12 08:20:53 -03:00
2019-11-12 08:20:53 -03:00
2019-08-14 10:48:39 -03:00
2019-08-14 10:59:59 -03:00
2019-08-31 22:24:10 -03:00
2019-07-29 18:34:42 -03:00
2019-09-20 09:19:20 -03: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
2019-08-31 22:24:10 -03:00
2018-05-16 16:11:09 -03:00
2019-10-15 12:05:18 -03:00
2019-09-25 09:51:49 -03:00
2019-07-29 18:34:42 -03:00
2019-08-22 17:16:56 -03:00
2019-02-06 10:00:39 -03:00
2019-11-06 15:49:39 -03:00
2019-11-06 15:49:39 -03:00
2019-08-22 17:16:57 -03:00
2019-08-31 19:10:40 -03:00
2019-11-06 15:43:05 -03:00
2019-08-31 22:24:10 -03:00
2019-09-20 15:58:11 -03:00
2019-11-06 15:43:05 -03:00
2019-11-06 15:43:05 -03:00
2019-11-12 08:20:53 -03:00
2019-07-29 18:34:42 -03:00
2019-11-12 08:32:27 -03:00
2019-11-12 08:32:27 -03:00
2019-09-20 09:19:20 -03:00
2019-09-20 09:19:20 -03:00
2019-11-19 19:12:26 -03:00
2019-11-19 19:12:26 -03:00
2019-11-19 19:12:26 -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
2019-11-18 18:56:27 -03:00
2019-11-06 15:43:06 -03:00
2019-09-20 09:19:20 -03:00
2019-11-06 15:49:39 -03:00
2019-11-06 15:49:39 -03:00
2019-11-12 08:20:53 -03:00
2019-09-20 09:19:22 -03:00
2019-08-31 22:24:10 -03:00
2019-10-22 01:15:32 +02:00
2019-10-09 11:23:52 -03:00
2019-09-25 16:26:40 -03:00
2019-11-12 08:20:53 -03:00
2019-09-25 16:26:34 -03:00
2019-11-12 08:32:27 -03:00
2019-09-25 16:26:40 -03:00
2019-08-15 12:26:13 -03:00
2019-08-15 12:25:55 -03:00
2019-08-31 19:10:19 -03:00
2019-01-08 13:28:13 -03:00
2019-08-29 17:38:32 -03:00
2019-08-29 17:38:32 -03:00
2019-09-25 16:26:41 -03:00
2018-04-12 10:33:31 -03:00
2019-08-26 11:58:29 -03:00
2019-07-09 10:13:26 -03:00
2019-10-15 11:54:11 -03:00
2019-11-06 15:43:05 -03:00
2019-07-09 10:13:26 -03:00
2019-11-12 08:20:53 -03:00
2019-11-07 09:14:15 -03:00
2019-09-25 09:51:47 -03:00
2019-06-05 17:36:37 +02:00
2019-09-25 09:51:47 -03:00
2019-06-05 17:36:37 +02:00
2019-06-05 17:37:04 +02:00
2019-01-25 15:12:10 +01:00
2019-09-30 17:29:49 -03:00
2019-06-19 17:09:51 +02:00
2019-09-20 10:28:26 -03:00
2019-11-06 15:43:05 -03:00
2019-08-29 17:38:32 -03:00
2019-09-20 09:19:20 -03:00
2019-11-19 19:12:26 -03:00
2019-11-19 19:12:26 -03:00
2019-11-18 13:01:58 -03:00
2019-11-12 08:20:53 -03:00
2019-11-19 19:12:26 -03:00
2019-11-19 19:12:26 -03:00
2019-08-31 19:10:40 -03:00
2019-08-31 19:10:40 -03:00
2019-11-12 08:20:53 -03:00
2019-08-31 22:27:48 -03:00
2019-09-20 09:19:22 -03:00
2019-11-18 19:14:29 -03:00
2019-08-31 22:27:52 -03:00
2019-10-10 12:52:41 -03:00
2019-10-10 11:49:46 -03:00
2019-09-20 10:28:21 -03:00
2019-09-20 10:28:21 -03:00
2019-08-31 19:10:19 -03:00
2018-12-17 15:02:17 -03:00
2019-08-31 19:10:19 -03:00
2019-11-18 19:14:29 -03:00
2019-11-18 19:14:29 -03:00
2019-08-14 10:59:59 -03:00
2019-11-12 08:34:16 -03:00
2019-10-10 09:29:33 -03:00
2019-05-15 16:36:49 -03:00
2019-08-31 22:24:10 -03:00
2019-08-31 22:24:10 -03:00
2019-09-25 16:26:34 -03:00
2019-10-10 09:29:33 -03:00
2019-10-10 09:29:33 -03:00
2019-09-20 09:19:20 -03:00
2019-05-28 18:37:44 -03:00
2019-11-07 08:30:18 -03:00
2019-10-19 15:35:01 -03:00
2019-06-25 21:02:47 -03:00
2019-11-18 19:09:23 -03:00
2019-11-18 19:09:23 -03:00
2019-11-18 19:08:02 -03:00
2019-11-18 19:08:02 -03:00
2019-11-18 19:09:23 -03:00
2019-11-18 19:09:23 -03:00
2019-08-31 19:10:19 -03:00
2019-09-25 16:26:34 -03:00
2019-11-12 08:32:27 -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
2019-09-25 09:51:48 -03:00
2019-11-06 15:43:05 -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
2019-01-21 17:00:48 -03:00
2018-08-08 15:26:48 -03:00
2019-09-20 09:19:21 -03:00
2018-08-03 10:34:18 -03:00
2019-09-20 09:19:20 -03:00
2019-07-29 18:34:42 -03:00
2019-07-29 18:34:42 -03:00
2019-11-19 19:31:55 -03:00
2019-10-07 12:22:17 -03:00
2019-07-09 10:13:26 -03:00
2019-08-14 10:48:39 -03:00
2019-06-10 16:20:11 -03:00
2019-11-19 19:12:26 -03:00
2019-10-11 10:57:00 -03:00
2019-10-11 10:57:00 -03:00
2019-10-11 10:57:00 -03:00
2019-09-25 09:51:48 -03:00
2019-02-06 10:00:38 -03:00
2019-07-09 10:13:26 -03:00
2019-01-25 15:12:09 +01:00
2019-11-06 15:49:39 -03:00
2019-09-25 16:26:40 -03:00
2019-11-06 15:49:39 -03:00
2019-11-06 15:49:39 -03:00
2019-08-31 19:10:19 -03:00
2019-07-09 10:13:26 -03:00
2019-10-15 13:03:57 -03:00
2019-07-01 22:50:40 -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
2019-11-07 10:14:48 -03:00
2019-08-31 22:24:05 -03:00
2019-11-12 08:20:53 -03:00
2019-09-20 09:19:20 -03:00
2019-11-18 13:01:58 -03:00
2019-11-12 08:20:53 -03:00
2019-08-31 22:24:05 -03:00
2019-11-06 15:49:25 -03:00
2019-09-20 09:19:22 -03:00
2019-07-29 18:34:42 -03:00
2019-07-29 18:34:42 -03:00
2019-09-20 09:19:20 -03:00
2019-08-29 08:36:12 -03:00
2019-08-29 08:36:12 -03:00
2019-08-31 19:10:19 -03:00
2019-06-17 20:48:14 +02:00
2019-11-06 15:49:25 -03:00
2019-08-26 19:39:11 -03:00
2019-10-15 08:36:22 -03:00
2019-10-15 08:36:22 -03:00
2019-08-26 19:39:11 -03:00
2019-09-25 09:51:48 -03:00
2019-08-31 22:24:10 -03:00
2019-09-25 09:51:48 -03:00
2019-11-05 08:39:27 -03:00
2019-09-20 09:19:20 -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
2019-09-20 09:19:22 -03:00
2019-11-12 08:20:53 -03:00
2019-11-12 08:20:53 -03:00
2019-08-31 22:24:10 -03:00
2019-11-12 08:20:53 -03:00
2019-09-20 09:19:20 -03:00
2019-11-06 15:43:05 -03:00
2019-09-25 09:51:49 -03:00
2019-08-31 19:10:19 -03:00
2019-11-06 15:49:39 -03:00
2019-07-09 10:13:26 -03:00
2019-09-20 09:19:20 -03:00
2019-07-23 09:04:03 -03:00