diff options
author | Steve French <sfrench@us.ibm.com> | 2006-01-12 17:47:08 -0500 |
---|---|---|
committer | Steve French <sfrench@us.ibm.com> | 2006-01-12 17:47:08 -0500 |
commit | 94bc2be31a01a3055ec94176e595dfe208e92d3b (patch) | |
tree | ebfbe81c6718a6390bfa1b99c6d228237d818576 /scripts/bloat-o-meter | |
parent | c32a0b689cb9cc160cfcd19735bbf50bb70c6ef4 (diff) | |
parent | 58cba4650a7a414eabd2b40cc9d8e45fcdf192d9 (diff) |
Merge with /pub/scm/linux/kernel/git/torvalds/linux-2.6.git
Signed-off-by: Steve French <sfrench@us.ibm.com>
Diffstat (limited to 'scripts/bloat-o-meter')
-rw-r--r-- | scripts/bloat-o-meter | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/scripts/bloat-o-meter b/scripts/bloat-o-meter new file mode 100644 index 000000000000..75f21d843c1d --- /dev/null +++ b/scripts/bloat-o-meter | |||
@@ -0,0 +1,58 @@ | |||
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 | sym[name] = int(size, 16) | ||
22 | return sym | ||
23 | |||
24 | old = getsizes(sys.argv[1]) | ||
25 | new = getsizes(sys.argv[2]) | ||
26 | grow, shrink, add, remove, up, down = 0, 0, 0, 0, 0, 0 | ||
27 | delta, common = [], {} | ||
28 | |||
29 | for a in old: | ||
30 | if a in new: | ||
31 | common[a] = 1 | ||
32 | |||
33 | for name in old: | ||
34 | if name not in common: | ||
35 | remove += 1 | ||
36 | down += old[name] | ||
37 | delta.append((-old[name], name)) | ||
38 | |||
39 | for name in new: | ||
40 | if name not in common: | ||
41 | add += 1 | ||
42 | up += new[name] | ||
43 | delta.append((new[name], name)) | ||
44 | |||
45 | for name in common: | ||
46 | d = new.get(name, 0) - old.get(name, 0) | ||
47 | if d>0: grow, up = grow+1, up+d | ||
48 | if d<0: shrink, down = shrink+1, down-d | ||
49 | delta.append((d, name)) | ||
50 | |||
51 | delta.sort() | ||
52 | delta.reverse() | ||
53 | |||
54 | print "add/remove: %s/%s grow/shrink: %s/%s up/down: %s/%s (%s)" % \ | ||
55 | (add, remove, grow, shrink, up, -down, up-down) | ||
56 | print "%-40s %7s %7s %+7s" % ("function", "old", "new", "delta") | ||
57 | for d, n in delta: | ||
58 | if d: print "%-40s %7s %7s %+7d" % (n, old.get(n,"-"), new.get(n,"-"), d) | ||