Chun-Tse Shao
3c97e7b991
perf lock: Report owner stack in usermode
...
This patch parses `owner_lock_stat` into a RB tree, enabling ordered
reporting of owner lock statistics with stack traces. It also updates
the documentation for the `-o` option in contention mode, decouples `-o`
from `-t`, and issues a warning to inform users about the new behavior
of `-ov`.
Example output:
$ sudo ~/linux/tools/perf/perf lock con -abvo -Y mutex-spin -E3 perf bench sched pipe
...
contended total wait max wait avg wait type caller
171 1.55 ms 20.26 us 9.06 us mutex pipe_read+0x57
0xffffffffac6318e7 pipe_read+0x57
0xffffffffac623862 vfs_read+0x332
0xffffffffac62434b ksys_read+0xbb
0xfffffffface604b2 do_syscall_64+0x82
0xffffffffad00012f entry_SYSCALL_64_after_hwframe+0x76
36 193.71 us 15.27 us 5.38 us mutex pipe_write+0x50
0xffffffffac631ee0 pipe_write+0x50
0xffffffffac6241db vfs_write+0x3bb
0xffffffffac6244ab ksys_write+0xbb
0xfffffffface604b2 do_syscall_64+0x82
0xffffffffad00012f entry_SYSCALL_64_after_hwframe+0x76
4 51.22 us 16.47 us 12.80 us mutex do_epoll_wait+0x24d
0xffffffffac691f0d do_epoll_wait+0x24d
0xffffffffac69249b do_epoll_pwait.part.0+0xb
0xffffffffac693ba5 __x64_sys_epoll_pwait+0x95
0xfffffffface604b2 do_syscall_64+0x82
0xffffffffad00012f entry_SYSCALL_64_after_hwframe+0x76
=== owner stack trace ===
3 31.24 us 15.27 us 10.41 us mutex pipe_read+0x348
0xffffffffac631bd8 pipe_read+0x348
0xffffffffac623862 vfs_read+0x332
0xffffffffac62434b ksys_read+0xbb
0xfffffffface604b2 do_syscall_64+0x82
0xffffffffad00012f entry_SYSCALL_64_after_hwframe+0x76
...
Signed-off-by: Chun-Tse Shao <ctshao@google.com >
Tested-by: Athira Rajeev <atrajeev@linux.ibm.com >
Link: https://lore.kernel.org/r/20250227003359.732948-5-ctshao@google.com
Signed-off-by: Namhyung Kim <namhyung@kernel.org >
2025-02-28 10:09:02 -08:00
..
2024-12-09 17:52:41 -03:00
2025-02-28 00:29:37 -08:00
2024-09-24 11:46:46 -07:00
2024-06-26 11:07:42 -07:00
2024-11-09 08:39:14 -08:00
2024-12-18 16:24:33 -03:00
2023-08-16 08:48:06 -03:00
2024-06-26 11:07:42 -07:00
2025-02-12 20:06:11 -08:00
2025-02-17 22:00:50 -08:00
2025-02-18 14:04:32 -08: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
2025-02-26 13:42:49 -08:00
2024-10-18 10:17:40 -07:00
2025-01-27 15:58:01 -08:00
2025-01-27 15:58:01 -08:00
2025-02-12 20:06:11 -08:00
2022-10-27 16:37:26 -03:00
2025-02-12 20:06:11 -08:00
2024-10-03 15:23:09 -07:00
2025-02-12 20:06:11 -08:00
2024-12-18 16:24:32 -03:00
2024-08-14 10:20:40 -03:00
2024-08-14 10:20:40 -03:00
2023-11-09 13:49:33 -03:00
2024-09-03 11:43:16 -03:00
2024-11-01 23:31:08 -07:00
2023-01-10 10:51:39 -03:00
2025-02-26 13:48:02 -08:00
2024-12-18 16:24:33 -03:00
2024-12-18 16:24:33 -03:00
2025-02-28 10:09:02 -08:00
2024-08-21 11:39:51 -03:00
2022-10-27 16:37:26 -03:00
2025-01-14 14:57:19 -03:00
2024-12-10 16:59:32 -03:00
2024-01-03 17:54:54 -03:00
2024-11-22 13:36:00 -08:00
2024-08-01 12:11:33 -03:00
2024-08-28 18:21:49 -03:00
2024-08-28 18:21:49 -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
2024-08-14 10:20:40 -03:00
2024-12-09 17:52:41 -03:00
2024-12-09 17:52:41 -03:00
2025-02-12 20:06:11 -08:00
2024-12-02 12:36:20 -08:00
2024-08-12 18:07:10 -03:00
2023-05-28 10:24:14 -03:00
2023-02-16 09:33:45 -03:00
2021-03-23 17:13:43 -03:00
2024-09-10 17:32:47 -03:00
2024-09-10 17:32:47 -03:00
2024-10-28 13:04:52 -03:00
2024-08-20 17:53:12 -03:00
2024-12-18 16:24:33 -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
2024-10-10 23:38:33 -07:00
2024-10-28 09:32:57 -07:00
2025-01-31 14:45:19 -08:00
2023-11-28 14:25:06 -03:00
2024-12-18 16:24:32 -03:00
2025-01-14 15:05:56 -03:00
2019-10-15 12:05:18 -03:00
2022-10-27 16:37:25 -03:00
2022-10-27 16:37:25 -03:00
2025-02-27 08:47:25 -08:00
2024-05-07 18:06:44 -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
2025-02-12 20:06:11 -08:00
2024-08-29 15:55:24 -03:00
2024-12-09 17:52:42 -03:00
2024-12-09 17:52:42 -03:00
2021-04-29 10:30:58 -03:00
2024-08-12 18:15:39 -03:00
2024-01-22 12:08:21 -08:00
2024-05-06 15:28:49 -03:00
2021-05-25 10:07:17 -03:00
2024-11-08 22:42:57 -08:00
2024-03-21 10:41:28 -03:00
2025-02-12 19:44:16 -08:00
2024-10-18 10:17:40 -07: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
2024-08-01 18:54:19 -03:00
2024-08-01 18:54:19 -03:00
2025-01-27 15:58:01 -08:00
2024-11-09 08:39:13 -08:00
2024-12-18 16:24:32 -03:00
2021-08-11 09:35:44 -03:00
2024-08-19 14:52:13 -03:00
2024-08-19 14:52:13 -03:00
2024-08-19 14:52:13 -03:00
2024-08-19 14:52:13 -03:00
2024-09-03 12:22:01 -03:00
2024-09-03 12:22:01 -03:00
2024-10-18 10:17:40 -07:00
2024-10-18 10:17:40 -07:00
2024-11-09 08:39:13 -08:00
2024-11-09 08:39:13 -08:00
2024-11-09 08:39:13 -08:00
2024-11-09 08:39:14 -08:00
2025-02-27 08:47:25 -08:00
2024-12-18 16:24:33 -03:00
2025-02-18 14:04:32 -08:00
2024-10-29 16:10:14 -07:00
2025-02-18 14:04:32 -08:00
2024-11-07 10:51:56 -08:00
2024-11-07 10:51:56 -08:00
2024-12-18 16:24:32 -03:00
2024-12-09 17:52:42 -03:00
2023-05-12 15:21:49 -03:00
2025-02-12 20:06:11 -08:00
2025-02-04 21:29:13 -08:00
2020-11-30 09:48:07 -03:00
2023-01-23 10:00:47 -03:00
2025-02-10 11:46:30 -08:00
2023-08-17 14:12:14 -03:00
2024-02-13 13:47:08 -08: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
2025-02-26 13:48:02 -08:00
2023-06-20 22:18:58 -07:00
2024-10-18 10:17:40 -07:00
2024-10-18 10:17:40 -07:00
2025-01-10 10:59:42 -03:00
2021-08-30 10:06:16 -03:00
2022-11-09 20:45:14 -08:00
2024-10-14 12:04:31 -07:00
2025-02-24 15:46:33 -08:00
2024-11-16 16:40:30 -03:00
2024-03-21 13:54:40 -03:00
2024-08-12 18:05:14 -03:00
2022-10-15 10:13:16 -03:00
2025-02-24 16:02:28 -08:00
2025-02-18 14:04:32 -08:00
2025-02-24 15:46:33 -08:00
2025-02-04 17:22:40 -08:00
2025-02-12 20:06:11 -08:00
2025-02-12 20:06:11 -08:00
2023-10-17 12:40:50 -07:00
2024-08-13 15:24:48 -03:00
2024-08-13 15:24:48 -03: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
2024-08-19 14:51:46 -03:00
2025-02-12 20:06:11 -08:00
2020-05-28 10:03:27 -03:00
2024-12-18 16:24:32 -03:00
2024-12-18 16:24:32 -03:00
2024-12-18 16:24:33 -03:00
2021-03-23 17:13:43 -03:00
2025-01-08 17:38:32 -03:00
2024-09-03 10:39:20 -03:00
2024-12-18 16:24:33 -03:00
2025-02-28 10:09:02 -08:00
2023-08-22 16:53:32 -03:00
2025-02-24 15:46:33 -08:00
2025-02-17 22:00:50 -08:00
2024-08-01 18:55:55 -03:00
2024-08-01 18:55:55 -03:00
2024-09-10 17:32:47 -03:00
2024-09-10 17:32:47 -03:00
2025-01-08 17:20:42 -03:00
2024-02-12 12:35:41 -08:00
2020-11-04 09:42:40 -03:00
2025-02-19 13:23:43 -08:00
2024-09-06 11:45:17 -03:00
2024-08-01 18:55:55 -03:00
2024-08-01 18:55:55 -03:00
2024-10-10 23:40:32 -07:00
2024-04-18 22:22:51 -03:00
2025-02-10 11:46:02 -08:00
2025-02-10 11:46:02 -08:00
2022-10-04 08:55:20 -03:00
2022-10-04 08:55:20 -03:00
2025-01-08 17:31:06 -03:00
2025-01-08 17:31:06 -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
2025-02-24 15:46:33 -08:00
2024-12-18 16:24:32 -03:00
2025-02-20 22:35:10 -08:00
2024-10-10 23:40:32 -07:00
2024-02-15 13:48:36 -08:00
2020-08-14 09:15:47 -03:00
2021-08-24 15:01:31 -03:00
2024-12-23 13:53:08 -03:00
2024-12-23 13:53:08 -03:00
2023-12-12 14:55:13 -03:00
2021-06-01 10:32:00 -03:00
2024-12-18 16:24:32 -03:00
2024-02-15 13:48:36 -08:00
2024-02-15 13:48:36 -08:00
2023-01-02 12:34:06 -03:00
2024-11-13 16:27:35 -03:00
2022-11-24 10:04:52 -03:00
2025-02-26 16:23:47 -08:00
2025-02-26 16:23:47 -08:00
2023-04-06 21:40:28 -03:00
2023-09-12 17:47:00 -03:00
2025-02-26 16:23:47 -08:00
2024-11-09 08:28:03 -08:00
2020-10-01 12:10:56 -03:00
2024-07-31 16:12:59 -03:00
2024-07-31 16:12:59 -03:00
2024-10-10 23:40:32 -07:00
2024-10-10 23:40:32 -07:00
2025-01-14 14:57:19 -03:00
2024-12-10 15:41:10 -03:00
2024-11-16 17:07:31 -03:00
2024-11-16 17:07:31 -03:00
2025-02-26 14:25:14 -08:00
2025-02-26 14:25:14 -08:00
2020-05-28 10:03:27 -03:00
2025-02-12 20:06:11 -08:00
2024-03-21 10:41:28 -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
2025-02-12 20:06:11 -08:00
2024-10-17 12:44:26 -07:00
2021-09-10 18:15:21 -03:00
2021-09-10 18:15:21 -03:00
2025-02-12 20:06:11 -08:00
2025-02-18 14:04:32 -08:00
2025-02-17 22:00:50 -08:00
2025-02-17 22:00:50 -08:00
2024-08-22 17:26:50 -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
2025-02-18 14:04:32 -08:00
2025-02-18 14:04:32 -08:00
2021-06-08 09:36:36 -03:00
2024-09-03 10:15:16 -03:00
2023-06-14 18:19:06 -03:00
2025-02-04 21:29:13 -08:00
2025-01-29 14:06:25 -08:00
2025-02-04 21:29:05 -08:00
2024-12-18 16:24:32 -03:00
2021-03-23 17:13:43 -03:00
2024-12-23 13:53:08 -03:00
2024-12-23 13:53:08 -03:00
2023-04-06 21:41:00 -03:00
2021-03-23 17:13:43 -03:00
2024-11-14 16:56:32 -03:00
2024-12-12 15:53:36 -03:00
2024-12-09 17:52:41 -03:00
2025-02-18 14:04:32 -08:00
2024-05-06 15:28:49 -03:00
2025-01-10 10:59:42 -03:00
2024-05-06 15:28:49 -03:00
2025-02-18 14:04:32 -08:00
2024-05-07 18:06:44 -03:00
2023-02-01 21:51:51 -03:00
2025-02-24 15:46:33 -08:00
2024-09-10 17:32:47 -03:00
2025-01-10 10:59:42 -03:00
2025-01-10 10:59:42 -03:00
2021-01-20 14:25:28 -03:00
2024-11-01 23:31:08 -07:00
2024-02-22 09:11:03 -08: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-08-08 17:30:27 -03:00
2024-08-08 17:30:27 -03:00
2024-10-14 12:04:31 -07:00
2024-03-03 22:52:13 -08:00
2024-09-03 11:21:55 -03:00
2025-02-26 16:23:47 -08:00
2025-02-26 16:23:47 -08:00
2024-08-12 18:13:58 -03:00
2024-08-12 18:13:58 -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
2024-09-10 09:52:13 -03:00
2023-10-12 10:01:57 -07:00
2024-12-09 17:52:42 -03:00
2024-11-08 22:42:57 -08:00
2024-12-18 16:24:33 -03:00
2024-11-08 22:42:57 -08:00
2024-12-18 16:24:32 -03:00
2024-05-09 18:46:43 -03:00
2024-05-09 18:46:43 -03:00
2024-11-13 16:27:35 -03:00
2024-10-10 23:40:32 -07:00
2021-03-15 11:36:54 -03:00
2021-03-15 11:36:54 -03:00
2025-02-12 20:06:11 -08:00
2022-04-09 12:34:29 -03:00
2024-07-17 13:17:57 -07:00
2024-05-06 15:28:49 -03:00
2023-08-16 08:48:06 -03:00
2023-04-10 19:20:53 -03:00
2024-11-16 16:30:39 -03:00
2024-11-16 16:30:39 -03:00
2024-12-23 13:53:08 -03:00
2024-12-23 13:53:08 -03:00
2024-09-27 15:38:52 -03:00
2023-11-28 14:25:06 -03:00