Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
torvalds
GitHub Repository: torvalds/linux
Path: blob/master/tools/bootconfig/scripts/ftrace.sh
26288 views
1
#!/bin/sh
2
# SPDX-License-Identifier: GPL-2.0-only
3
4
clear_trace() { # reset trace output
5
echo > trace
6
}
7
8
disable_tracing() { # stop trace recording
9
echo 0 > tracing_on
10
}
11
12
enable_tracing() { # start trace recording
13
echo 1 > tracing_on
14
}
15
16
reset_tracer() { # reset the current tracer
17
echo nop > current_tracer
18
}
19
20
reset_trigger_file() {
21
# remove action triggers first
22
grep -H ':on[^:]*(' $@ |
23
while read line; do
24
cmd=`echo $line | cut -f2- -d: | cut -f1 -d"["`
25
file=`echo $line | cut -f1 -d:`
26
echo "!$cmd" >> $file
27
done
28
grep -Hv ^# $@ |
29
while read line; do
30
cmd=`echo $line | cut -f2- -d: | cut -f1 -d"["`
31
file=`echo $line | cut -f1 -d:`
32
echo "!$cmd" > $file
33
done
34
}
35
36
reset_trigger() { # reset all current setting triggers
37
if [ -d events/synthetic ]; then
38
reset_trigger_file events/synthetic/*/trigger
39
fi
40
reset_trigger_file events/*/*/trigger
41
}
42
43
reset_events_filter() { # reset all current setting filters
44
grep -v ^none events/*/*/filter |
45
while read line; do
46
echo 0 > `echo $line | cut -f1 -d:`
47
done
48
}
49
50
reset_ftrace_filter() { # reset all triggers in set_ftrace_filter
51
if [ ! -f set_ftrace_filter ]; then
52
return 0
53
fi
54
echo > set_ftrace_filter
55
grep -v '^#' set_ftrace_filter | while read t; do
56
tr=`echo $t | cut -d: -f2`
57
if [ "$tr" = "" ]; then
58
continue
59
fi
60
if ! grep -q "$t" set_ftrace_filter; then
61
continue;
62
fi
63
name=`echo $t | cut -d: -f1 | cut -d' ' -f1`
64
if [ $tr = "enable_event" -o $tr = "disable_event" ]; then
65
tr=`echo $t | cut -d: -f2-4`
66
limit=`echo $t | cut -d: -f5`
67
else
68
tr=`echo $t | cut -d: -f2`
69
limit=`echo $t | cut -d: -f3`
70
fi
71
if [ "$limit" != "unlimited" ]; then
72
tr="$tr:$limit"
73
fi
74
echo "!$name:$tr" > set_ftrace_filter
75
done
76
}
77
78
disable_events() {
79
echo 0 > events/enable
80
}
81
82
clear_synthetic_events() { # reset all current synthetic events
83
grep -v ^# synthetic_events |
84
while read line; do
85
echo "!$line" >> synthetic_events
86
done
87
}
88
89
initialize_ftrace() { # Reset ftrace to initial-state
90
# As the initial state, ftrace will be set to nop tracer,
91
# no events, no triggers, no filters, no function filters,
92
# no probes, and tracing on.
93
disable_tracing
94
reset_tracer
95
reset_trigger
96
reset_events_filter
97
reset_ftrace_filter
98
disable_events
99
[ -f set_event_pid ] && echo > set_event_pid
100
[ -f set_ftrace_pid ] && echo > set_ftrace_pid
101
[ -f set_ftrace_notrace ] && echo > set_ftrace_notrace
102
[ -f set_graph_function ] && echo | tee set_graph_*
103
[ -f stack_trace_filter ] && echo > stack_trace_filter
104
[ -f kprobe_events ] && echo > kprobe_events
105
[ -f uprobe_events ] && echo > uprobe_events
106
[ -f synthetic_events ] && echo > synthetic_events
107
[ -f snapshot ] && echo 0 > snapshot
108
clear_trace
109
enable_tracing
110
}
111
112