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=:: |
| 44 | Delete a probe event. |
| 45 | |
| 46 | -l:: |
| 47 | --list:: |
| 48 | List up current probe events. |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 49 | |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame^] | 50 | -L:: |
| 51 | --line=:: |
| 52 | Show source code lines which can be probed. This needs an argument |
| 53 | which specifies a range of the source code. |
| 54 | |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 55 | PROBE SYNTAX |
| 56 | ------------ |
| 57 | Probe points are defined by following syntax. |
| 58 | |
Masami Hiramatsu | af663d7 | 2009-12-15 10:32:18 -0500 | [diff] [blame] | 59 | "[EVENT=]FUNC[+OFFS|:RLN|%return][@SRC]|SRC:ALN [ARG ...]" |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 60 | |
Masami Hiramatsu | af663d7 | 2009-12-15 10:32:18 -0500 | [diff] [blame] | 61 | '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] | 62 | '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. |
| 63 | 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] | 64 | '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). |
| 65 | |
Masami Hiramatsu | 631c9de | 2010-01-06 09:45:34 -0500 | [diff] [blame^] | 66 | LINE SYNTAX |
| 67 | ----------- |
| 68 | Line range is descripted by following syntax. |
| 69 | |
| 70 | "FUNC[:RLN[+NUM|:RLN2]]|SRC:ALN[+NUM|:ALN2]" |
| 71 | |
| 72 | FUNC specifies the function name of showing lines. 'RLN' is the start line |
| 73 | number from function entry line, and 'RLN2' is the end line number. As same as |
| 74 | probe syntax, 'SRC' means the source file path, 'ALN' is start line number, |
| 75 | and 'ALN2' is end line number in the file. It is also possible to specify how |
| 76 | many lines to show by using 'NUM'. |
| 77 | 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. |
| 78 | |
Masami Hiramatsu | 595c364 | 2009-10-16 20:08:27 -0400 | [diff] [blame] | 79 | SEE ALSO |
| 80 | -------- |
| 81 | linkperf:perf-trace[1], linkperf:perf-record[1] |