#!/usr/bin/perl | |
# Parse a massif.out.xxx file and output peak total memory usage | |
use warnings; | |
use strict; | |
use utf8; | |
use open qw(:std utf8); | |
die unless @ARGV == 1; | |
my @snaps; | |
open my $fh, '<', $ARGV[0] or die; | |
{ local $/ = 'snapshot='; @snaps = <$fh>; } | |
close $fh or die; | |
my ($max, $max_heap, $max_he, $max_stack) = (0, 0, 0, 0); | |
for (@snaps) | |
{ | |
my ($heap, $heap_extra, $stack) = m{ | |
mem_heap_B=(\d+)\n | |
mem_heap_extra_B=(\d+)\n | |
mem_stacks_B=(\d+) | |
}xm; | |
next unless defined $heap; | |
my $total = $heap + $heap_extra + $stack; | |
if( $total > $max ) { | |
($max, $max_heap, $max_he, $max_stack) = ($total, $heap, $heap_extra, $stack); | |
} | |
} | |
printf "$max (heap $max_heap+$max_he, stack $max_stack)\n"; |