Blame OLD/leak

Packit 6f02de
#!/usr/local/bin/perl
Packit 6f02de
Packit 6f02de
# leak < <lsof_leak_debug_output>
Packit 6f02de
Packit 6f02de
while (<>) {
Packit 6f02de
    if (!/^MEM[afr]/) { next; }
Packit 6f02de
    chop;
Packit 6f02de
    if (/^MEMa ([^ ]*) (.*)/) {
Packit 6f02de
	$new = $1; $loc = $2;
Packit 6f02de
	if (defined($mem{$new})) {
Packit 6f02de
	    print "ERROR: $new already allocated;\n";
Packit 6f02de
	    print "  OLD: $mem{$new}\n";
Packit 6f02de
	    print "  NEW: $_\n";
Packit 6f02de
	} else {$mem{$new} = $loc; }
Packit 6f02de
	next;
Packit 6f02de
    } elsif (/^MEMf ([^ ]*) (.*)/) {
Packit 6f02de
	$old = $1; $loc = $2;
Packit 6f02de
	if (!defined($mem{$old})) {
Packit 6f02de
	    print "ERROR: $old not allocated: $_\n";
Packit 6f02de
	} else { undef($mem{$old}); }
Packit 6f02de
	next;
Packit 6f02de
    } elsif (/^MEMr ([^ ]*) ([^ ]*) (.*)/) {
Packit 6f02de
	$old = $1; $new = $2; $loc = $3;
Packit 6f02de
	if (!defined($mem{$old})) {
Packit 6f02de
	    print "ERROR: $old not allocated: $_\n";
Packit 6f02de
	} else { undef($mem{$old}); }
Packit 6f02de
	if (defined($mem{$new})) {
Packit 6f02de
	    print "ERROR: $new already allocated;\n";
Packit 6f02de
	    print "  OLD: $mem{$new}\n";
Packit 6f02de
	    print "  NEW: $_\n";
Packit 6f02de
	} else {$mem{$new} = $loc; }
Packit 6f02de
	next;
Packit 6f02de
    } else { print "ERROR: MEM what? $_\n"; }
Packit 6f02de
}
Packit 6f02de
foreach $addr (sort keys(%mem)) {
Packit 6f02de
    if (defined($mem{$addr})) {
Packit 6f02de
	if (($mem{$addr} =~ /^rnch.c/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^print.c:14[18]/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^print.c:323/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^print.c:1135/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^print.c:207/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^print.c:219/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^print.c:335/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^print.c:261/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^print.c:1076/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^proc.c:191/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^main.c:581/)) { next; }
Packit 6f02de
	if (($mem{$addr} =~ /^rvfs.c:68/)) { next; }
Packit 6f02de
	print "IN USE $addr: $mem{$addr}\n";
Packit 6f02de
    }
Packit 6f02de
}