Steven Rostedt (Google)
cc5fc8bfc9
tracing/histogram: Add stacktrace type
Now that stacktraces can be part of synthetic events, allow a key to be
typed as a stacktrace.
# cd /sys/kernel/tracing
# echo 's:block_lat u64 delta; unsigned long stack[];' >> dynamic_events
# echo 'hist:keys=next_pid:ts=common_timestamp.usecs,st=stacktrace if prev_state == 2' >> events/sched/sched_switch/trigger
# echo 'hist:keys=prev_pid:delta=common_timestamp.usecs-$ts,st2=$st:onmatch(sched.sched_switch).trace(block_lat,$delta,$st2)' >> events/sched/sched_switch/trigger
# echo 'hist:keys=delta.buckets=100,stack.stacktrace:sort=delta' > events/synthetic/block_lat/trigger
# cat events/synthetic/block_lat/hist
# event histogram
#
# trigger info: hist:keys=delta.buckets=100,stacktrace:vals=hitcount:sort=delta.buckets=100:size=2048 [active]
#
{ delta: ~ 0-99, stacktrace:
event_hist_trigger+0x464/0x480
event_triggers_call+0x52/0xe0
trace_event_buffer_commit+0x193/0x250
trace_event_raw_event_sched_switch+0xfc/0x150
__traceiter_sched_switch+0x41/0x60
__schedule+0x448/0x7b0
schedule_idle+0x26/0x40
cpu_startup_entry+0x19/0x20
start_secondary+0xed/0xf0
secondary_startup_64_no_verify+0xe0/0xeb
} hitcount: 6
{ delta: ~ 0-99, stacktrace:
event_hist_trigger+0x464/0x480
event_triggers_call+0x52/0xe0
trace_event_buffer_commit+0x193/0x250
trace_event_raw_event_sched_switch+0xfc/0x150
__traceiter_sched_switch+0x41/0x60
__schedule+0x448/0x7b0
schedule_idle+0x26/0x40
cpu_startup_entry+0x19/0x20
__pfx_kernel_init+0x0/0x10
arch_call_rest_init+0xa/0x24
start_kernel+0x964/0x98d
secondary_startup_64_no_verify+0xe0/0xeb
} hitcount: 3
{ delta: ~ 0-99, stacktrace:
event_hist_trigger+0x464/0x480
event_triggers_call+0x52/0xe0
trace_event_buffer_commit+0x193/0x250
trace_event_raw_event_sched_switch+0xfc/0x150
__traceiter_sched_switch+0x41/0x60
__schedule+0x448/0x7b0
schedule+0x5a/0xb0
worker_thread+0xaf/0x380
kthread+0xe9/0x110
ret_from_fork+0x2c/0x50
} hitcount: 1
{ delta: ~ 100-199, stacktrace:
event_hist_trigger+0x464/0x480
event_triggers_call+0x52/0xe0
trace_event_buffer_commit+0x193/0x250
trace_event_raw_event_sched_switch+0xfc/0x150
__traceiter_sched_switch+0x41/0x60
__schedule+0x448/0x7b0
schedule_idle+0x26/0x40
cpu_startup_entry+0x19/0x20
start_secondary+0xed/0xf0
secondary_startup_64_no_verify+0xe0/0xeb
} hitcount: 15
[..]
{ delta: ~ 8500-8599, stacktrace:
event_hist_trigger+0x464/0x480
event_triggers_call+0x52/0xe0
trace_event_buffer_commit+0x193/0x250
trace_event_raw_event_sched_switch+0xfc/0x150
__traceiter_sched_switch+0x41/0x60
__schedule+0x448/0x7b0
schedule_idle+0x26/0x40
cpu_startup_entry+0x19/0x20
start_secondary+0xed/0xf0
secondary_startup_64_no_verify+0xe0/0xeb
} hitcount: 1
Totals:
Hits: 89
Entries: 11
Dropped: 0
Link: https://lkml.kernel.org/r/20230117152236.167046397@goodmis.org
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Tom Zanussi <zanussi@kernel.org>
Cc: Ross Zwisler <zwisler@google.com>
Cc: Ching-lin Yu <chinglinyu@google.com>
Signed-off-by: Steven Rostedt (Google) <rostedt@goodmis.org>
2023-01-25 10:31:24 -05:00
..
2023-01-25 10:31:02 -05:00
2022-12-08 09:26:11 -07:00
2023-01-06 22:48:58 +01:00
2022-06-03 14:05:34 -07:00
2022-11-04 08:50:07 +09:00
2023-01-24 11:20:58 -05:00
2023-01-24 13:22:38 -05:00
2022-11-18 10:15:34 +09:00
2022-07-30 14:01:28 -04:00
2022-04-26 17:58:50 -04:00
2021-10-05 17:38:45 -04:00
2022-11-18 10:15:34 +09:00
2022-11-23 19:08:30 -05:00
2023-01-25 10:31:24 -05:00
2022-11-17 17:51:38 -05:00
2022-09-26 13:01:09 -04:00
2022-09-26 13:01:09 -04:00
2022-05-26 21:13:00 -04:00
2022-11-23 19:07:12 -05:00
2021-08-18 18:10:32 -04:00
2022-11-24 00:42:18 +09:00
2022-11-23 19:08:31 -05:00
2023-01-25 10:31:11 -05:00
2023-01-25 10:31:24 -05:00
2021-12-06 15:37:21 -05:00
2023-01-25 10:31:24 -05:00
2022-12-14 08:50:56 -05:00
2022-12-15 18:01:16 -08:00
2023-01-25 10:31:11 -05:00
2021-10-13 18:19:41 -04:00
2021-10-27 11:21:49 -04:00
2022-01-15 16:30:24 +02:00
2022-12-09 23:48:05 -05:00
2023-01-24 18:11:41 -05:00
2023-01-24 11:27:29 -05:00
2022-09-06 22:26:00 -04:00
2021-10-08 18:08:43 -04:00
2022-10-12 13:50:20 -04:00
2022-12-15 08:48:57 +09:00
2022-12-21 18:57:24 -08:00
2022-12-15 09:00:20 +09:00
2022-05-26 21:12:52 -04:00
2022-05-12 00:37:11 +02:00
2022-05-12 00:37:11 +02:00
2022-10-17 16:41:19 +02:00
2021-10-08 18:08:43 -04:00
2021-10-08 18:08:43 -04:00
2023-01-25 10:31:24 -05:00
2022-11-17 20:21:06 -05:00
2022-12-15 09:00:20 +09:00
2023-01-24 11:27:29 -05:00
2023-01-25 10:31:24 -05:00
2022-10-03 12:20:31 -04:00