Changbin Du
1e5b0cf867
perf top: Fix global-buffer-overflow issue
The array str[] should have six elements.
=================================================================
==4322==ERROR: AddressSanitizer: global-buffer-overflow on address 0x56463844e300 at pc 0x564637e7ad0d bp 0x7f30c8c89d10 sp 0x7f30c8c89d00
READ of size 8 at 0x56463844e300 thread T9
#0 0x564637e7ad0c in __ordered_events__flush util/ordered-events.c:316
#1 0x564637e7b0e4 in ordered_events__flush util/ordered-events.c:338
#2 0x564637c6a57d in process_thread /home/changbin/work/linux/tools/perf/builtin-top.c:1073
#3 0x7f30d173a163 in start_thread (/lib/x86_64-linux-gnu/libpthread.so.0+0x8163)
#4 0x7f30cfffbdee in __clone (/lib/x86_64-linux-gnu/libc.so.6+0x11adee)
0x56463844e300 is located 32 bytes to the left of global variable 'flags' defined in 'util/trace-event-parse.c:229:26' (0x56463844e320) of size 192
0x56463844e300 is located 0 bytes to the right of global variable 'str' defined in 'util/ordered-events.c:268:28' (0x56463844e2e0) of size 32
SUMMARY: AddressSanitizer: global-buffer-overflow util/ordered-events.c:316 in __ordered_events__flush
Shadow bytes around the buggy address:
0x0ac947081c10: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
0x0ac947081c20: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
0x0ac947081c30: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
0x0ac947081c40: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
0x0ac947081c50: 00 00 00 00 00 00 00 00 f9 f9 f9 f9 00 00 00 00
=>0x0ac947081c60:[f9]f9 f9 f9 00 00 00 00 00 00 00 00 00 00 00 00
0x0ac947081c70: 00 00 00 00 00 00 00 00 00 00 00 00 f9 f9 f9 f9
0x0ac947081c80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
0x0ac947081c90: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
0x0ac947081ca0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
0x0ac947081cb0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
Shadow byte legend (one shadow byte represents 8 application bytes):
Addressable: 00
Partially addressable: 01 02 03 04 05 06 07
Heap left redzone: fa
Freed heap region: fd
Stack left redzone: f1
Stack mid redzone: f2
Stack right redzone: f3
Stack after return: f5
Stack use after scope: f8
Global redzone: f9
Global init order: f6
Poisoned by user: f7
Container overflow: fc
Array cookie: ac
Intra object redzone: bb
ASan internal: fe
Left alloca redzone: ca
Right alloca redzone: cb
Thread T9 created by T0 here:
#0 0x7f30d179de5f in __interceptor_pthread_create (/usr/lib/x86_64-linux-gnu/libasan.so.5+0x4ae5f)
#1 0x564637c6b954 in __cmd_top /home/changbin/work/linux/tools/perf/builtin-top.c:1253
#2 0x564637c7173c in cmd_top /home/changbin/work/linux/tools/perf/builtin-top.c:1642
#3 0x564637d85038 in run_builtin /home/changbin/work/linux/tools/perf/perf.c:302
#4 0x564637d85577 in handle_internal_command /home/changbin/work/linux/tools/perf/perf.c:354
#5 0x564637d8597b in run_argv /home/changbin/work/linux/tools/perf/perf.c:398
#6 0x564637d860e9 in main /home/changbin/work/linux/tools/perf/perf.c:520
#7 0x7f30cff0509a in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x2409a)
Signed-off-by: Changbin Du <changbin.du@gmail.com>
Reviewed-by: Jiri Olsa <jolsa@kernel.org>
Cc: Alexei Starovoitov <ast@kernel.org>
Cc: Daniel Borkmann <daniel@iogearbox.net>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Steven Rostedt (VMware) <rostedt@goodmis.org>
Cc: Jiri Olsa <jolsa@kernel.org>
Fixes: 16c66bc167 ("perf top: Add processing thread")
Fixes: 68ca5d07de ("perf ordered_events: Add ordered_events__flush_time interface")
Link: http://lkml.kernel.org/r/20190316080556.3075-13-changbin.du@gmail.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2019-03-19 16:52:05 -03:00
..
2019-03-06 09:47:48 -03:00
2019-02-14 15:18:08 -03:00
2019-01-03 18:57:57 -08:00
2019-02-14 15:18:08 -03:00
2017-11-02 11:10:55 +01:00
2019-03-01 14:50:47 -03:00
2019-03-06 16:40:15 -03:00
2019-03-06 16:40:15 -03:00
2019-03-11 11:56:02 -03:00
2018-01-17 10:23:31 -03:00
2018-01-17 10:23:31 -03:00
2018-01-17 10:23:31 -03:00
2018-01-17 10:23:31 -03:00
2019-03-01 14:47:06 -03:00
2019-02-06 11:20:32 -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-02-20 16:23:07 -03:00
2019-01-21 17:36:39 -03:00
2019-03-06 07:59:36 -08:00
2019-02-06 10:00:39 -03:00
2018-06-15 18:10:01 -03:00
2017-11-02 11:10:55 +01:00
2017-07-18 23:14:40 -03:00
2019-01-25 15:12:08 +01:00
2019-02-19 16:11:56 -03:00
2019-03-19 16:52:04 -03:00
2019-01-25 15:12:09 +01:00
2017-11-02 11:10:55 +01:00
2016-05-06 13:00:43 -03:00
2016-05-06 13:00:43 -03:00
2019-02-06 10:00:38 -03:00
2019-02-06 10:00:38 -03:00
2018-06-04 10:28:50 -03:00
2018-03-07 10:22:26 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-01-21 17:38:56 -03:00
2019-01-21 17:38:56 -03:00
2019-01-25 15:12:08 +01:00
2019-01-25 15:12:09 +01:00
2019-01-25 15:12:09 +01:00
2018-08-20 08:54:59 -03:00
2019-03-19 16:52:04 -03:00
2018-05-16 16:11:09 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-02-06 10:00:39 -03:00
2019-02-20 17:08:39 -03:00
2019-02-06 10:00:39 -03:00
2019-02-19 12:21:10 -03:00
2019-02-19 12:21:06 -03:00
2019-02-14 15:18:08 -03:00
2019-02-14 15:18:06 -03:00
2017-11-02 11:10:55 +01:00
2019-02-22 16:52:07 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-03-19 11:56:20 -03:00
2019-03-19 11:56:20 -03:00
2019-03-01 14:50:47 -03:00
2019-03-01 14:50:47 -03:00
2018-03-16 16:39:02 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-03-19 16:52:03 -03:00
2019-01-25 15:12:10 +01:00
2018-12-28 16:33:02 -03:00
2018-12-28 16:33:02 -03:00
2018-04-02 13:50:24 -03:00
2016-09-29 11:17:08 -03:00
2017-11-02 11:10:55 +01:00
2018-12-17 14:54:02 -03:00
2018-10-18 11:16:38 -03:00
2019-02-06 10:00:38 -03:00
2019-02-06 11:20:32 -03:00
2019-03-06 18:19:45 -03:00
2019-02-06 10:00:39 -03:00
2018-12-17 14:57:07 -03:00
2019-03-19 16:52:03 -03:00
2019-02-06 10:00:38 -03:00
2017-11-02 11:10:55 +01:00
2017-08-22 12:19:08 -03:00
2019-01-08 13:28:13 -03:00
2017-06-19 15:27:07 -03:00
2018-04-30 12:02:03 -03:00
2018-10-18 11:16:38 -03:00
2018-04-12 10:33:31 -03:00
2018-11-19 12:12:17 -08:00
2017-11-02 11:10:55 +01:00
2019-03-11 11:56:03 -03:00
2019-03-11 11:56:03 -03:00
2017-11-02 11:10:55 +01:00
2015-12-14 12:30:37 -03:00
2019-03-19 16:52:04 -03:00
2019-03-11 16:33:19 -03:00
2019-03-06 17:55:35 -03:00
2015-08-21 11:34:10 -03:00
2019-03-01 14:48:30 -03:00
2016-09-29 11:17:05 -03:00
2013-10-14 10:28:48 -03:00
2019-01-25 15:12:10 +01:00
2017-11-07 10:30:18 +01:00
2019-01-25 15:12:09 +01:00
2016-10-24 11:07:39 -03:00
2019-02-06 10:00:39 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-08-30 15:52:20 -03:00
2018-08-20 08:54:58 -03:00
2018-08-20 08:54:59 -03:00
2019-02-06 10:00:38 -03:00
2019-02-06 10:00:38 -03:00
2019-02-06 10:00:38 -03:00
2019-02-06 10:00:38 -03:00
2019-03-19 16:52:05 -03:00
2019-02-06 10:00:38 -03:00
2018-03-16 13:52:37 -03:00
2018-03-16 13:52:37 -03:00
2019-02-04 11:32:14 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-02-14 15:18:09 -03:00
2019-02-14 15:18:09 -03:00
2019-02-06 10:00:39 -03:00
2019-02-06 10:00:39 -03:00
2018-11-19 12:12:26 -08:00
2018-11-19 12:12:26 -08:00
2019-03-19 16:52:05 -03:00
2018-12-17 15:02:17 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-03-19 16:52:04 -03:00
2018-10-19 16:31:09 -03:00
2018-10-19 16:31:09 -03:00
2019-02-14 15:18:08 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-12-27 12:15:48 -03:00
2017-12-27 12:15:48 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2016-11-29 12:13:27 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-03-06 18:18:17 -03:00
2019-03-06 18:18:17 -03:00
2012-03-16 14:29:35 -03:00
2013-02-14 16:12:34 -03:00
2017-11-07 10:30:18 +01:00
2017-11-07 10:30:18 +01:00
2019-03-11 11:56:03 -03:00
2019-01-25 15:12:09 +01:00
2019-01-25 15:12:09 +01:00
2018-09-24 04:44:54 -04:00
2018-03-19 13:51:53 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-12-27 12:15:56 -03:00
2018-12-28 16:33:02 -03:00
2019-01-25 15:12:10 +01:00
2019-01-25 15:12:10 +01:00
2019-01-25 15:12:10 +01:00
2018-03-05 11:52:41 -03:00
2017-09-21 13:28:06 -03:00
2017-09-21 13:28:06 -03:00
2019-01-21 17:00:48 -03:00
2018-08-08 15:26:48 -03:00
2019-02-14 13:31:08 -03:00
2018-08-03 10:34:18 -03:00
2019-01-21 17:00:56 -03:00
2019-01-21 17:00:48 -03:00
2019-01-21 17:00:48 -03:00
2017-11-02 11:10:55 +01:00
2019-03-11 11:56:03 -03:00
2018-09-19 10:25:10 -03:00
2017-07-18 23:14:08 -03:00
2019-02-06 10:00:39 -03:00
2017-08-22 12:09:04 -03:00
2017-08-22 12:09:04 -03:00
2019-03-19 16:15:42 -03:00
2019-03-19 16:15:42 -03:00
2018-12-17 14:57:07 -03:00
2019-02-06 10:00:38 -03:00
2019-02-19 12:30:12 -03:00
2019-01-25 15:12:09 +01:00
2019-01-25 15:12:08 +01:00
2019-01-25 15:12:10 +01:00
2019-03-19 16:52:03 -03:00
2018-09-19 10:25:10 -03:00
2019-01-04 12:54:49 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-12-27 12:15:55 -03:00
2017-12-27 12:15:55 -03:00
2017-04-24 13:43:33 -03:00
2019-01-25 15:12:10 +01:00
2018-12-17 14:59:20 -03:00
2017-11-02 11:10:55 +01:00
2019-03-11 16:33:19 -03:00
2019-01-25 15:12:10 +01:00
2019-02-09 13:16:01 +01:00
2019-01-25 15:12:09 +01:00
2019-03-11 16:33:19 -03:00
2019-02-06 10:00:38 -03:00
2018-07-24 14:53:01 -03:00
2017-11-02 11:10:55 +01:00
2016-07-29 11:54:35 -03:00
2017-12-27 12:15:47 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-02-27 11:29:21 -03:00
2018-02-27 11:29:21 -03:00
2019-03-01 14:50:47 -03:00
2019-03-01 14:50:47 -03:00
2019-03-06 17:55:35 -03:00
2019-03-06 17:55:35 -03:00
2019-03-11 11:56:02 -03:00
2019-03-11 11:56:02 -03:00
2019-01-21 17:00:57 -03:00
2018-12-17 14:58:47 -03:00
2018-12-17 14:58:33 -03:00
2018-10-08 14:23:45 -03:00
2018-12-17 14:56:02 -03:00
2018-12-17 14:56:08 -03:00
2018-08-10 15:29:35 -03:00
2018-12-17 14:56:02 -03:00
2018-12-17 14:56:02 -03:00
2018-03-06 11:31:14 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-02-06 10:00:38 -03:00
2017-11-02 11:10:55 +01:00
2019-02-06 10:00:38 -03:00
2019-02-06 10:00:38 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-02-25 10:58:28 -03:00
2019-02-25 10:58:28 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-02-06 10:00:38 -03:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2019-01-21 15:15:57 -03:00