diff options
author | Bartosz Golaszewski <bartekgola@gmail.com> | 2013-10-16 19:18:05 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2013-10-16 19:18:05 +0200 |
commit | 28a209466f43c22db42dd02baa136ac7ac25069b (patch) | |
tree | bd8fc6cdbe9bfc9e2a586ff01b9fadcaecd60560 | |
parent | 64938011f3ba06a8f425926397172dc361bce851 (diff) | |
download | busybox-w32-28a209466f43c22db42dd02baa136ac7ac25069b.tar.gz busybox-w32-28a209466f43c22db42dd02baa136ac7ac25069b.tar.bz2 busybox-w32-28a209466f43c22db42dd02baa136ac7ac25069b.zip |
bloat-o-meter: add usage info
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | docs/keep_data_small.txt | 15 | ||||
-rwxr-xr-x | scripts/bloat-o-meter | 11 |
2 files changed, 16 insertions, 10 deletions
diff --git a/docs/keep_data_small.txt b/docs/keep_data_small.txt index 21d732674..9fc799646 100644 --- a/docs/keep_data_small.txt +++ b/docs/keep_data_small.txt | |||
@@ -138,13 +138,6 @@ less readable, use #defines: | |||
138 | #define sector (G.sector) | 138 | #define sector (G.sector) |
139 | 139 | ||
140 | 140 | ||
141 | Word of caution | ||
142 | |||
143 | If applet doesn't use much of global data, converting it to use | ||
144 | one of above methods is not worth the resulting code obfuscation. | ||
145 | If you have less than ~300 bytes of global data - don't bother. | ||
146 | |||
147 | |||
148 | Finding non-shared duplicated strings | 141 | Finding non-shared duplicated strings |
149 | 142 | ||
150 | strings busybox | sort | uniq -c | sort -nr | 143 | strings busybox | sort | uniq -c | sort -nr |
@@ -224,6 +217,14 @@ Result (non-static busybox built against glibc): | |||
224 | 217 | ||
225 | Keeping code small | 218 | Keeping code small |
226 | 219 | ||
220 | Use scripts/bloat-o-meter to check whether introduced changes | ||
221 | didn't generate unnecessary bloat. This script needs unstripped binaries | ||
222 | to generate a detailed report. To automate this, just use | ||
223 | "make bloatcheck". It requires busybox_old binary to be present, | ||
224 | use "make baseline" to generate it from unmodified source, or | ||
225 | copy busybox_unstripped to busybox_old before modifying sources | ||
226 | and rebuilding. | ||
227 | |||
227 | Set CONFIG_EXTRA_CFLAGS="-fno-inline-functions-called-once", | 228 | Set CONFIG_EXTRA_CFLAGS="-fno-inline-functions-called-once", |
228 | produce "make bloatcheck", see the biggest auto-inlined functions. | 229 | produce "make bloatcheck", see the biggest auto-inlined functions. |
229 | Now, set CONFIG_EXTRA_CFLAGS back to "", but add NOINLINE | 230 | Now, set CONFIG_EXTRA_CFLAGS back to "", but add NOINLINE |
diff --git a/scripts/bloat-o-meter b/scripts/bloat-o-meter index 6db2a5e58..cb861b8e9 100755 --- a/scripts/bloat-o-meter +++ b/scripts/bloat-o-meter | |||
@@ -7,11 +7,14 @@ | |||
7 | # This software may be used and distributed according to the terms | 7 | # This software may be used and distributed according to the terms |
8 | # of the GNU General Public License, incorporated herein by reference. | 8 | # of the GNU General Public License, incorporated herein by reference. |
9 | 9 | ||
10 | import sys, os#, re | 10 | import sys, os |
11 | 11 | ||
12 | def usage(): | 12 | def usage(): |
13 | sys.stderr.write("usage: %s [-t] file1 file2\n" % sys.argv[0]) | 13 | sys.stderr.write("usage: %s [-t] file1 file2 [-- <readelf options>]\n" |
14 | sys.exit(-1) | 14 | % sys.argv[0]) |
15 | sys.stderr.write("\t-t\tShow time spent on parsing/processing\n") | ||
16 | sys.stderr.write("\t--\tPass additional parameters to readelf\n") | ||
17 | sys.exit(1) | ||
15 | 18 | ||
16 | f1, f2 = (None, None) | 19 | f1, f2 = (None, None) |
17 | flag_timing, dashes = (False, False) | 20 | flag_timing, dashes = (False, False) |
@@ -31,6 +34,8 @@ for f in sys.argv[1:]: | |||
31 | f1 = f | 34 | f1 = f |
32 | elif f2 is None: | 35 | elif f2 is None: |
33 | f2 = f | 36 | f2 = f |
37 | else: | ||
38 | usage() | ||
34 | if flag_timing: | 39 | if flag_timing: |
35 | import time | 40 | import time |
36 | if f1 is None or f2 is None: | 41 | if f1 is None or f2 is None: |