Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934803AbdIYKwF (ORCPT ); Mon, 25 Sep 2017 06:52:05 -0400 Received: from mailout1.samsung.com ([203.254.224.24]:31243 "EHLO mailout1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934668AbdIYKwD (ORCPT ); Mon, 25 Sep 2017 06:52:03 -0400 X-AuditID: b6c32a49-99fff7000000104d-6b-59c8dfd08267 From: Maninder Singh To: adobriyan@gmail.com, akpm@linux-foundation.org Cc: linux-kernel@vger.kernel.org, pankaj.m@samsung.com, a.sahrawat@samsung.com, lalit.mohan@samsung.com, Maninder Singh , Vaneet Narang Subject: [PATCH 1/1] bloat-o-meter: provide 3 different arguments for data, function and All Date: Mon, 25 Sep 2017 16:15:13 +0530 Message-Id: <1506336313-27187-1-git-send-email-maninder1.s@samsung.com> X-Mailer: git-send-email 1.9.1 X-Brightmail-Tracker: H4sIAAAAAAAAA0VSbUhTYRjt3b2bd+bqsgrfpERu+UPBtbu2eRdZaZLLLBZFuMTsom/bym2y u5kFlWYNM0pXo0zXNAwxNY00Sy0EJad9mGFEK1pJXxRWpGI/jGjbLfp3zvOc83zxEJjUL4wh TBY7slnYQkoUiXcPJiQmjb0Z1st7yxjmaR9iLpZlMp6ONhFT1ahmxns9Imaw3okzgclbAmZg 5DLYQGh7al9HaIdr5nDt2a4WoJ2+GavDd6O1RsQWIFscsuRbC0wWQwq1ZUfexjyVWk4n0Rom mYqzsGaUQqVn6ZI2mQqDM1BxxWyhIxjSsRxHrVq31mZ12FGc0crZU6gcmlbIaHmyTKFQyJSq 3DUKVVCyFxk7qr/iRe7VJa6+elAKplZUAjEBSSV81PMDqwSRhJTsA7Buuk3AkykAv53rF/Fk FkD3vU/CSkCELd6h7Xz8HoAPuk/iPJkB0PfuMR6qKyJlsKX3bhgvJhWwwl8XLouFelx/PgFC iUXkHljhbQ9jnIyHj880CEJYQmZAp9sP+AFj4cjQeWHIDMkyEWw83vg3kQ5r2meFPF4Ev/i6 IngcAz9XOSN4w2kAmx6+F/CkBsDmQADjVevh2xf3I0ILYWQC7OhdxYdT4FT/ZFiCkQvgmbmQ N7SzBFY4pbwkHp7w3/jbVwt/+jtFPE6FF293hjeWkrnww8g1QTVYXvu/QQMALWApKuLMBsSp imgLOijjWDPnsBhk+VbzTRB+q8TNd0DtaNYAIAlARUmyf/v0UiFbzB0yDwBIYNRiyYxvWC+V FLCHDiObNc/mKETcAFAFL+jCYpbkW4NParHn0UqNXKlWJ9NyuUZJRUuGehx6KWlg7egAQkXI 9s8nIMQxpeCIC6QPRmtLZL59+1PnR1+99Ky8fMyfxnpEs97olt8PTpf3fxB36+bliL2jtTvb H7a53K1mHToV9evjpCB1YWOJETSZrhx5daFZI1i5jQATx5y7Xj3JbP3iL14vq8hwj5emfezb ejBgj9zimR/bMPFdvOyu9qXp5Wi3bfdc9tFmCueMLJ2I2Tj2D47VtHdsAwAA X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFmpnluLIzCtJLcpLzFFi42LZdlhJTvfC/RORBi+vKltc3J1qMb3Ry2LO +jVsFv2LzSwu75rDZnF4fhuLxb03W5ksDp2cy+jA4bFz1l12jxMzfrN49G1ZxejxeZNcAEsU l01Kak5mWWqRvl0CV8b6CW9ZCqYYV0zcPZ+xgfGTchcjB4eEgInEvGOBXYycHEICuxklGg6q gdgSAtISP/+9Z4GwhSVW/nvODlHziVHi5JkSEJtNQE9i1a49YDUiQGNaT58GquHiYBY4yCix q3MzM0hCWCBGYufDb2A2i4CqxNneBUwgNq+Au0TblJuMEAvkJE4em8w6gZFnASPDKkbJ1ILi 3PTcYsMCw7zUcr3ixNzi0rx0veT83E2M4ODR0tzBeHlJ/CFGAQ5GJR7eiH/HI4VYE8uKK3MP MUpwMCuJ8H45fiJSiDclsbIqtSg/vqg0J7X4EKM0B4uSOO/TvGORQgLpiSWp2ampBalFMFkm Dk6pBsbGlKS1SfU8/HfCJ53eftRSI9Rh8YmU4ydq/PdzPFqbP8NJPVP6u/ONoJ+efuEhHNe1 T/X+nxXczXbTNKjRz05vlUzgqvuJbDbHcn3jQu6/69hl57a4tH36V00Fbs6Iu96Wm1evLw/o Sfi2OGf75DUnHxebijomOztU5my+vCbdZdGCD5Z7TiuxFGckGmoxFxUnAgCtDI1iGgIAAA== X-CMS-MailID: 20170925105200epcas5p317b731f1beee4f95132f335b622ceec3 X-Msg-Generator: CA X-Sender-IP: 182.195.40.13 X-Local-Sender: =?UTF-8?B?TWFuaW5kZXIgU2luZ2gbU1JJLURlbGhpLVBsYXRmb3JtIFMv?= =?UTF-8?B?VyAxIFRlYW0b7IK87ISx7KCE7J6QG0xlYWQgRW5naW5lZXI=?= X-Global-Sender: =?UTF-8?B?TWFuaW5kZXIgU2luZ2gbU1JJLURlbGhpLVBsYXRmb3JtIFMv?= =?UTF-8?B?VyAxIFRlYW0bU2Ftc3VuZ8KgRWxlY3Ryb25pY3PCoBtMZWFkIEVuZ2luZWVy?= X-Sender-Code: =?UTF-8?B?QzEwG1NXQUhRG0MxMElEMDJJRDAyODExNQ==?= Content-Type: text/plain; charset="utf-8" X-MTR: 20170925105200epcas5p317b731f1beee4f95132f335b622ceec3 CMS-TYPE: 105P DLP-Filter: Pass X-CFilter-Loop: Reflected X-CMS-RootMailID: 20170925105200epcas5p317b731f1beee4f95132f335b622ceec3 X-RootMTR: 20170925105200epcas5p317b731f1beee4f95132f335b622ceec3 References: Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 6364 Lines: 182 This patch provides 3 new arguments for bloat-o-meter 1) -c -> for all (showing function and data differently) 2) -d -> data 3) -t -> function output:- ./scripts/bloat-o-meter -c "file1" "file2" add/remove: 0/0 grow/shrink: 0/1 up/down: 0/-152 (-152) Function old new delta main 412 260 -152 Total: Before=548, After=396, chg -27.74% ########################################################## add/remove: 1/0 grow/shrink: 1/0 up/down: 84/0 (84) Data old new delta arr - 64 +64 backtrace 60 80 +20 Total: Before=109, After=193, chg +77.06% ########################################################## add/remove: 0/1 grow/shrink: 0/0 up/down: 0/-64 (-64) RO Data old new delta arr 64 - -64 Total: Before=68, After=4, chg -94.12% Signed-off-by: Vaneet Narang Signed-off-by: Maninder Singh --- scripts/bloat-o-meter | 132 ++++++++++++++++++++++++++++++-------------------- 1 file changed, 80 insertions(+), 52 deletions(-) diff --git a/scripts/bloat-o-meter b/scripts/bloat-o-meter index a276771..33d6f8f 100755 --- a/scripts/bloat-o-meter +++ b/scripts/bloat-o-meter @@ -12,66 +12,94 @@ from signal import signal, SIGPIPE, SIG_DFL signal(SIGPIPE, SIG_DFL) -if len(sys.argv) != 3: - sys.stderr.write("usage: %s file1 file2\n" % sys.argv[0]) +if len(sys.argv) < 3: + sys.stderr.write("usage: %s [option] file1 file2 \n" % sys.argv[0]) + sys.stderr.write("The options are:\n") + sys.stderr.write("-c cateogrize output based on symbole type\n") + sys.stderr.write("-d Show delta of Data Section\n") + sys.stderr.write("-t Show delta of text Section\n") sys.exit(-1) re_NUMBER = re.compile(r'\.[0-9]+') -def getsizes(file): - sym = {} - with os.popen("nm --size-sort " + file) as f: - for line in f: - size, type, name = line.split() - if type in "tTdDbBrR": - # strip generated symbols - if name.startswith("__mod_"): continue - if name.startswith("SyS_"): continue - if name.startswith("compat_SyS_"): continue - if name == "linux_banner": continue - # statics and some other optimizations adds random .NUMBER - name = re_NUMBER.sub('', name) - sym[name] = sym.get(name, 0) + int(size, 16) - return sym - -old = getsizes(sys.argv[1]) -new = getsizes(sys.argv[2]) -grow, shrink, add, remove, up, down = 0, 0, 0, 0, 0, 0 -delta, common = [], {} -otot, ntot = 0, 0 - -for a in old: - if a in new: - common[a] = 1 - -for name in old: - otot += old[name] - if name not in common: - remove += 1 - down += old[name] - delta.append((-old[name], name)) - -for name in new: - ntot += new[name] - if name not in common: - add += 1 - up += new[name] - delta.append((new[name], name)) - -for name in common: +def getsizes(file, format) : + func_sym = {} + for l in os.popen("nm --size-sort " + file).readlines(): + size, type, name = l[:-1].split() + if type in format: + # strip generated symbols + if name.startswith("__mod_"): continue + if name.startswith("SyS_"): continue + if name.startswith("compat_SyS_"): continue + if name == "linux_banner": continue + # statics and some other optimizations adds random .NUMBER + name = re_NUMBER.sub('', name) + func_sym[name] = func_sym.get(name, 0) + int(size, 16) + return func_sym + +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 + + for a in old: + if a in new: + common[a] = 1 + + for name in old: + otot += old[name] + if name not in common: + remove += 1 + down += old[name] + delta.append((-old[name], name)) + + for name in new: + ntot += new[name] + if name not in common: + add += 1 + up += new[name] + delta.append((new[name], name)) + + for name in common: 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)) -delta.sort() -delta.reverse() + delta.sort() + delta.reverse() + return grow, shrink, add, remove, up, down, delta, old, new, otot, ntot + +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) + + 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) + + print("Total: Before=%d, After=%d, chg %+.2f%%" % \ + (otot, ntot, (ntot - otot)*100.0/otot)) + +if(sys.argv[1] == "-c"): + print_result("Function", "tT", 3) + print("##########################################################") + + print_result("Data", "dDbB", 3) + print("##########################################################") + + print_result("RO Data", "rR", 3) + +elif(sys.argv[1] == "-d"): + print_result("Data", "dDbBrR", 3) -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" % ("function", "old", "new", "delta")) -for d, n in delta: - if d: print("%-40s %7s %7s %+7d" % (n, old.get(n,"-"), new.get(n,"-"), d)) +elif(sys.argv[1] == "-t"): + print_result("Function", "tT", 3) -print("Total: Before=%d, After=%d, chg %+.2f%%" % \ - (otot, ntot, (ntot - otot)*100.0/otot)) +else: + print_result("Function", "tTdDbBrR", 2) -- 1.9.1