|
12 | 12 | # (note, if this is a problem with function_graph tracing, then simply
|
13 | 13 | # replace "function" with "function_graph" in the following steps).
|
14 | 14 | #
|
15 |
| -# # cd /sys/kernel/debug/tracing |
| 15 | +# # cd /sys/kernel/tracing |
16 | 16 | # # echo schedule > set_ftrace_filter
|
17 | 17 | # # echo function > current_tracer
|
18 | 18 | #
|
19 | 19 | # If this works, then we know that something is being traced that shouldn't be.
|
20 | 20 | #
|
21 | 21 | # # echo nop > current_tracer
|
22 | 22 | #
|
23 |
| -# # cat available_filter_functions > ~/full-file |
| 23 | +# Starting with v5.1 this can be done with numbers, making it much faster: |
| 24 | +# |
| 25 | +# The old (slow) way, for kernels before v5.1. |
| 26 | +# |
| 27 | +# [old-way] # cat available_filter_functions > ~/full-file |
| 28 | +# |
| 29 | +# [old-way] *** Note *** this process will take several minutes to update the |
| 30 | +# [old-way] filters. Setting multiple functions is an O(n^2) operation, and we |
| 31 | +# [old-way] are dealing with thousands of functions. So go have coffee, talk |
| 32 | +# [old-way] with your coworkers, read facebook. And eventually, this operation |
| 33 | +# [old-way] will end. |
| 34 | +# |
| 35 | +# The new way (using numbers) is an O(n) operation, and usually takes less than a second. |
| 36 | +# |
| 37 | +# seq `wc -l available_filter_functions | cut -d' ' -f1` > ~/full-file |
| 38 | +# |
| 39 | +# This will create a sequence of numbers that match the functions in |
| 40 | +# available_filter_functions, and when echoing in a number into the |
| 41 | +# set_ftrace_filter file, it will enable the corresponding function in |
| 42 | +# O(1) time. Making enabling all functions O(n) where n is the number of |
| 43 | +# functions to enable. |
| 44 | +# |
| 45 | +# For either the new or old way, the rest of the operations remain the same. |
| 46 | +# |
24 | 47 | # # ftrace-bisect ~/full-file ~/test-file ~/non-test-file
|
25 | 48 | # # cat ~/test-file > set_ftrace_filter
|
26 | 49 | #
|
27 |
| -# *** Note *** this will take several minutes. Setting multiple functions is |
28 |
| -# an O(n^2) operation, and we are dealing with thousands of functions. So go |
29 |
| -# have coffee, talk with your coworkers, read facebook. And eventually, this |
30 |
| -# operation will end. |
31 |
| -# |
32 | 50 | # # echo function > current_tracer
|
33 | 51 | #
|
34 | 52 | # If it crashes, we know that ~/test-file has a bad function.
|
35 | 53 | #
|
36 | 54 | # Reboot back to test kernel.
|
37 | 55 | #
|
38 |
| -# # cd /sys/kernel/debug/tracing |
| 56 | +# # cd /sys/kernel/tracing |
39 | 57 | # # mv ~/test-file ~/full-file
|
40 | 58 | #
|
41 | 59 | # If it didn't crash.
|
|
0 commit comments