
# Extract the context switching information from lmbench result files.
# Usage: getctx file file....
#
# Hacked into existence by Larry McVoy (lm@sun.com now lm@sgi.com).
# Copyright (c) 1994 Larry McVoy.  GPLed software.
# $Id: getctx,v 1.3 1994/11/26 01:05:18 lm Exp $
eval "exec perl -Ss $0 $*"
	if 0;

foreach $file (@ARGV) {
	warn "$file\n";
	open(FD, $file);
	while (<FD>) {
		chop;
		if (/^\[lmbench/) {
			split;
			if ($_[3] eq "SunOS") {
				$_[3] .= "-$_[5]";
			}
			$uname = "@_";
		}
		if (/Mhz/) {
			$mhz = $_;
		}
		if (/^.size=/) {
			s/size/Process size/;
			s/ ovr/\toverhead/;
			@info = &getinfo($uname, $mhz);
			($f = $file) =~ s|.*/||;
			open(OUT, ">tmp/ctx.$f");
			print OUT "\"%X Processes \n\"%Y Time in microseconds\n";
			print OUT
			    "\"%T Context switches for $info[3] $info[$#info]Mhz\n";
			print OUT "$_\n";
			while (<FD>) {
				last if /^Null/ || /^Pipe/ || /^Memor/;
				next if /\$Id/;
				s/ ovr/\toverhead/;
				s/size/Process size/;
			    	print OUT;
			}
			close(OUT);
			last;
		}
	}
}

# Try and create sensible names from uname -a output
sub getinfo
{
	local(@info);
	local($name);
	local($mhz) = sprintf("%.0f", $_[1]);

	@info = split(/\s+/, $_[0]);
	$name = pop(@info);
	chop($name);
	if ($name eq "mips") {
		$name = "$info[$#info]@$mhz";
	} elsif ($_[0] =~ /HP-UX/) {
		$name = "$info[7]@$mhz";
	} elsif ($_[0] =~ /SunOS/) {
		$name = "$info[7]@$mhz";
	} else {
		$name .= "@$mhz";
	}
	push(@info, $name);
	@info;
}
