Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 1 | perf-probe(1) |
| 2 | ============= |
| 3 | |
| 4 | NAME |
| 5 | ---- |
| 6 | perf-probe - Define new dynamic tracepoints |
| 7 | |
| 8 | SYNOPSIS |
| 9 | -------- |
| 10 | [verse] |
Masami Hiramatsu | c937fe2 | 2009-12-08 17:03:30 -0500 | [diff] [blame] | 11 | 'perf probe' [options] --add='PROBE' [...] |
Masami Hiramatsu | c43f9d1 | 2009-11-03 19:12:13 -0500 | [diff] [blame] | 12 | or |
Masami Hiramatsu | c937fe2 | 2009-12-08 17:03:30 -0500 | [diff] [blame] | 13 | 'perf probe' [options] PROBE |
| 14 | or |
| 15 | 'perf probe' [options] --del='[GROUP:]EVENT' [...] |
| 16 | or |
| 17 | 'perf probe' --list |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame] | 18 | or |
| 19 | 'perf probe' --line='FUNC[:RLN[+NUM|:RLN2]]|SRC:ALN[+NUM|:ALN2]' |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 20 | |
| 21 | DESCRIPTION |
| 22 | ----------- |
| 23 | This command defines dynamic tracepoint events, by symbol and registers |
| 24 | without debuginfo, or by C expressions (C line numbers, C function names, |
| 25 | and C local variables) with debuginfo. |
| 26 | |
| 27 | |
| 28 | OPTIONS |
| 29 | ------- |
| 30 | -k:: |
Masami Hiramatsu | c43f9d1 | 2009-11-03 19:12:13 -0500 | [diff] [blame] | 31 | --vmlinux=PATH:: |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 32 | Specify vmlinux path which has debuginfo (Dwarf binary). |
| 33 | |
| 34 | -v:: |
| 35 | --verbose:: |
| 36 | Be more verbose (show parsed arguments, etc). |
| 37 | |
Masami Hiramatsu | c43f9d1 | 2009-11-03 19:12:13 -0500 | [diff] [blame] | 38 | -a:: |
Masami Hiramatsu | c937fe2 | 2009-12-08 17:03:30 -0500 | [diff] [blame] | 39 | --add=:: |
| 40 | Define a probe event (see PROBE SYNTAX for detail). |
| 41 | |
| 42 | -d:: |
| 43 | --del=:: |
Masami Hiramatsu | ee391de | 2010-02-25 08:35:19 -0500 | [diff] [blame^] | 44 | Delete probe events. This accepts glob wildcards('*', '?') and character |
| 45 | classes(e.g. [a-z], [!A-Z]). |
Masami Hiramatsu | c937fe2 | 2009-12-08 17:03:30 -0500 | [diff] [blame] | 46 | |
| 47 | -l:: |
| 48 | --list:: |
| 49 | List up current probe events. |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 50 | |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame] | 51 | -L:: |
| 52 | --line=:: |
| 53 | Show source code lines which can be probed. This needs an argument |
Masami Hiramatsu | ee391de | 2010-02-25 08:35:19 -0500 | [diff] [blame^] | 54 | which specifies a range of the source code. (see LINE SYNTAX for detail) |
| 55 | |
| 56 | -f:: |
| 57 | --force:: |
| 58 | Forcibly add events with existing name. |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame] | 59 | |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 60 | PROBE SYNTAX |
| 61 | ------------ |
| 62 | Probe points are defined by following syntax. |
| 63 | |
Masami Hiramatsu | af663d7 | 2009-12-15 10:32:18 -0500 | [diff] [blame] | 64 | "[EVENT=]FUNC[+OFFS|:RLN|%return][@SRC]|SRC:ALN [ARG ...]" |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 65 | |
Masami Hiramatsu | af663d7 | 2009-12-15 10:32:18 -0500 | [diff] [blame] | 66 | 'EVENT' specifies the name of new event, if omitted, it will be set the name of the probed function. Currently, event group name is set as 'probe'. |
Masami Hiramatsu | c43f9d1 | 2009-11-03 19:12:13 -0500 | [diff] [blame] | 67 | 'FUNC' specifies a probed function name, and it may have one of the following options; '+OFFS' is the offset from function entry address in bytes, 'RLN' is the relative-line number from function entry line, and '%return' means that it probes function return. In addition, 'SRC' specifies a source file which has that function. |
| 68 | It is also possible to specify a probe point by the source line number by using 'SRC:ALN' syntax, where 'SRC' is the source file path and 'ALN' is the line number. |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 69 | 'ARG' specifies the arguments of this probe point. You can use the name of local variable, or kprobe-tracer argument format (e.g. $retval, %ax, etc). |
| 70 | |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame] | 71 | LINE SYNTAX |
| 72 | ----------- |
| 73 | Line range is descripted by following syntax. |
| 74 | |
| 75 | "FUNC[:RLN[+NUM|:RLN2]]|SRC:ALN[+NUM|:ALN2]" |
| 76 | |
| 77 | FUNC specifies the function name of showing lines. 'RLN' is the start line |
| 78 | number from function entry line, and 'RLN2' is the end line number. As same as |
| 79 | probe syntax, 'SRC' means the source file path, 'ALN' is start line number, |
| 80 | and 'ALN2' is end line number in the file. It is also possible to specify how |
| 81 | many lines to show by using 'NUM'. |
| 82 | So, "source.c:100-120" shows lines between 100th to l20th in source.c file. And "func:10+20" shows 20 lines from 10th line of func function. |
| 83 | |
Masami Hiramatsu | ee391de | 2010-02-25 08:35:19 -0500 | [diff] [blame^] | 84 | EXAMPLES |
| 85 | -------- |
| 86 | Display which lines in schedule() can be probed: |
| 87 | |
| 88 | ./perf probe --line schedule |
| 89 | |
| 90 | Add a probe on schedule() function 12th line with recording cpu local variable: |
| 91 | |
| 92 | ./perf probe schedule:12 cpu |
| 93 | or |
| 94 | ./perf probe --add='schedule:12 cpu' |
| 95 | |
| 96 | this will add one or more probes which has the name start with "schedule". |
| 97 | |
| 98 | Delete all probes on schedule(). |
| 99 | |
| 100 | ./perf probe --del='schedule*' |
| 101 | |
| 102 | |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 103 | SEE ALSO |
| 104 | -------- |
| 105 | linkperf:perf-trace[1], linkperf:perf-record[1] |