blob: 4fea6fe765b7617d203b8b24f3bfbcab052e5730 [file] [log] [blame]
Denis Vlasenko7d219aa2006-10-05 10:17:08 +00001#!/bin/sh
2
3debug=false
4
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +00005# Linker flags used:
6#
7# Informational:
8# --warn-common
9# -Map $EXE.map
10# --verbose
11#
12# Optimizations:
13# --sort-common reduces padding
14# --sort-section alignment reduces padding
15# --gc-sections throws out unused sections,
16# does not work for shared libs
Denis Vlasenko42e41822007-10-09 18:01:13 +000017# -On Not used, maybe useful?
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +000018#
19# List of files to link:
20# $l_list == --start-group -llib1 -llib2 --end-group
21# --start-group $O_FILES $A_FILES --end-group
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +000022#
23# Shared library link:
24# -shared self-explanatory
25# -fPIC position-independent code
Denis Vlasenko724d1962007-10-10 14:41:07 +000026# --enable-new-dtags ?
27# -z,combreloc ?
28# -soname="libbusybox.so.$BB_VER"
Denis Vlasenko9b49a5e2007-10-11 10:05:36 +000029# --undefined=lbb_main Seed name to start pulling from
Denis Vlasenko724d1962007-10-10 14:41:07 +000030# (otherwise we'll need --whole-archive)
31# -static Not used, but may be useful! manpage:
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +000032# "... This option can be used with -shared.
33# Doing so means that a shared library
34# is being created but that all of the library's
35# external references must be resolved by pulling
36# in entries from static libraries."
37
38
Denis Vlasenko018e0852007-02-25 00:40:37 +000039try() {
Denis Vlasenko32404742007-10-07 17:05:22 +000040 printf "%s\n" "Output of:" >$EXE.out
41 printf "%s\n" "$*" >>$EXE.out
42 printf "%s\n" "==========" >>$EXE.out
43 $debug && echo "Trying: $*"
44 "$@" >>$EXE.out 2>&1
45 exitcode=$?
Denis Vlasenko32404742007-10-07 17:05:22 +000046 return $exitcode
Denis Vlasenko7d219aa2006-10-05 10:17:08 +000047}
48
Denis Vlasenko130f5592007-11-13 17:36:12 +000049check_cc() {
50 if $CC $1 -shared -o /dev/null -xc /dev/null > /dev/null 2>&1; then
51 echo "$1";
52 else
53 echo "$2";
54 fi
55}
56
Denis Vlasenko32404742007-10-07 17:05:22 +000057EXE="$1"
58CC="$2"
59LDFLAGS="$3"
60O_FILES="$4"
61A_FILES="$5"
62LDLIBS="$6"
63
Denis Vlasenko130f5592007-11-13 17:36:12 +000064# The -Wl,--sort-section option is not supported by older versions of ld
65SORT_SECTION=`check_cc "-Wl,--sort-section -Wl,alignment" ""`
66
Denis Vlasenko150d2fa2007-07-17 20:39:27 +000067# Sanitize lib list (dups, extra spaces etc)
Denis Vlasenko76a6b232007-10-07 17:05:42 +000068LDLIBS=`echo "$LDLIBS" | xargs -n1 | sort | uniq | xargs`
Denis Vlasenko150d2fa2007-07-17 20:39:27 +000069
70# First link with all libs. If it fails, bail out
Denis Vlasenko76a6b232007-10-07 17:05:42 +000071echo "Trying libraries: $LDLIBS"
Denis Vlasenko32404742007-10-07 17:05:22 +000072# "lib1 lib2 lib3" -> "-llib1 -llib2 -llib3"
Denis Vlasenko76a6b232007-10-07 17:05:42 +000073l_list=`echo "$LDLIBS" | sed -e 's/ / -l/g' -e 's/^/-l/' -e 's/^-l$//'`
Bernhard Reutner-Fischerd2bb2d32007-09-02 15:28:30 +000074test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group"
Denis Vlasenko32404742007-10-07 17:05:22 +000075try $CC $LDFLAGS \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +000076 -o $EXE \
77 -Wl,--sort-common \
Denis Vlasenko130f5592007-11-13 17:36:12 +000078 $SORT_SECTION \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +000079 -Wl,--gc-sections \
Denis Vlasenko32404742007-10-07 17:05:22 +000080 -Wl,--start-group $O_FILES $A_FILES -Wl,--end-group \
81 $l_list \
Denis Vlasenko150d2fa2007-07-17 20:39:27 +000082|| {
Denis Vlasenko32404742007-10-07 17:05:22 +000083 echo "Failed: $* $l_list"
84 cat $EXE.out
Denis Vlasenko150d2fa2007-07-17 20:39:27 +000085 exit 1
86}
Denis Vlasenko6ca409e2007-08-12 20:58:27 +000087
Denis Vlasenko8274e062007-08-06 03:41:08 +000088# Now try to remove each lib and build without it.
Denis Vlasenko150d2fa2007-07-17 20:39:27 +000089# Stop when no lib can be removed.
Denis Vlasenko76a6b232007-10-07 17:05:42 +000090while test "$LDLIBS"; do
91 $debug && echo "Trying libraries: $LDLIBS"
Denis Vlasenko150d2fa2007-07-17 20:39:27 +000092 all_needed=true
Denis Vlasenko76a6b232007-10-07 17:05:42 +000093 for one in $LDLIBS; do
94 without_one=`echo " $LDLIBS " | sed "s/ $one / /g" | xargs`
Denis Vlasenko32404742007-10-07 17:05:22 +000095 # "lib1 lib2 lib3" -> "-llib1 -llib2 -llib3"
Bernhard Reutner-Fischerd2bb2d32007-09-02 15:28:30 +000096 l_list=`echo "$without_one" | sed -e 's/ / -l/g' -e 's/^/-l/' -e 's/^-l$//'`
97 test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group"
Bernhard Reutner-Fischer8d91c132007-09-02 14:51:54 +000098 $debug && echo "Trying -l options: '$l_list'"
Denis Vlasenko32404742007-10-07 17:05:22 +000099 try $CC $LDFLAGS \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000100 -o $EXE \
101 -Wl,--sort-common \
Denis Vlasenko130f5592007-11-13 17:36:12 +0000102 $SORT_SECTION \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000103 -Wl,--gc-sections \
Denis Vlasenko32404742007-10-07 17:05:22 +0000104 -Wl,--start-group $O_FILES $A_FILES -Wl,--end-group \
Denis Vlasenkod19b87e2007-10-09 13:08:02 +0000105 $l_list
Denis Vlasenko32404742007-10-07 17:05:22 +0000106 if test $? = 0; then
107 echo "Library $one is not needed"
Denis Vlasenko76a6b232007-10-07 17:05:42 +0000108 LDLIBS="$without_one"
Denis Vlasenko32404742007-10-07 17:05:22 +0000109 all_needed=false
Denis Vlasenko150d2fa2007-07-17 20:39:27 +0000110 else
Denis Vlasenko32404742007-10-07 17:05:22 +0000111 echo "Library $one is needed"
Denis Vlasenko150d2fa2007-07-17 20:39:27 +0000112 fi
113 done
114 # All libs were needed, can't remove any
115 $all_needed && break
Denis Vlasenko8274e062007-08-06 03:41:08 +0000116 # If there is no space char, the list has just one lib.
Denis Vlasenko150d2fa2007-07-17 20:39:27 +0000117 # I'm not sure that in this case lib really is 100% needed.
118 # Let's try linking without it anyway... thus commented out.
Denis Vlasenko76a6b232007-10-07 17:05:42 +0000119 #{ echo "$LDLIBS" | grep -q ' '; } || break
Denis Vlasenko150d2fa2007-07-17 20:39:27 +0000120done
121
Denis Vlasenko9862e6b2007-09-03 11:28:14 +0000122# Make the binary with final, minimal list of libs
Denis Vlasenko76a6b232007-10-07 17:05:42 +0000123echo "Final link with: $LDLIBS"
124l_list=`echo "$LDLIBS" | sed -e 's/ / -l/g' -e 's/^/-l/' -e 's/^-l$//'`
Denis Vlasenko8d755ad2007-10-09 10:15:41 +0000125test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group"
Denis Vlasenko9862e6b2007-09-03 11:28:14 +0000126# --verbose gives us gobs of info to stdout (e.g. linker script used)
127if ! test -f busybox_ldscript; then
Denis Vlasenko32404742007-10-07 17:05:22 +0000128 try $CC $LDFLAGS \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000129 -o $EXE \
130 -Wl,--sort-common \
Denis Vlasenko130f5592007-11-13 17:36:12 +0000131 $SORT_SECTION \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000132 -Wl,--gc-sections \
Denis Vlasenko32404742007-10-07 17:05:22 +0000133 -Wl,--start-group $O_FILES $A_FILES -Wl,--end-group \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000134 $l_list \
135 -Wl,--warn-common \
136 -Wl,-Map -Wl,$EXE.map \
137 -Wl,--verbose \
Denis Vlasenkod19b87e2007-10-09 13:08:02 +0000138 || {
139 cat $EXE.out
140 exit 1
141 }
Denis Vlasenko9862e6b2007-09-03 11:28:14 +0000142else
143 echo "Custom linker script 'busybox_ldscript' found, using it"
Denis Vlasenko76a6b232007-10-07 17:05:42 +0000144 # Add SORT_BY_ALIGNMENT to linker script (found in $EXE.out):
Denis Vlasenko9862e6b2007-09-03 11:28:14 +0000145 # .rodata : { *(.rodata SORT_BY_ALIGNMENT(.rodata.*) .gnu.linkonce.r.*) }
146 # *(.data SORT_BY_ALIGNMENT(.data.*) .gnu.linkonce.d.*)
147 # *(.bss SORT_BY_ALIGNMENT(.bss.*) .gnu.linkonce.b.*)
Denis Vlasenko76a6b232007-10-07 17:05:42 +0000148 # This will eliminate most of the padding (~3kb).
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000149 # Hmm, "ld --sort-section alignment" should do it too.
Denis Vlasenko32404742007-10-07 17:05:22 +0000150 try $CC $LDFLAGS \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000151 -o $EXE \
152 -Wl,--sort-common \
Denis Vlasenko130f5592007-11-13 17:36:12 +0000153 $SORT_SECTION \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000154 -Wl,--gc-sections \
Denis Vlasenko32404742007-10-07 17:05:22 +0000155 -Wl,-T -Wl,busybox_ldscript \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000156 -Wl,--start-group $O_FILES $A_FILES -Wl,--end-group \
157 $l_list \
158 -Wl,--warn-common \
159 -Wl,-Map -Wl,$EXE.map \
160 -Wl,--verbose \
Denis Vlasenkod19b87e2007-10-09 13:08:02 +0000161 || {
162 cat $EXE.out
163 exit 1
164 }
Denis Vlasenko9862e6b2007-09-03 11:28:14 +0000165fi
Denis Vlasenko32404742007-10-07 17:05:22 +0000166
Denis Vlasenko42e41822007-10-09 18:01:13 +0000167. ./.config
Denis Vlasenko32404742007-10-07 17:05:22 +0000168
Denis Vlasenkodef88982007-10-07 17:06:01 +0000169sharedlib_dir="0_lib"
170
171if test "$CONFIG_BUILD_LIBBUSYBOX" = y; then
172 mkdir "$sharedlib_dir" 2>/dev/null
173 test -d "$sharedlib_dir" || {
174 echo "Cannot make directory $sharedlib_dir"
175 exit 1
176 }
177 ln -s "libbusybox.so.$BB_VER" "$sharedlib_dir"/libbusybox.so 2>/dev/null
178
179 EXE="$sharedlib_dir/libbusybox.so.${BB_VER}_unstripped"
180 try $CC $LDFLAGS \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000181 -o $EXE \
182 -shared -fPIC \
183 -Wl,--enable-new-dtags \
184 -Wl,-z,combreloc \
185 -Wl,-soname="libbusybox.so.$BB_VER" \
Denis Vlasenko9b49a5e2007-10-11 10:05:36 +0000186 -Wl,--undefined=lbb_main \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000187 -Wl,--sort-common \
Denis Vlasenko130f5592007-11-13 17:36:12 +0000188 $SORT_SECTION \
Denis Vlasenko724d1962007-10-10 14:41:07 +0000189 -Wl,--start-group $A_FILES -Wl,--end-group \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000190 $l_list \
191 -Wl,--warn-common \
192 -Wl,-Map -Wl,$EXE.map \
193 -Wl,--verbose \
Denis Vlasenkodef88982007-10-07 17:06:01 +0000194 || {
195 echo "Linking $EXE failed"
196 cat $EXE.out
197 exit 1
198 }
Denis Vlasenko141750e2007-10-10 10:05:35 +0000199 $STRIP -s --remove-section=.note --remove-section=.comment $EXE -o "$sharedlib_dir/libbusybox.so.$BB_VER"
Denis Vlasenkod62fd842007-10-07 20:46:34 +0000200 chmod a+x "$sharedlib_dir/libbusybox.so.$BB_VER"
Denis Vlasenkodef88982007-10-07 17:06:01 +0000201 echo "libbusybox: $sharedlib_dir/libbusybox.so.$BB_VER"
202fi
Denis Vlasenko32404742007-10-07 17:05:22 +0000203
Denis Vlasenkodef88982007-10-07 17:06:01 +0000204if test "$CONFIG_FEATURE_SHARED_BUSYBOX" = y; then
205 EXE="$sharedlib_dir/busybox_unstripped"
206 try $CC $LDFLAGS \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000207 -o $EXE \
208 -Wl,--sort-common \
Denis Vlasenko130f5592007-11-13 17:36:12 +0000209 $SORT_SECTION \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000210 -Wl,--gc-sections \
211 -Wl,--start-group $O_FILES -Wl,--end-group \
212 -L"$sharedlib_dir" -lbusybox \
213 -Wl,--warn-common \
214 -Wl,-Map -Wl,$EXE.map \
215 -Wl,--verbose \
Denis Vlasenkodef88982007-10-07 17:06:01 +0000216 || {
217 echo "Linking $EXE failed"
218 cat $EXE.out
219 exit 1
220 }
Denis Vlasenko141750e2007-10-10 10:05:35 +0000221 $STRIP -s --remove-section=.note --remove-section=.comment $EXE -o "$sharedlib_dir/busybox"
Denis Vlasenkodef88982007-10-07 17:06:01 +0000222 echo "busybox linked against libbusybox: $sharedlib_dir/busybox"
223fi
Denis Vlasenkof545be02007-10-07 17:06:26 +0000224
225if test "$CONFIG_FEATURE_INDIVIDUAL" = y; then
Denis Vlasenkoe9fd69c2007-10-08 22:16:14 +0000226 echo "Linking individual applets against libbusybox (see $sharedlib_dir/*)"
Denis Vlasenkof545be02007-10-07 17:06:26 +0000227 gcc -DNAME_MAIN_CNAME -E -include include/autoconf.h include/applets.h \
228 | grep -v "^#" \
229 | grep -v "^$" \
Denis Vlasenkoe9fd69c2007-10-08 22:16:14 +0000230 > applet_lst.tmp
Denis Vlasenko642a52d2007-10-07 21:00:41 +0000231 while read name main junk; do
Denis Vlasenkof545be02007-10-07 17:06:26 +0000232
233 echo "\
Denis Vlasenko15cb4a42007-10-11 10:06:26 +0000234void lbb_prepare(const char *applet, char **argv);
Denis Vlasenkod62fd842007-10-07 20:46:34 +0000235int $main(int argc, char **argv);
Denis Vlasenkof545be02007-10-07 17:06:26 +0000236
Denis Vlasenkof545be02007-10-07 17:06:26 +0000237int main(int argc, char **argv)
238{
Denis Vlasenko15cb4a42007-10-11 10:06:26 +0000239 lbb_prepare(\"$name\", argv);
Denis Vlasenkod62fd842007-10-07 20:46:34 +0000240 return $main(argc, argv);
Denis Vlasenkof545be02007-10-07 17:06:26 +0000241}
242" >"$sharedlib_dir/applet.c"
243
244 EXE="$sharedlib_dir/$name"
245 try $CC $LDFLAGS "$sharedlib_dir/applet.c" \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000246 -o $EXE \
247 -Wl,--sort-common \
Denis Vlasenko130f5592007-11-13 17:36:12 +0000248 $SORT_SECTION \
Denis Vlasenko01f3b2c2007-10-09 13:49:26 +0000249 -Wl,--gc-sections \
250 -L"$sharedlib_dir" -lbusybox \
251 -Wl,--warn-common \
Denis Vlasenkof545be02007-10-07 17:06:26 +0000252 || {
253 echo "Linking $EXE failed"
Denis Vlasenko8d755ad2007-10-09 10:15:41 +0000254 cat $EXE.out
Denis Vlasenkof545be02007-10-07 17:06:26 +0000255 exit 1
256 }
257 rm -- "$sharedlib_dir/applet.c" $EXE.out
Denis Vlasenko141750e2007-10-10 10:05:35 +0000258 $STRIP -s --remove-section=.note --remove-section=.comment $EXE
Denis Vlasenkof545be02007-10-07 17:06:26 +0000259
Denis Vlasenkoe9fd69c2007-10-08 22:16:14 +0000260 done <applet_lst.tmp
Denis Vlasenkof545be02007-10-07 17:06:26 +0000261fi
Denis Vlasenkod62fd842007-10-07 20:46:34 +0000262
263# libbusybox.so is needed only for -lbusybox at link time,
264# it is not needed at runtime. Deleting to reduce confusion.
Denis Vlasenko8d755ad2007-10-09 10:15:41 +0000265rm "$sharedlib_dir"/libbusybox.so 2>/dev/null
266exit 0 # or else we may confuse make