~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/scripts/bloat-o-meter

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /scripts/bloat-o-meter (Architecture i386) and /scripts/bloat-o-meter (Architecture alpha)


  1 #!/usr/bin/env python3                              1 #!/usr/bin/env python3
  2 #                                                   2 #
  3 # Copyright 2004 Matt Mackall <mpm@selenic.com>      3 # Copyright 2004 Matt Mackall <mpm@selenic.com>
  4 #                                                   4 #
  5 # inspired by perl Bloat-O-Meter (c) 1997 by A      5 # inspired by perl Bloat-O-Meter (c) 1997 by Andi Kleen
  6 #                                                   6 #
  7 # This software may be used and distributed ac      7 # This software may be used and distributed according to the terms
  8 # of the GNU General Public License, incorpora      8 # of the GNU General Public License, incorporated herein by reference.
  9                                                     9 
 10 import sys, os, re, argparse                       10 import sys, os, re, argparse
 11 from signal import signal, SIGPIPE, SIG_DFL        11 from signal import signal, SIGPIPE, SIG_DFL
 12                                                    12 
 13 signal(SIGPIPE, SIG_DFL)                           13 signal(SIGPIPE, SIG_DFL)
 14                                                    14 
 15 parser = argparse.ArgumentParser(description="     15 parser = argparse.ArgumentParser(description="Simple script used to compare the symbol sizes of 2 object files")
 16 group = parser.add_mutually_exclusive_group()      16 group = parser.add_mutually_exclusive_group()
 17 group.add_argument('-c', help='categorize outp     17 group.add_argument('-c', help='categorize output based on symbol type', action='store_true')
 18 group.add_argument('-d', help='Show delta of D     18 group.add_argument('-d', help='Show delta of Data Section', action='store_true')
 19 group.add_argument('-t', help='Show delta of t     19 group.add_argument('-t', help='Show delta of text Section', action='store_true')
 20 parser.add_argument('-p', dest='prefix', help=     20 parser.add_argument('-p', dest='prefix', help='Arch prefix for the tool being used. Useful in cross build scenarios')
 21 parser.add_argument('file1', help='First file      21 parser.add_argument('file1', help='First file to compare')
 22 parser.add_argument('file2', help='Second file     22 parser.add_argument('file2', help='Second file to compare')
 23                                                    23 
 24 args = parser.parse_args()                         24 args = parser.parse_args()
 25                                                    25 
 26 re_NUMBER = re.compile(r'\.[0-9]+')                26 re_NUMBER = re.compile(r'\.[0-9]+')
 27                                                    27 
 28 def getsizes(file, format):                        28 def getsizes(file, format):
 29     sym = {}                                       29     sym = {}
 30     nm = "nm"                                      30     nm = "nm"
 31     if args.prefix:                                31     if args.prefix:
 32         nm = "{}nm".format(args.prefix)            32         nm = "{}nm".format(args.prefix)
 33                                                    33 
 34     with os.popen("{} --size-sort {}".format(n     34     with os.popen("{} --size-sort {}".format(nm, file)) as f:
 35         for line in f:                             35         for line in f:
 36             if line.startswith("\n") or ":" in     36             if line.startswith("\n") or ":" in line:
 37                 continue                           37                 continue
 38             size, type, name = line.split()        38             size, type, name = line.split()
 39             if type in format:                     39             if type in format:
 40                 # strip generated symbols          40                 # strip generated symbols
 41                 if name.startswith("__mod_"):      41                 if name.startswith("__mod_"): continue
 42                 if name.startswith("__se_sys")     42                 if name.startswith("__se_sys"): continue
 43                 if name.startswith("__se_compa     43                 if name.startswith("__se_compat_sys"): continue
 44                 if name.startswith("__addressa     44                 if name.startswith("__addressable_"): continue
 45                 if name == "linux_banner": con     45                 if name == "linux_banner": continue
 46                 if name == "vermagic": continu     46                 if name == "vermagic": continue
 47                 # statics and some other optim     47                 # statics and some other optimizations adds random .NUMBER
 48                 name = re_NUMBER.sub('', name)     48                 name = re_NUMBER.sub('', name)
 49                 sym[name] = sym.get(name, 0) +     49                 sym[name] = sym.get(name, 0) + int(size, 16)
 50     return sym                                     50     return sym
 51                                                    51 
 52 def calc(oldfile, newfile, format):                52 def calc(oldfile, newfile, format):
 53     old = getsizes(oldfile, format)                53     old = getsizes(oldfile, format)
 54     new = getsizes(newfile, format)                54     new = getsizes(newfile, format)
 55     grow, shrink, add, remove, up, down = 0, 0     55     grow, shrink, add, remove, up, down = 0, 0, 0, 0, 0, 0
 56     delta, common = [], {}                         56     delta, common = [], {}
 57     otot, ntot = 0, 0                              57     otot, ntot = 0, 0
 58                                                    58 
 59     for a in old:                                  59     for a in old:
 60         if a in new:                               60         if a in new:
 61             common[a] = 1                          61             common[a] = 1
 62                                                    62 
 63     for name in old:                               63     for name in old:
 64         otot += old[name]                          64         otot += old[name]
 65         if name not in common:                     65         if name not in common:
 66             remove += 1                            66             remove += 1
 67             down += old[name]                      67             down += old[name]
 68             delta.append((-old[name], name))       68             delta.append((-old[name], name))
 69                                                    69 
 70     for name in new:                               70     for name in new:
 71         ntot += new[name]                          71         ntot += new[name]
 72         if name not in common:                     72         if name not in common:
 73             add += 1                               73             add += 1
 74             up += new[name]                        74             up += new[name]
 75             delta.append((new[name], name))        75             delta.append((new[name], name))
 76                                                    76 
 77     for name in common:                            77     for name in common:
 78         d = new.get(name, 0) - old.get(name, 0     78         d = new.get(name, 0) - old.get(name, 0)
 79         if d>0: grow, up = grow+1, up+d            79         if d>0: grow, up = grow+1, up+d
 80         if d<0: shrink, down = shrink+1, down-     80         if d<0: shrink, down = shrink+1, down-d
 81         delta.append((d, name))                    81         delta.append((d, name))
 82                                                    82 
 83     delta.sort(reverse=True)                       83     delta.sort(reverse=True)
 84     return grow, shrink, add, remove, up, down     84     return grow, shrink, add, remove, up, down, delta, old, new, otot, ntot
 85                                                    85 
 86 def print_result(symboltype, symbolformat):        86 def print_result(symboltype, symbolformat):
 87     grow, shrink, add, remove, up, down, delta     87     grow, shrink, add, remove, up, down, delta, old, new, otot, ntot = \
 88     calc(args.file1, args.file2, symbolformat)     88     calc(args.file1, args.file2, symbolformat)
 89                                                    89 
 90     print("add/remove: %s/%s grow/shrink: %s/%     90     print("add/remove: %s/%s grow/shrink: %s/%s up/down: %s/%s (%s)" % \
 91           (add, remove, grow, shrink, up, -dow     91           (add, remove, grow, shrink, up, -down, up-down))
 92     print("%-40s %7s %7s %+7s" % (symboltype,      92     print("%-40s %7s %7s %+7s" % (symboltype, "old", "new", "delta"))
 93     for d, n in delta:                             93     for d, n in delta:
 94         if d: print("%-40s %7s %7s %+7d" % (n,     94         if d: print("%-40s %7s %7s %+7d" % (n, old.get(n,"-"), new.get(n,"-"), d))
 95                                                    95 
 96     if otot:                                       96     if otot:
 97         percent = (ntot - otot) * 100.0 / otot     97         percent = (ntot - otot) * 100.0 / otot
 98     else:                                          98     else:
 99         percent = 0                                99         percent = 0
100     print("Total: Before=%d, After=%d, chg %+.    100     print("Total: Before=%d, After=%d, chg %+.2f%%" % (otot, ntot, percent))
101                                                   101 
102 if args.c:                                        102 if args.c:
103     print_result("Function", "tTwW")              103     print_result("Function", "tTwW")
104     print_result("Data", "dDbBvV")                104     print_result("Data", "dDbBvV")
105     print_result("RO Data", "rR")                 105     print_result("RO Data", "rR")
106 elif args.d:                                      106 elif args.d:
107     print_result("Data", "dDbBrRvV")              107     print_result("Data", "dDbBrRvV")
108 elif args.t:                                      108 elif args.t:
109     print_result("Function", "tTwW")              109     print_result("Function", "tTwW")
110 else:                                             110 else:
111     print_result("Function", "tTdDbBrRvVwW")      111     print_result("Function", "tTdDbBrRvVwW")
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php