 07100877ea
			
		
	
	
	07100877ea
	
	
	
		
			
			Older kernels (e.g., RHEL6) do system call tracing via the
syscalls:sys_{enter,exit} tracepoints rather than using raw_syscalls:*.
Update perf python and perl scripts to fallback to syscalls:* when
raw_syscalls:* isn't available.
Signed-off-by: Daniel Bristot de Oliveira <bristot@redhat.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Luis Claudio R. Goncalves <lgoncalv@redhat.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/5a6c64081a3375bc3bc66351b14559678ef4d71e.1402507908.git.bristot@redhat.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
	
			
		
			
				
	
	
		
			47 lines
		
	
	
	
		
			1.1 KiB
			
		
	
	
	
		
			Raku
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
	
		
			1.1 KiB
			
		
	
	
	
		
			Raku
		
	
	
	
	
	
| # failed system call counts
 | |
| # (c) 2010, Tom Zanussi <tzanussi@gmail.com>
 | |
| # Licensed under the terms of the GNU GPL License version 2
 | |
| #
 | |
| # Displays system-wide failed system call totals
 | |
| # If a [comm] arg is specified, only syscalls called by [comm] are displayed.
 | |
| 
 | |
| use lib "$ENV{'PERF_EXEC_PATH'}/scripts/perl/Perf-Trace-Util/lib";
 | |
| use lib "./Perf-Trace-Util/lib";
 | |
| use Perf::Trace::Core;
 | |
| use Perf::Trace::Context;
 | |
| use Perf::Trace::Util;
 | |
| 
 | |
| my $for_comm = shift;
 | |
| 
 | |
| my %failed_syscalls;
 | |
| 
 | |
| sub raw_syscalls::sys_exit
 | |
| {
 | |
| 	my ($event_name, $context, $common_cpu, $common_secs, $common_nsecs,
 | |
| 	    $common_pid, $common_comm,
 | |
| 	    $id, $ret) = @_;
 | |
| 
 | |
| 	if ($ret < 0) {
 | |
| 	    $failed_syscalls{$common_comm}++;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| sub syscalls::sys_exit
 | |
| {
 | |
| 	raw_syscalls::sys_exit(@_)
 | |
| }
 | |
| 
 | |
| sub trace_end
 | |
| {
 | |
|     printf("\nfailed syscalls by comm:\n\n");
 | |
| 
 | |
|     printf("%-20s  %10s\n", "comm", "# errors");
 | |
|     printf("%-20s  %6s  %10s\n", "--------------------", "----------");
 | |
| 
 | |
|     foreach my $comm (sort {$failed_syscalls{$b} <=> $failed_syscalls{$a}}
 | |
| 		      keys %failed_syscalls) {
 | |
| 	next if ($for_comm && $comm ne $for_comm);
 | |
| 
 | |
| 	printf("%-20s  %10s\n", $comm, $failed_syscalls{$comm});
 | |
|     }
 | |
| }
 |