| 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 | } |