xref: /openbmc/linux/scripts/bloat-o-meter (revision 21cf6e584ce35b79374581e6344dd7c74f8b4a2b)
1d960600dSMatt Mackall#!/usr/bin/python
2d960600dSMatt Mackall#
3d960600dSMatt Mackall# Copyright 2004 Matt Mackall <mpm@selenic.com>
4d960600dSMatt Mackall#
5d960600dSMatt Mackall# inspired by perl Bloat-O-Meter (c) 1997 by Andi Kleen
6d960600dSMatt Mackall#
7d960600dSMatt Mackall# This software may be used and distributed according to the terms
8d960600dSMatt Mackall# of the GNU General Public License, incorporated herein by reference.
9d960600dSMatt Mackall
10d960600dSMatt Mackallimport sys, os, re
11d960600dSMatt Mackall
12d960600dSMatt Mackallif len(sys.argv) != 3:
13d960600dSMatt Mackall    sys.stderr.write("usage: %s file1 file2\n" % sys.argv[0])
14d960600dSMatt Mackall    sys.exit(-1)
15d960600dSMatt Mackall
16d960600dSMatt Mackalldef getsizes(file):
17d960600dSMatt Mackall    sym = {}
18d960600dSMatt Mackall    for l in os.popen("nm --size-sort " + file).readlines():
19d960600dSMatt Mackall        size, type, name = l[:-1].split()
20c50e3f51SJean Delvare        if type in "tTdDbBrR":
21c50e3f51SJean Delvare            # strip generated symbols
22c50e3f51SJean Delvare            if name[:6] == "__mod_": continue
23*21cf6e58SAndi Kleen            # statics and some other optimizations adds random .NUMBER
24*21cf6e58SAndi Kleen            name = re.sub(r'\.[0-9]+', '', name)
2551849738SRob Landley            sym[name] = sym.get(name, 0) + int(size, 16)
26d960600dSMatt Mackall    return sym
27d960600dSMatt Mackall
28d960600dSMatt Mackallold = getsizes(sys.argv[1])
29d960600dSMatt Mackallnew = getsizes(sys.argv[2])
30d960600dSMatt Mackallgrow, shrink, add, remove, up, down = 0, 0, 0, 0, 0, 0
31d960600dSMatt Mackalldelta, common = [], {}
32d960600dSMatt Mackall
33d960600dSMatt Mackallfor a in old:
34d960600dSMatt Mackall    if a in new:
35d960600dSMatt Mackall        common[a] = 1
36d960600dSMatt Mackall
37d960600dSMatt Mackallfor name in old:
38d960600dSMatt Mackall    if name not in common:
39d960600dSMatt Mackall        remove += 1
40d960600dSMatt Mackall        down += old[name]
41d960600dSMatt Mackall        delta.append((-old[name], name))
42d960600dSMatt Mackall
43d960600dSMatt Mackallfor name in new:
44d960600dSMatt Mackall    if name not in common:
45d960600dSMatt Mackall        add += 1
46d960600dSMatt Mackall        up += new[name]
47d960600dSMatt Mackall        delta.append((new[name], name))
48d960600dSMatt Mackall
49d960600dSMatt Mackallfor name in common:
50d960600dSMatt Mackall        d = new.get(name, 0) - old.get(name, 0)
51d960600dSMatt Mackall        if d>0: grow, up = grow+1, up+d
52d960600dSMatt Mackall        if d<0: shrink, down = shrink+1, down-d
53d960600dSMatt Mackall        delta.append((d, name))
54d960600dSMatt Mackall
55d960600dSMatt Mackalldelta.sort()
56d960600dSMatt Mackalldelta.reverse()
57d960600dSMatt Mackall
58d960600dSMatt Mackallprint "add/remove: %s/%s grow/shrink: %s/%s up/down: %s/%s (%s)" % \
59d960600dSMatt Mackall      (add, remove, grow, shrink, up, -down, up-down)
60d960600dSMatt Mackallprint "%-40s %7s %7s %+7s" % ("function", "old", "new", "delta")
61d960600dSMatt Mackallfor d, n in delta:
62d960600dSMatt Mackall    if d: print "%-40s %7s %7s %+7d" % (n, old.get(n,"-"), new.get(n,"-"), d)
63