diff options
| author | Rob Landley <rob@landley.net> | 2006-05-07 19:26:53 +0000 |
|---|---|---|
| committer | Rob Landley <rob@landley.net> | 2006-05-07 19:26:53 +0000 |
| commit | f8a808426745ee5f4e5cc76ff1fb9c484c315195 (patch) | |
| tree | 98685847c9ee70e5997466e29db22f8d46b30e36 /scripts | |
| parent | 9fb272a222c8c25dbd99d7c186f668516d6b3ebe (diff) | |
| download | busybox-w32-f8a808426745ee5f4e5cc76ff1fb9c484c315195.tar.gz busybox-w32-f8a808426745ee5f4e5cc76ff1fb9c484c315195.tar.bz2 busybox-w32-f8a808426745ee5f4e5cc76ff1fb9c484c315195.zip | |
Add "make bloatcheck" to run Matt Mackall's bloat-o-meter. Copy an old
busybox_unstripped to busybox_old, build a new version, and "make bloatcheck"
to see a detailed breakdown of the size difference.
Diffstat (limited to 'scripts')
| -rwxr-xr-x | scripts/bloat-o-meter | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/scripts/bloat-o-meter b/scripts/bloat-o-meter new file mode 100755 index 000000000..af42f8402 --- /dev/null +++ b/scripts/bloat-o-meter | |||
| @@ -0,0 +1,60 @@ | |||
| 1 | #!/usr/bin/python | ||
| 2 | # | ||
| 3 | # Copyright 2004 Matt Mackall <mpm@selenic.com> | ||
| 4 | # | ||
| 5 | # inspired by perl Bloat-O-Meter (c) 1997 by Andi Kleen | ||
| 6 | # | ||
| 7 | # This software may be used and distributed according to the terms | ||
| 8 | # of the GNU General Public License, incorporated herein by reference. | ||
| 9 | |||
| 10 | import sys, os, re | ||
| 11 | |||
| 12 | if len(sys.argv) != 3: | ||
| 13 | sys.stderr.write("usage: %s file1 file2\n" % sys.argv[0]) | ||
| 14 | sys.exit(-1) | ||
| 15 | |||
| 16 | def getsizes(file): | ||
| 17 | sym = {} | ||
| 18 | for l in os.popen("nm --size-sort " + file).readlines(): | ||
| 19 | size, type, name = l[:-1].split() | ||
| 20 | if type in "tTdDbB": | ||
| 21 | if name.find(".") != -1: name = "static." + name.split(".")[0] | ||
| 22 | if name in sym: sym[name] += int(size, 16) | ||
| 23 | else :sym[name] = int(size, 16) | ||
| 24 | return sym | ||
| 25 | |||
| 26 | old = getsizes(sys.argv[1]) | ||
| 27 | new = getsizes(sys.argv[2]) | ||
| 28 | grow, shrink, add, remove, up, down = 0, 0, 0, 0, 0, 0 | ||
| 29 | delta, common = [], {} | ||
| 30 | |||
| 31 | for a in old: | ||
| 32 | if a in new: | ||
| 33 | common[a] = 1 | ||
| 34 | |||
| 35 | for name in old: | ||
| 36 | if name not in common: | ||
| 37 | remove += 1 | ||
| 38 | down += old[name] | ||
| 39 | delta.append((-old[name], name)) | ||
| 40 | |||
| 41 | for name in new: | ||
| 42 | if name not in common: | ||
| 43 | add += 1 | ||
| 44 | up += new[name] | ||
| 45 | delta.append((new[name], name)) | ||
| 46 | |||
| 47 | for name in common: | ||
| 48 | d = new.get(name, 0) - old.get(name, 0) | ||
| 49 | if d>0: grow, up = grow+1, up+d | ||
| 50 | if d<0: shrink, down = shrink+1, down-d | ||
| 51 | delta.append((d, name)) | ||
| 52 | |||
| 53 | delta.sort() | ||
| 54 | delta.reverse() | ||
| 55 | |||
| 56 | print "add/remove: %s/%s grow/shrink: %s/%s up/down: %s/%s (%s)" % \ | ||
| 57 | (add, remove, grow, shrink, up, -down, up-down) | ||
| 58 | print "%-40s %7s %7s %+7s" % ("function", "old", "new", "delta") | ||
| 59 | for d, n in delta: | ||
| 60 | if d: print "%-40s %7s %7s %+7d" % (n, old.get(n,"-"), new.get(n,"-"), d) | ||
