Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 1 | perf-diff(1) |
Arnaldo Carvalho de Melo | 4778e0e | 2010-05-05 11:23:27 -0300 | [diff] [blame] | 2 | ============ |
Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 3 | |
| 4 | NAME |
| 5 | ---- |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 6 | perf-diff - Read perf.data files and display the differential profile |
Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 7 | |
| 8 | SYNOPSIS |
| 9 | -------- |
| 10 | [verse] |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 11 | 'perf diff' [baseline file] [data file1] [[data file2] ... ] |
Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 12 | |
| 13 | DESCRIPTION |
| 14 | ----------- |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 15 | This command displays the performance difference amongst two or more perf.data |
| 16 | files captured via perf record. |
Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 17 | |
| 18 | If no parameters are passed it will assume perf.data.old and perf.data. |
| 19 | |
Jiri Olsa | 863e451 | 2012-09-06 17:46:55 +0200 | [diff] [blame] | 20 | The differential profile is displayed only for events matching both |
| 21 | specified perf.data files. |
| 22 | |
Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 23 | OPTIONS |
| 24 | ------- |
Shawn Bohrer | 5ea4f85 | 2010-11-30 19:57:12 -0600 | [diff] [blame] | 25 | -D:: |
| 26 | --dump-raw-trace:: |
| 27 | Dump raw trace in ASCII. |
| 28 | |
| 29 | -m:: |
| 30 | --modules:: |
| 31 | Load module symbols. WARNING: use only with -k and LIVE kernel |
| 32 | |
Arnaldo Carvalho de Melo | c351c28 | 2009-12-16 13:49:27 -0200 | [diff] [blame] | 33 | -d:: |
| 34 | --dsos=:: |
| 35 | Only consider symbols in these dsos. CSV that understands |
Namhyung Kim | 8810f6c | 2014-02-07 12:06:07 +0900 | [diff] [blame] | 36 | file://filename entries. This option will affect the percentage |
| 37 | of the Baseline/Delta column. See --percentage for more info. |
Arnaldo Carvalho de Melo | c351c28 | 2009-12-16 13:49:27 -0200 | [diff] [blame] | 38 | |
| 39 | -C:: |
| 40 | --comms=:: |
| 41 | Only consider symbols in these comms. CSV that understands |
Namhyung Kim | 8810f6c | 2014-02-07 12:06:07 +0900 | [diff] [blame] | 42 | file://filename entries. This option will affect the percentage |
| 43 | of the Baseline/Delta column. See --percentage for more info. |
Arnaldo Carvalho de Melo | c351c28 | 2009-12-16 13:49:27 -0200 | [diff] [blame] | 44 | |
| 45 | -S:: |
| 46 | --symbols=:: |
| 47 | Only consider these symbols. CSV that understands |
Namhyung Kim | 8810f6c | 2014-02-07 12:06:07 +0900 | [diff] [blame] | 48 | file://filename entries. This option will affect the percentage |
| 49 | of the Baseline/Delta column. See --percentage for more info. |
Arnaldo Carvalho de Melo | c351c28 | 2009-12-16 13:49:27 -0200 | [diff] [blame] | 50 | |
| 51 | -s:: |
| 52 | --sort=:: |
Namhyung Kim | a2ce067 | 2014-03-04 09:06:42 +0900 | [diff] [blame^] | 53 | Sort by key(s): pid, comm, dso, symbol, cpu, parent, srcline. |
| 54 | Please see description of --sort in the perf-report man page. |
Arnaldo Carvalho de Melo | c351c28 | 2009-12-16 13:49:27 -0200 | [diff] [blame] | 55 | |
| 56 | -t:: |
| 57 | --field-separator=:: |
| 58 | |
| 59 | Use a special separator character and don't pad with spaces, replacing |
Shawn Bohrer | 5ea4f85 | 2010-11-30 19:57:12 -0600 | [diff] [blame] | 60 | all occurrences of this separator in symbol names (and other output) |
Arnaldo Carvalho de Melo | c351c28 | 2009-12-16 13:49:27 -0200 | [diff] [blame] | 61 | with a '.' character, that thus it's the only non valid separator. |
| 62 | |
Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 63 | -v:: |
| 64 | --verbose:: |
Ingo Molnar | d30531c | 2009-12-15 10:24:08 +0100 | [diff] [blame] | 65 | Be verbose, for instance, show the raw counts in addition to the |
Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 66 | diff. |
Arnaldo Carvalho de Melo | cdccc69 | 2009-12-15 11:01:22 -0200 | [diff] [blame] | 67 | |
Shawn Bohrer | 5ea4f85 | 2010-11-30 19:57:12 -0600 | [diff] [blame] | 68 | -f:: |
| 69 | --force:: |
| 70 | Don't complain, do it. |
| 71 | |
David Ahern | ec5761e | 2010-12-09 13:27:07 -0700 | [diff] [blame] | 72 | --symfs=<directory>:: |
| 73 | Look for files with symbols relative to this directory. |
Shawn Bohrer | 5ea4f85 | 2010-11-30 19:57:12 -0600 | [diff] [blame] | 74 | |
Jiri Olsa | a06d143 | 2012-10-05 16:44:40 +0200 | [diff] [blame] | 75 | -b:: |
| 76 | --baseline-only:: |
| 77 | Show only items with match in baseline. |
| 78 | |
Jiri Olsa | 7aaf6b3 | 2012-10-05 16:44:41 +0200 | [diff] [blame] | 79 | -c:: |
| 80 | --compute:: |
Jiri Olsa | 81d5f95 | 2012-10-05 16:44:43 +0200 | [diff] [blame] | 81 | Differential computation selection - delta,ratio,wdiff (default is delta). |
Jiri Olsa | 7aaf6b3 | 2012-10-05 16:44:41 +0200 | [diff] [blame] | 82 | See COMPARISON METHODS section for more info. |
| 83 | |
Jiri Olsa | 61949b2 | 2012-10-05 16:44:44 +0200 | [diff] [blame] | 84 | -p:: |
| 85 | --period:: |
| 86 | Show period values for both compared hist entries. |
| 87 | |
Jiri Olsa | ed279da | 2012-10-05 16:44:45 +0200 | [diff] [blame] | 88 | -F:: |
| 89 | --formula:: |
| 90 | Show formula for given computation. |
| 91 | |
Jiri Olsa | 5f3f8d3 | 2012-11-25 23:10:20 +0100 | [diff] [blame] | 92 | -o:: |
| 93 | --order:: |
| 94 | Specify compute sorting column number. |
| 95 | |
Namhyung Kim | 8810f6c | 2014-02-07 12:06:07 +0900 | [diff] [blame] | 96 | --percentage:: |
| 97 | Determine how to display the overhead percentage of filtered entries. |
| 98 | Filters can be applied by --comms, --dsos and/or --symbols options. |
| 99 | |
| 100 | "relative" means it's relative to filtered entries only so that the |
| 101 | sum of shown entries will be always 100%. "absolute" means it retains |
| 102 | the original value before and after the filter is applied. |
| 103 | |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 104 | COMPARISON |
| 105 | ---------- |
| 106 | The comparison is governed by the baseline file. The baseline perf.data |
| 107 | file is iterated for samples. All other perf.data files specified on |
| 108 | the command line are searched for the baseline sample pair. If the pair |
| 109 | is found, specified computation is made and result is displayed. |
| 110 | |
| 111 | All samples from non-baseline perf.data files, that do not match any |
| 112 | baseline entry, are displayed with empty space within baseline column |
| 113 | and possible computation results (delta) in their related column. |
| 114 | |
| 115 | Example files samples: |
| 116 | - file A with samples f1, f2, f3, f4, f6 |
| 117 | - file B with samples f2, f4, f5 |
| 118 | - file C with samples f1, f2, f5 |
| 119 | |
| 120 | Example output: |
| 121 | x - computation takes place for pair |
| 122 | b - baseline sample percentage |
| 123 | |
| 124 | - perf diff A B C |
| 125 | |
| 126 | baseline/A compute/B compute/C samples |
| 127 | --------------------------------------- |
| 128 | b x f1 |
| 129 | b x x f2 |
| 130 | b f3 |
| 131 | b x f4 |
| 132 | b f6 |
| 133 | x x f5 |
| 134 | |
| 135 | - perf diff B A C |
| 136 | |
| 137 | baseline/B compute/A compute/C samples |
| 138 | --------------------------------------- |
| 139 | b x x f2 |
| 140 | b x f4 |
| 141 | b x f5 |
| 142 | x x f1 |
| 143 | x f3 |
| 144 | x f6 |
| 145 | |
| 146 | - perf diff C B A |
| 147 | |
| 148 | baseline/C compute/B compute/A samples |
| 149 | --------------------------------------- |
| 150 | b x f1 |
| 151 | b x x f2 |
| 152 | b x f5 |
| 153 | x f3 |
| 154 | x x f4 |
| 155 | x f6 |
| 156 | |
Jiri Olsa | 7aaf6b3 | 2012-10-05 16:44:41 +0200 | [diff] [blame] | 157 | COMPARISON METHODS |
| 158 | ------------------ |
| 159 | delta |
| 160 | ~~~~~ |
| 161 | If specified the 'Delta' column is displayed with value 'd' computed as: |
| 162 | |
| 163 | d = A->period_percent - B->period_percent |
| 164 | |
| 165 | with: |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 166 | - A/B being matching hist entry from data/baseline file specified |
Jiri Olsa | 7aaf6b3 | 2012-10-05 16:44:41 +0200 | [diff] [blame] | 167 | (or perf.data/perf.data.old) respectively. |
| 168 | |
| 169 | - period_percent being the % of the hist entry period value within |
| 170 | single data file |
| 171 | |
Namhyung Kim | 8810f6c | 2014-02-07 12:06:07 +0900 | [diff] [blame] | 172 | - with filtering by -C, -d and/or -S, period_percent might be changed |
| 173 | relative to how entries are filtered. Use --percentage=absolute to |
| 174 | prevent such fluctuation. |
| 175 | |
Jiri Olsa | 7aaf6b3 | 2012-10-05 16:44:41 +0200 | [diff] [blame] | 176 | ratio |
| 177 | ~~~~~ |
| 178 | If specified the 'Ratio' column is displayed with value 'r' computed as: |
| 179 | |
| 180 | r = A->period / B->period |
| 181 | |
| 182 | with: |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 183 | - A/B being matching hist entry from data/baseline file specified |
Jiri Olsa | 7aaf6b3 | 2012-10-05 16:44:41 +0200 | [diff] [blame] | 184 | (or perf.data/perf.data.old) respectively. |
| 185 | |
| 186 | - period being the hist entry period value |
| 187 | |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 188 | wdiff:WEIGHT-B,WEIGHT-A |
| 189 | ~~~~~~~~~~~~~~~~~~~~~~~ |
Jiri Olsa | 81d5f95 | 2012-10-05 16:44:43 +0200 | [diff] [blame] | 190 | If specified the 'Weighted diff' column is displayed with value 'd' computed as: |
| 191 | |
| 192 | d = B->period * WEIGHT-A - A->period * WEIGHT-B |
| 193 | |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 194 | - A/B being matching hist entry from data/baseline file specified |
Jiri Olsa | 81d5f95 | 2012-10-05 16:44:43 +0200 | [diff] [blame] | 195 | (or perf.data/perf.data.old) respectively. |
| 196 | |
| 197 | - period being the hist entry period value |
| 198 | |
| 199 | - WEIGHT-A/WEIGHT-B being user suplied weights in the the '-c' option |
| 200 | behind ':' separator like '-c wdiff:1,2'. |
Jiri Olsa | 3a3beae | 2012-10-24 14:56:51 +0200 | [diff] [blame] | 201 | - WIEGHT-A being the weight of the data file |
| 202 | - WIEGHT-B being the weight of the baseline data file |
Jiri Olsa | 7aaf6b3 | 2012-10-05 16:44:41 +0200 | [diff] [blame] | 203 | |
Arnaldo Carvalho de Melo | 86a9eee | 2009-12-14 20:09:31 -0200 | [diff] [blame] | 204 | SEE ALSO |
| 205 | -------- |
Namhyung Kim | a2ce067 | 2014-03-04 09:06:42 +0900 | [diff] [blame^] | 206 | linkperf:perf-record[1], linkperf:perf-report[1] |