aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorMilian Wolff <milian.wolff@kdab.com>2015-08-06 05:24:29 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2015-08-06 10:29:49 -0400
commit834fd46ddb50953cf3fd9caa3f35485715c62ea3 (patch)
tree035f741efbfd3bba099bb938076284ef1f8ea1d1 /tools
parentb6b6c18fcd9af2a71d7b2cfca0388a928308f963 (diff)
perf trace: Add total time column to summary.
It is cumbersome to manually calculate the total time spent in a given syscall by multiplying the average value with the number of calls. Instead, we now do this directly inside perf trace. Note that this is also done by 'strace', which even adds a column with relative numbers - something we could do in the future. Example: perf trace -s find /some/folder > /dev/null Summary of events: find (19976), 700123 events, 100.0%, 0.000 msec syscall calls total min avg max stddev (msec) (msec) (msec) (msec) (%) --------------- -------- --------- --------- --------- --------- ------ read 4 0.006 0.001 0.002 0.003 27.42% write 8046 9.617 0.001 0.001 0.035 0.56% open 34196 40.384 0.001 0.001 0.071 0.30% close 68375 57.104 0.001 0.001 0.076 0.25% stat 4 0.004 0.001 0.001 0.001 3.14% fstat 34189 27.518 0.001 0.001 0.060 0.34% mmap 13 0.029 0.001 0.002 0.003 10.74% mprotect 6 0.018 0.002 0.003 0.005 17.04% munmap 3 0.014 0.003 0.005 0.006 24.87% brk 87 0.490 0.001 0.006 0.016 6.50% ioctl 3 0.004 0.001 0.001 0.003 36.39% access 1 0.004 0.004 0.004 0.004 0.00% uname 1 0.001 0.001 0.001 0.001 0.00% getdents 68393 143.600 0.001 0.002 0.187 0.95% fchdir 68371 56.980 0.001 0.001 0.111 0.39% arch_prctl 1 0.001 0.001 0.001 0.001 0.00% openat 34184 41.737 0.001 0.001 0.102 0.41% newfstatat 34184 41.180 0.001 0.001 0.064 0.34% Signed-off-by: Milian Wolff <milian.wolff@kdab.com> Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com> LPU-Reference: 1438853069-5902-1-git-send-email-milian.wolff@kdab.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools')
-rw-r--r--tools/perf/builtin-trace.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/tools/perf/builtin-trace.c b/tools/perf/builtin-trace.c
index a47497011c93..a25048c85b76 100644
--- a/tools/perf/builtin-trace.c
+++ b/tools/perf/builtin-trace.c
@@ -2773,9 +2773,9 @@ static size_t thread__dump_stats(struct thread_trace *ttrace,
2773 2773
2774 printed += fprintf(fp, "\n"); 2774 printed += fprintf(fp, "\n");
2775 2775
2776 printed += fprintf(fp, " syscall calls min avg max stddev\n"); 2776 printed += fprintf(fp, " syscall calls total min avg max stddev\n");
2777 printed += fprintf(fp, " (msec) (msec) (msec) (%%)\n"); 2777 printed += fprintf(fp, " (msec) (msec) (msec) (msec) (%%)\n");
2778 printed += fprintf(fp, " --------------- -------- --------- --------- --------- ------\n"); 2778 printed += fprintf(fp, " --------------- -------- --------- --------- --------- --------- ------\n");
2779 2779
2780 /* each int_node is a syscall */ 2780 /* each int_node is a syscall */
2781 while (inode) { 2781 while (inode) {
@@ -2792,8 +2792,8 @@ static size_t thread__dump_stats(struct thread_trace *ttrace,
2792 2792
2793 sc = &trace->syscalls.table[inode->i]; 2793 sc = &trace->syscalls.table[inode->i];
2794 printed += fprintf(fp, " %-15s", sc->name); 2794 printed += fprintf(fp, " %-15s", sc->name);
2795 printed += fprintf(fp, " %8" PRIu64 " %9.3f %9.3f", 2795 printed += fprintf(fp, " %8" PRIu64 " %9.3f %9.3f %9.3f",
2796 n, min, avg); 2796 n, avg * n, min, avg);
2797 printed += fprintf(fp, " %9.3f %9.2f%%\n", max, pct); 2797 printed += fprintf(fp, " %9.3f %9.2f%%\n", max, pct);
2798 } 2798 }
2799 2799