Tom Zanussi | 4d161f0 | 2010-01-27 02:27:58 -0600 | [diff] [blame] | 1 | # failed system call counts |
| 2 | # (c) 2010, Tom Zanussi <tzanussi@gmail.com> |
| 3 | # Licensed under the terms of the GNU GPL License version 2 |
| 4 | # |
| 5 | # Displays system-wide failed system call totals |
| 6 | # If a [comm] arg is specified, only syscalls called by [comm] are displayed. |
| 7 | |
| 8 | use lib "$ENV{'PERF_EXEC_PATH'}/scripts/perl/Perf-Trace-Util/lib"; |
| 9 | use lib "./Perf-Trace-Util/lib"; |
| 10 | use Perf::Trace::Core; |
| 11 | use Perf::Trace::Context; |
| 12 | use Perf::Trace::Util; |
| 13 | |
Tom Zanussi | c3f5fd2 | 2010-05-09 23:46:52 -0500 | [diff] [blame] | 14 | my $for_comm = shift; |
| 15 | |
Tom Zanussi | 4d161f0 | 2010-01-27 02:27:58 -0600 | [diff] [blame] | 16 | my %failed_syscalls; |
| 17 | |
| 18 | sub raw_syscalls::sys_exit |
| 19 | { |
| 20 | my ($event_name, $context, $common_cpu, $common_secs, $common_nsecs, |
| 21 | $common_pid, $common_comm, |
| 22 | $id, $ret) = @_; |
| 23 | |
| 24 | if ($ret < 0) { |
| 25 | $failed_syscalls{$common_comm}++; |
| 26 | } |
| 27 | } |
| 28 | |
| 29 | sub trace_end |
| 30 | { |
| 31 | printf("\nfailed syscalls by comm:\n\n"); |
| 32 | |
| 33 | printf("%-20s %10s\n", "comm", "# errors"); |
| 34 | printf("%-20s %6s %10s\n", "--------------------", "----------"); |
| 35 | |
| 36 | foreach my $comm (sort {$failed_syscalls{$b} <=> $failed_syscalls{$a}} |
| 37 | keys %failed_syscalls) { |
Tom Zanussi | c3f5fd2 | 2010-05-09 23:46:52 -0500 | [diff] [blame] | 38 | next if ($for_comm && $comm ne $for_comm); |
| 39 | |
| 40 | printf("%-20s %10s\n", $comm, $failed_syscalls{$comm}); |
Tom Zanussi | 4d161f0 | 2010-01-27 02:27:58 -0600 | [diff] [blame] | 41 | } |
| 42 | } |