mirror of https://github.com/mirror/busybox.git
reviving libbusybox, adding CONFIG_INDIVIDUAL part 1
parent
e747f62ed6
commit
3240474c23
12
Makefile
12
Makefile
|
@ -568,11 +568,13 @@ busybox-all := $(core-y) $(libs-y)
|
||||||
# Rule to link busybox - also used during CONFIG_KALLSYMS
|
# Rule to link busybox - also used during CONFIG_KALLSYMS
|
||||||
# May be overridden by arch/$(ARCH)/Makefile
|
# May be overridden by arch/$(ARCH)/Makefile
|
||||||
quiet_cmd_busybox__ ?= LINK $@
|
quiet_cmd_busybox__ ?= LINK $@
|
||||||
cmd_busybox__ ?= $(srctree)/scripts/trylink $(CC) $(LDFLAGS) $(EXTRA_LDFLAGS) \
|
cmd_busybox__ ?= $(srctree)/scripts/trylink \
|
||||||
-o $@ -Wl,-Map -Wl,$@.map \
|
"$@" \
|
||||||
-Wl,--warn-common -Wl,--sort-common -Wl,--gc-sections \
|
"$(CC)" \
|
||||||
-Wl,--start-group $(busybox-all) -Wl,--end-group \
|
"$(LDFLAGS) $(EXTRA_LDFLAGS)" \
|
||||||
$(LDLIBS)
|
"$(core-y)" \
|
||||||
|
"$(libs-y)" \
|
||||||
|
"$(LDLIBS)"
|
||||||
|
|
||||||
# Generate System.map
|
# Generate System.map
|
||||||
quiet_cmd_sysmap = SYSMAP
|
quiet_cmd_sysmap = SYSMAP
|
||||||
|
|
|
@ -3,24 +3,40 @@
|
||||||
debug=false
|
debug=false
|
||||||
|
|
||||||
try() {
|
try() {
|
||||||
added="$1"
|
printf "%s\n" "Output of:" >$EXE.out
|
||||||
shift
|
printf "%s\n" "$*" >>$EXE.out
|
||||||
$debug && echo "Trying: $* $added"
|
printf "%s\n" "==========" >>$EXE.out
|
||||||
"$@" $added 2>busybox_ld.err
|
$debug && echo "Trying: $*"
|
||||||
|
"$@" >>$EXE.out 2>&1
|
||||||
|
exitcode=$?
|
||||||
|
cat $EXE.out
|
||||||
|
return $exitcode
|
||||||
}
|
}
|
||||||
|
|
||||||
|
EXE="$1"
|
||||||
|
CC="$2"
|
||||||
|
LDFLAGS="$3"
|
||||||
|
O_FILES="$4"
|
||||||
|
A_FILES="$5"
|
||||||
|
LDLIBS="$6"
|
||||||
|
|
||||||
# Sanitize lib list (dups, extra spaces etc)
|
# Sanitize lib list (dups, extra spaces etc)
|
||||||
#echo "BBOX_LIB_LIST=$BBOX_LIB_LIST"
|
|
||||||
BBOX_LIB_LIST=`echo "$BBOX_LIB_LIST" | xargs -n1 | sort | uniq | xargs`
|
BBOX_LIB_LIST=`echo "$BBOX_LIB_LIST" | xargs -n1 | sort | uniq | xargs`
|
||||||
|
|
||||||
# First link with all libs. If it fails, bail out
|
# First link with all libs. If it fails, bail out
|
||||||
echo "Trying libraries: $BBOX_LIB_LIST"
|
echo "Trying libraries: $BBOX_LIB_LIST"
|
||||||
|
# "lib1 lib2 lib3" -> "-llib1 -llib2 -llib3"
|
||||||
l_list=`echo "$BBOX_LIB_LIST" | sed -e 's/ / -l/g' -e 's/^/-l/' -e 's/^-l$//'`
|
l_list=`echo "$BBOX_LIB_LIST" | sed -e 's/ / -l/g' -e 's/^/-l/' -e 's/^-l$//'`
|
||||||
test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group"
|
test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group"
|
||||||
try "$l_list" "$@" \
|
try $CC $LDFLAGS \
|
||||||
|
-o $EXE -Wl,-Map -Wl,$EXE.map \
|
||||||
|
-Wl,--warn-common -Wl,--sort-common -Wl,--gc-sections \
|
||||||
|
-Wl,--start-group $O_FILES $A_FILES -Wl,--end-group \
|
||||||
|
$l_list \
|
||||||
|
>/dev/null \
|
||||||
|| {
|
|| {
|
||||||
echo "Failed: $* -Wl,--start-group $l_list -Wl,--end-group"
|
echo "Failed: $* $l_list"
|
||||||
cat busybox_ld.err
|
cat $EXE.out
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,15 +47,22 @@ while test "$BBOX_LIB_LIST"; do
|
||||||
all_needed=true
|
all_needed=true
|
||||||
for one in $BBOX_LIB_LIST; do
|
for one in $BBOX_LIB_LIST; do
|
||||||
without_one=`echo " $BBOX_LIB_LIST " | sed "s/ $one / /g" | xargs`
|
without_one=`echo " $BBOX_LIB_LIST " | sed "s/ $one / /g" | xargs`
|
||||||
|
# "lib1 lib2 lib3" -> "-llib1 -llib2 -llib3"
|
||||||
l_list=`echo "$without_one" | sed -e 's/ / -l/g' -e 's/^/-l/' -e 's/^-l$//'`
|
l_list=`echo "$without_one" | sed -e 's/ / -l/g' -e 's/^/-l/' -e 's/^-l$//'`
|
||||||
test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group"
|
test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group"
|
||||||
$debug && echo "Trying -l options: '$l_list'"
|
$debug && echo "Trying -l options: '$l_list'"
|
||||||
if try "$l_list" "$@"; then
|
try $CC $LDFLAGS \
|
||||||
echo "Library $one is not needed"
|
-o $EXE -Wl,-Map -Wl,$EXE.map \
|
||||||
BBOX_LIB_LIST="$without_one"
|
-Wl,--warn-common -Wl,--sort-common -Wl,--gc-sections \
|
||||||
all_needed=false
|
-Wl,--start-group $O_FILES $A_FILES -Wl,--end-group \
|
||||||
|
$l_list \
|
||||||
|
>/dev/null
|
||||||
|
if test $? = 0; then
|
||||||
|
echo "Library $one is not needed"
|
||||||
|
BBOX_LIB_LIST="$without_one"
|
||||||
|
all_needed=false
|
||||||
else
|
else
|
||||||
echo "Library $one is needed"
|
echo "Library $one is needed"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
# All libs were needed, can't remove any
|
# All libs were needed, can't remove any
|
||||||
|
@ -56,13 +79,55 @@ l_list=`echo "$BBOX_LIB_LIST" | sed -e 's/ / -l/g' -e 's/^/-l/' -e 's/^-l$//'`
|
||||||
test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group -Wl,--verbose"
|
test "x$l_list" != "x" && l_list="-Wl,--start-group $l_list -Wl,--end-group -Wl,--verbose"
|
||||||
# --verbose gives us gobs of info to stdout (e.g. linker script used)
|
# --verbose gives us gobs of info to stdout (e.g. linker script used)
|
||||||
if ! test -f busybox_ldscript; then
|
if ! test -f busybox_ldscript; then
|
||||||
try "$l_list -Wl,--verbose" "$@" >busybox_ld.out
|
try $CC $LDFLAGS \
|
||||||
|
-o $EXE -Wl,-Map -Wl,$EXE.map \
|
||||||
|
-Wl,--warn-common -Wl,--sort-common -Wl,--gc-sections \
|
||||||
|
-Wl,--start-group $O_FILES $A_FILES -Wl,--end-group \
|
||||||
|
$l_list -Wl,--verbose \
|
||||||
|
>/dev/null
|
||||||
else
|
else
|
||||||
echo "Custom linker script 'busybox_ldscript' found, using it"
|
echo "Custom linker script 'busybox_ldscript' found, using it"
|
||||||
# Add SORT_BY_ALIGNMENT to linker script (found in busybox_ld.out):
|
# Add SORT_BY_ALIGNMENT to linker script (found in ${EXE}_ld.out):
|
||||||
# .rodata : { *(.rodata SORT_BY_ALIGNMENT(.rodata.*) .gnu.linkonce.r.*) }
|
# .rodata : { *(.rodata SORT_BY_ALIGNMENT(.rodata.*) .gnu.linkonce.r.*) }
|
||||||
# *(.data SORT_BY_ALIGNMENT(.data.*) .gnu.linkonce.d.*)
|
# *(.data SORT_BY_ALIGNMENT(.data.*) .gnu.linkonce.d.*)
|
||||||
# *(.bss SORT_BY_ALIGNMENT(.bss.*) .gnu.linkonce.b.*)
|
# *(.bss SORT_BY_ALIGNMENT(.bss.*) .gnu.linkonce.b.*)
|
||||||
# This will eliminate most of the data padding (~3kb).
|
# This will eliminate most of the data padding (~3kb).
|
||||||
try "$l_list -Wl,--verbose -Wl,-T -Wl,busybox_ldscript" "$@" >busybox_ld.out
|
try $CC $LDFLAGS \
|
||||||
|
-o $EXE -Wl,-Map -Wl,$EXE.map \
|
||||||
|
-Wl,--warn-common -Wl,--sort-common -Wl,--gc-sections \
|
||||||
|
-Wl,--start-group $O_FILES $A_FILES -Wl,--end-group \
|
||||||
|
$l_list -Wl,--verbose \
|
||||||
|
-Wl,-T -Wl,busybox_ldscript \
|
||||||
|
>/dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
mkdir 0lib 2>/dev/null
|
||||||
|
test -d 0lib || exit 1
|
||||||
|
ln -s libbusybox.so.1.8.0 0lib/libbusybox.so 2>/dev/null
|
||||||
|
|
||||||
|
EXE="0lib/libbusybox.so.1.8.0"
|
||||||
|
try $CC $LDFLAGS \
|
||||||
|
-o $EXE -Wl,-Map -Wl,$EXE.map \
|
||||||
|
-shared -fPIC -Wl,--enable-new-dtags \
|
||||||
|
-Wl,--start-group -Wl,--whole-archive $A_FILES -Wl,--no-whole-archive -Wl,--end-group \
|
||||||
|
$l_list -Wl,--verbose \
|
||||||
|
-Wl,-soname="libbusybox.so.1.8.0" \
|
||||||
|
-Wl,-z,combreloc \
|
||||||
|
>/dev/null \
|
||||||
|
|| {
|
||||||
|
echo "Linking $EXE failed"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
EXE="0lib/busybox"
|
||||||
|
try $CC $LDFLAGS \
|
||||||
|
-o $EXE -Wl,-Map -Wl,$EXE.map \
|
||||||
|
-Wl,--warn-common -Wl,--sort-common -Wl,--gc-sections \
|
||||||
|
-Wl,--start-group $O_FILES -Wl,--end-group \
|
||||||
|
$l_list -Wl,--verbose \
|
||||||
|
-L"0lib" -lbusybox \
|
||||||
|
>/dev/null \
|
||||||
|
|| {
|
||||||
|
echo "Linking $EXE failed"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue