diff options
author | David Ahern <dsahern@gmail.com> | 2011-05-27 16:28:44 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2011-06-02 12:29:14 -0400 |
commit | 610723f24eeb842025178a6722fa9108c4e157b6 (patch) | |
tree | e184c3b2242ba9b9da065221d4673603dd9d8e86 /tools | |
parent | 787bef174f055343c69a9639e6e05a564980ed4c (diff) |
perf script: Make printing of dso a separate field option
The 'sym' option displays both the function name and the DSO it comes
from. Split the display of the dso into a separate option. This allows
display of the ip address and symbol without the dso, thus shortening
line lengths - and decluttering the output a bit.
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/1306528124-25861-3-git-send-email-dsahern@gmail.com
Signed-off-by: David Ahern <dsahern@gmail.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools')
-rw-r--r-- | tools/perf/Documentation/perf-script.txt | 2 | ||||
-rw-r--r-- | tools/perf/builtin-script.c | 17 | ||||
-rw-r--r-- | tools/perf/util/session.c | 13 | ||||
-rw-r--r-- | tools/perf/util/session.h | 2 |
4 files changed, 24 insertions, 10 deletions
diff --git a/tools/perf/Documentation/perf-script.txt b/tools/perf/Documentation/perf-script.txt index 67a4e5cbc880..1e744c2391dc 100644 --- a/tools/perf/Documentation/perf-script.txt +++ b/tools/perf/Documentation/perf-script.txt | |||
@@ -115,7 +115,7 @@ OPTIONS | |||
115 | -f:: | 115 | -f:: |
116 | --fields:: | 116 | --fields:: |
117 | Comma separated list of fields to print. Options are: | 117 | Comma separated list of fields to print. Options are: |
118 | comm, tid, pid, time, cpu, event, trace, ip, sym. Field | 118 | comm, tid, pid, time, cpu, event, trace, ip, sym, dso. Field |
119 | list can be prepended with the type, trace, sw or hw, | 119 | list can be prepended with the type, trace, sw or hw, |
120 | to indicate to which event type the field list applies. | 120 | to indicate to which event type the field list applies. |
121 | e.g., -f sw:comm,tid,time,ip,sym and -f trace:time,cpu,trace | 121 | e.g., -f sw:comm,tid,time,ip,sym and -f trace:time,cpu,trace |
diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c index 0852db2ea155..a8bd00f2e557 100644 --- a/tools/perf/builtin-script.c +++ b/tools/perf/builtin-script.c | |||
@@ -32,6 +32,7 @@ enum perf_output_field { | |||
32 | PERF_OUTPUT_TRACE = 1U << 6, | 32 | PERF_OUTPUT_TRACE = 1U << 6, |
33 | PERF_OUTPUT_IP = 1U << 7, | 33 | PERF_OUTPUT_IP = 1U << 7, |
34 | PERF_OUTPUT_SYM = 1U << 8, | 34 | PERF_OUTPUT_SYM = 1U << 8, |
35 | PERF_OUTPUT_DSO = 1U << 9, | ||
35 | }; | 36 | }; |
36 | 37 | ||
37 | struct output_option { | 38 | struct output_option { |
@@ -47,6 +48,7 @@ struct output_option { | |||
47 | {.str = "trace", .field = PERF_OUTPUT_TRACE}, | 48 | {.str = "trace", .field = PERF_OUTPUT_TRACE}, |
48 | {.str = "ip", .field = PERF_OUTPUT_IP}, | 49 | {.str = "ip", .field = PERF_OUTPUT_IP}, |
49 | {.str = "sym", .field = PERF_OUTPUT_SYM}, | 50 | {.str = "sym", .field = PERF_OUTPUT_SYM}, |
51 | {.str = "dso", .field = PERF_OUTPUT_DSO}, | ||
50 | }; | 52 | }; |
51 | 53 | ||
52 | /* default set to maintain compatibility with current format */ | 54 | /* default set to maintain compatibility with current format */ |
@@ -63,7 +65,7 @@ static struct { | |||
63 | .fields = PERF_OUTPUT_COMM | PERF_OUTPUT_TID | | 65 | .fields = PERF_OUTPUT_COMM | PERF_OUTPUT_TID | |
64 | PERF_OUTPUT_CPU | PERF_OUTPUT_TIME | | 66 | PERF_OUTPUT_CPU | PERF_OUTPUT_TIME | |
65 | PERF_OUTPUT_EVNAME | PERF_OUTPUT_IP | | 67 | PERF_OUTPUT_EVNAME | PERF_OUTPUT_IP | |
66 | PERF_OUTPUT_SYM, | 68 | PERF_OUTPUT_SYM | PERF_OUTPUT_DSO, |
67 | 69 | ||
68 | .invalid_fields = PERF_OUTPUT_TRACE, | 70 | .invalid_fields = PERF_OUTPUT_TRACE, |
69 | }, | 71 | }, |
@@ -74,7 +76,7 @@ static struct { | |||
74 | .fields = PERF_OUTPUT_COMM | PERF_OUTPUT_TID | | 76 | .fields = PERF_OUTPUT_COMM | PERF_OUTPUT_TID | |
75 | PERF_OUTPUT_CPU | PERF_OUTPUT_TIME | | 77 | PERF_OUTPUT_CPU | PERF_OUTPUT_TIME | |
76 | PERF_OUTPUT_EVNAME | PERF_OUTPUT_IP | | 78 | PERF_OUTPUT_EVNAME | PERF_OUTPUT_IP | |
77 | PERF_OUTPUT_SYM, | 79 | PERF_OUTPUT_SYM | PERF_OUTPUT_DSO, |
78 | 80 | ||
79 | .invalid_fields = PERF_OUTPUT_TRACE, | 81 | .invalid_fields = PERF_OUTPUT_TRACE, |
80 | }, | 82 | }, |
@@ -93,7 +95,7 @@ static struct { | |||
93 | .fields = PERF_OUTPUT_COMM | PERF_OUTPUT_TID | | 95 | .fields = PERF_OUTPUT_COMM | PERF_OUTPUT_TID | |
94 | PERF_OUTPUT_CPU | PERF_OUTPUT_TIME | | 96 | PERF_OUTPUT_CPU | PERF_OUTPUT_TIME | |
95 | PERF_OUTPUT_EVNAME | PERF_OUTPUT_IP | | 97 | PERF_OUTPUT_EVNAME | PERF_OUTPUT_IP | |
96 | PERF_OUTPUT_SYM, | 98 | PERF_OUTPUT_SYM | PERF_OUTPUT_DSO, |
97 | 99 | ||
98 | .invalid_fields = PERF_OUTPUT_TRACE, | 100 | .invalid_fields = PERF_OUTPUT_TRACE, |
99 | }, | 101 | }, |
@@ -176,6 +178,11 @@ static int perf_evsel__check_attr(struct perf_evsel *evsel, | |||
176 | "No addresses to convert to symbols.\n"); | 178 | "No addresses to convert to symbols.\n"); |
177 | return -EINVAL; | 179 | return -EINVAL; |
178 | } | 180 | } |
181 | if (PRINT_FIELD(DSO) && !PRINT_FIELD(IP)) { | ||
182 | pr_err("Display of DSO requested but IP is not selected.\n" | ||
183 | "No addresses to convert to dso.\n"); | ||
184 | return -EINVAL; | ||
185 | } | ||
179 | 186 | ||
180 | if ((PRINT_FIELD(PID) || PRINT_FIELD(TID)) && | 187 | if ((PRINT_FIELD(PID) || PRINT_FIELD(TID)) && |
181 | perf_event_attr__check_stype(attr, PERF_SAMPLE_TID, "TID", | 188 | perf_event_attr__check_stype(attr, PERF_SAMPLE_TID, "TID", |
@@ -304,7 +311,7 @@ static void process_event(union perf_event *event __unused, | |||
304 | else | 311 | else |
305 | printf("\n"); | 312 | printf("\n"); |
306 | perf_session__print_ip(event, sample, session, | 313 | perf_session__print_ip(event, sample, session, |
307 | PRINT_FIELD(SYM)); | 314 | PRINT_FIELD(SYM), PRINT_FIELD(DSO)); |
308 | } | 315 | } |
309 | 316 | ||
310 | printf("\n"); | 317 | printf("\n"); |
@@ -996,7 +1003,7 @@ static const struct option options[] = { | |||
996 | OPT_STRING(0, "symfs", &symbol_conf.symfs, "directory", | 1003 | OPT_STRING(0, "symfs", &symbol_conf.symfs, "directory", |
997 | "Look for files with symbols relative to this directory"), | 1004 | "Look for files with symbols relative to this directory"), |
998 | OPT_CALLBACK('f', "fields", NULL, "str", | 1005 | OPT_CALLBACK('f', "fields", NULL, "str", |
999 | "comma separated output fields prepend with 'type:'. Valid types: hw,sw,trace,raw. Fields: comm,tid,pid,time,cpu,event,trace,ip,sym", | 1006 | "comma separated output fields prepend with 'type:'. Valid types: hw,sw,trace,raw. Fields: comm,tid,pid,time,cpu,event,trace,ip,sym,dso", |
1000 | parse_output_fields), | 1007 | parse_output_fields), |
1001 | 1008 | ||
1002 | OPT_END() | 1009 | OPT_END() |
diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index ad33650cdd41..0dd418299261 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c | |||
@@ -1205,7 +1205,7 @@ struct perf_evsel *perf_session__find_first_evtype(struct perf_session *session, | |||
1205 | void perf_session__print_ip(union perf_event *event, | 1205 | void perf_session__print_ip(union perf_event *event, |
1206 | struct perf_sample *sample, | 1206 | struct perf_sample *sample, |
1207 | struct perf_session *session, | 1207 | struct perf_session *session, |
1208 | int print_sym) | 1208 | int print_sym, int print_dso) |
1209 | { | 1209 | { |
1210 | struct addr_location al; | 1210 | struct addr_location al; |
1211 | const char *symname, *dsoname; | 1211 | const char *symname, *dsoname; |
@@ -1241,12 +1241,15 @@ void perf_session__print_ip(union perf_event *event, | |||
1241 | else | 1241 | else |
1242 | symname = ""; | 1242 | symname = ""; |
1243 | 1243 | ||
1244 | printf(" %s", symname); | ||
1245 | } | ||
1246 | if (print_dso) { | ||
1244 | if (node->map && node->map->dso && node->map->dso->name) | 1247 | if (node->map && node->map->dso && node->map->dso->name) |
1245 | dsoname = node->map->dso->name; | 1248 | dsoname = node->map->dso->name; |
1246 | else | 1249 | else |
1247 | dsoname = ""; | 1250 | dsoname = ""; |
1248 | 1251 | ||
1249 | printf(" %s (%s)", symname, dsoname); | 1252 | printf(" (%s)", dsoname); |
1250 | } | 1253 | } |
1251 | printf("\n"); | 1254 | printf("\n"); |
1252 | 1255 | ||
@@ -1261,12 +1264,16 @@ void perf_session__print_ip(union perf_event *event, | |||
1261 | else | 1264 | else |
1262 | symname = ""; | 1265 | symname = ""; |
1263 | 1266 | ||
1267 | printf(" %s", symname); | ||
1268 | } | ||
1269 | |||
1270 | if (print_dso) { | ||
1264 | if (al.map && al.map->dso && al.map->dso->name) | 1271 | if (al.map && al.map->dso && al.map->dso->name) |
1265 | dsoname = al.map->dso->name; | 1272 | dsoname = al.map->dso->name; |
1266 | else | 1273 | else |
1267 | dsoname = ""; | 1274 | dsoname = ""; |
1268 | 1275 | ||
1269 | printf(" %s (%s)", symname, dsoname); | 1276 | printf(" (%s)", dsoname); |
1270 | } | 1277 | } |
1271 | } | 1278 | } |
1272 | } | 1279 | } |
diff --git a/tools/perf/util/session.h b/tools/perf/util/session.h index d76af0f975d3..de4178d7bb7b 100644 --- a/tools/perf/util/session.h +++ b/tools/perf/util/session.h | |||
@@ -170,6 +170,6 @@ struct perf_evsel *perf_session__find_first_evtype(struct perf_session *session, | |||
170 | void perf_session__print_ip(union perf_event *event, | 170 | void perf_session__print_ip(union perf_event *event, |
171 | struct perf_sample *sample, | 171 | struct perf_sample *sample, |
172 | struct perf_session *session, | 172 | struct perf_session *session, |
173 | int print_sym); | 173 | int print_sym, int print_dso); |
174 | 174 | ||
175 | #endif /* __PERF_SESSION_H */ | 175 | #endif /* __PERF_SESSION_H */ |