Blame view

scripts/bloat-o-meter 3.36 KB
d960600df   Matt Mackall   [PATCH] tiny: Add...
1
2
3
4
5
6
7
8
9
10
  #!/usr/bin/python
  #
  # Copyright 2004 Matt Mackall <mpm@selenic.com>
  #
  # inspired by perl Bloat-O-Meter (c) 1997 by Andi Kleen
  #
  # This software may be used and distributed according to the terms
  # of the GNU General Public License, incorporated herein by reference.
  
  import sys, os, re
eef06b82f   Alexey Dobriyan   scripts/bloat-o-m...
11
12
13
  from signal import signal, SIGPIPE, SIG_DFL
  
  signal(SIGPIPE, SIG_DFL)
d960600df   Matt Mackall   [PATCH] tiny: Add...
14

192efb7a1   Maninder Singh   bloat-o-meter: pr...
15
16
17
18
19
  if len(sys.argv) < 3:
      sys.stderr.write("usage: %s [option] file1 file2
  " % sys.argv[0])
      sys.stderr.write("The options are:
  ")
61fc47081   Matteo Croce   scripts/bloat-o-m...
20
21
      sys.stderr.write("-c	categorize output based on symbol type
  ")
192efb7a1   Maninder Singh   bloat-o-meter: pr...
22
23
24
25
      sys.stderr.write("-d	Show delta of Data Section
  ")
      sys.stderr.write("-t	Show delta of text Section
  ")
d960600df   Matt Mackall   [PATCH] tiny: Add...
26
      sys.exit(-1)
0d7bbb436   Alexey Dobriyan   scripts/bloat-o-m...
27
  re_NUMBER = re.compile(r'\.[0-9]+')
192efb7a1   Maninder Singh   bloat-o-meter: pr...
28
  def getsizes(file, format):
d960600df   Matt Mackall   [PATCH] tiny: Add...
29
      sym = {}
3af06fd96   Alexey Dobriyan   scripts/bloat-o-m...
30
31
      with os.popen("nm --size-sort " + file) as f:
          for line in f:
1d35b6054   Nikolay Borisov   scripts/bloat-o-m...
32
33
34
              if line.startswith("
  ") or ":" in line:
                  continue
3af06fd96   Alexey Dobriyan   scripts/bloat-o-m...
35
              size, type, name = line.split()
192efb7a1   Maninder Singh   bloat-o-meter: pr...
36
              if type in format:
3af06fd96   Alexey Dobriyan   scripts/bloat-o-m...
37
38
                  # strip generated symbols
                  if name.startswith("__mod_"): continue
e145242ea   Dominik Brodowski   syscalls/core, sy...
39
                  if name.startswith("__se_sys"): continue
5ac9efa3c   Dominik Brodowski   syscalls/core, sy...
40
                  if name.startswith("__se_compat_sys"): continue
e0b2475a3   Rasmus Villemoes   bloat-o-meter: ig...
41
                  if name.startswith("__addressable_"): continue
3af06fd96   Alexey Dobriyan   scripts/bloat-o-m...
42
43
                  if name == "linux_banner": continue
                  # statics and some other optimizations adds random .NUMBER
0d7bbb436   Alexey Dobriyan   scripts/bloat-o-m...
44
                  name = re_NUMBER.sub('', name)
3af06fd96   Alexey Dobriyan   scripts/bloat-o-m...
45
                  sym[name] = sym.get(name, 0) + int(size, 16)
d960600df   Matt Mackall   [PATCH] tiny: Add...
46
      return sym
192efb7a1   Maninder Singh   bloat-o-meter: pr...
47
48
49
50
51
52
  def calc(oldfile, newfile, format):
      old = getsizes(oldfile, format)
      new = getsizes(newfile, format)
      grow, shrink, add, remove, up, down = 0, 0, 0, 0, 0, 0
      delta, common = [], {}
      otot, ntot = 0, 0
d960600df   Matt Mackall   [PATCH] tiny: Add...
53

192efb7a1   Maninder Singh   bloat-o-meter: pr...
54
55
56
      for a in old:
          if a in new:
              common[a] = 1
d960600df   Matt Mackall   [PATCH] tiny: Add...
57

192efb7a1   Maninder Singh   bloat-o-meter: pr...
58
59
60
61
62
63
      for name in old:
          otot += old[name]
          if name not in common:
              remove += 1
              down += old[name]
              delta.append((-old[name], name))
d960600df   Matt Mackall   [PATCH] tiny: Add...
64

192efb7a1   Maninder Singh   bloat-o-meter: pr...
65
66
67
68
69
70
      for name in new:
          ntot += new[name]
          if name not in common:
              add += 1
              up += new[name]
              delta.append((new[name], name))
d960600df   Matt Mackall   [PATCH] tiny: Add...
71

192efb7a1   Maninder Singh   bloat-o-meter: pr...
72
      for name in common:
d960600df   Matt Mackall   [PATCH] tiny: Add...
73
74
75
76
          d = new.get(name, 0) - old.get(name, 0)
          if d>0: grow, up = grow+1, up+d
          if d<0: shrink, down = shrink+1, down-d
          delta.append((d, name))
192efb7a1   Maninder Singh   bloat-o-meter: pr...
77
78
79
      delta.sort()
      delta.reverse()
      return grow, shrink, add, remove, up, down, delta, old, new, otot, ntot
d960600df   Matt Mackall   [PATCH] tiny: Add...
80

192efb7a1   Maninder Singh   bloat-o-meter: pr...
81
82
83
  def print_result(symboltype, symbolformat, argc):
      grow, shrink, add, remove, up, down, delta, old, new, otot, ntot = \
      calc(sys.argv[argc - 1], sys.argv[argc], symbolformat)
b21e91c30   Vineet Gupta   scripts/bloat-o-m...
84

192efb7a1   Maninder Singh   bloat-o-meter: pr...
85
86
87
88
89
      print("add/remove: %s/%s grow/shrink: %s/%s up/down: %s/%s (%s)" % \
            (add, remove, grow, shrink, up, -down, up-down))
      print("%-40s %7s %7s %+7s" % (symboltype, "old", "new", "delta"))
      for d, n in delta:
          if d: print("%-40s %7s %7s %+7d" % (n, old.get(n,"-"), new.get(n,"-"), d))
edbddb83a   Andy Shevchenko   scripts/bloat-o-m...
90
91
92
93
94
      if otot:
          percent = (ntot - otot) * 100.0 / otot
      else:
          percent = 0
      print("Total: Before=%d, After=%d, chg %+.2f%%" % (otot, ntot, percent))
192efb7a1   Maninder Singh   bloat-o-meter: pr...
95
96
97
98
99
100
101
102
103
104
105
  
  if sys.argv[1] == "-c":
      print_result("Function", "tT", 3)
      print_result("Data", "dDbB", 3)
      print_result("RO Data", "rR", 3)
  elif sys.argv[1] == "-d":
      print_result("Data", "dDbBrR", 3)
  elif sys.argv[1] == "-t":
      print_result("Function", "tT", 3)
  else:
      print_result("Function", "tTdDbBrR", 2)