build system: fix generate_BUFSIZ.sh to not alternate 1k and malloc builds

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
1_25_stable
Denys Vlasenko 2016-04-21 23:52:35 +02:00
parent 93e1aaa1c7
commit d7b502c059
2 changed files with 106 additions and 70 deletions

View File

@ -611,7 +611,7 @@ quiet_cmd_busybox__ ?= LINK $@
"$(core-y)" \ "$(core-y)" \
"$(libs-y)" \ "$(libs-y)" \
"$(LDLIBS)" \ "$(LDLIBS)" \
&& $(srctree)/scripts/generate_BUFSIZ.sh include/common_bufsiz.h && $(srctree)/scripts/generate_BUFSIZ.sh --post include/common_bufsiz.h
# Generate System.map # Generate System.map
quiet_cmd_sysmap = SYSMAP quiet_cmd_sysmap = SYSMAP

View File

@ -7,11 +7,16 @@
debug=false debug=false
postcompile=false
test x"$1" = x"--post" && { postcompile=true; shift; }
common_bufsiz_h=$1 common_bufsiz_h=$1
test x"$NM" = x"" && NM="${CONFIG_CROSS_COMPILER_PREFIX}nm" test x"$NM" = x"" && NM="${CONFIG_CROSS_COMPILER_PREFIX}nm"
test x"$CC" = x"" && CC="${CONFIG_CROSS_COMPILER_PREFIX}gcc" test x"$CC" = x"" && CC="${CONFIG_CROSS_COMPILER_PREFIX}gcc"
exitcmd="exit 0"
regenerate() { regenerate() {
cat >"$1.$$" cat >"$1.$$"
test -f "$1" && diff "$1.$$" "$1" >/dev/null && rm "$1.$$" && return test -f "$1" && diff "$1.$$" "$1" >/dev/null && rm "$1.$$" && return
@ -19,30 +24,60 @@ regenerate() {
} }
generate_std_and_exit() { generate_std_and_exit() {
$debug && echo "Default: bb_common_bufsiz1[] in bss" $debug && echo "Configuring: bb_common_bufsiz1[] in bss"
{ {
echo "enum { COMMON_BUFSIZE = 1024 };" echo "enum { COMMON_BUFSIZE = 1024 };"
echo "extern char bb_common_bufsiz1[];" echo "extern char bb_common_bufsiz1[];"
echo "#define setup_common_bufsiz() ((void)0)" echo "#define setup_common_bufsiz() ((void)0)"
} | regenerate "$common_bufsiz_h" } | regenerate "$common_bufsiz_h"
exit 0 echo "std" >"$common_bufsiz_h.method"
$exitcmd
}
generate_big_and_exit() {
$debug && echo "Configuring: bb_common_bufsiz1[] in _end[], COMMON_BUFSIZE = $1"
{
echo "enum { COMMON_BUFSIZE = $1 };"
echo "extern char _end[]; /* linker-provided label */"
echo "#define bb_common_bufsiz1 _end"
echo "#define setup_common_bufsiz() ((void)0)"
} | regenerate "$common_bufsiz_h"
echo "$2" >"$common_bufsiz_h.method"
$exitcmd
}
generate_1k_and_exit() {
generate_big_and_exit 1024 "1k"
}
generate_malloc_and_exit() {
$debug && echo "Configuring: bb_common_bufsiz1[] is malloced"
{
echo "enum { COMMON_BUFSIZE = 1024 };"
echo "extern char *const bb_common_bufsiz1;"
echo "void setup_common_bufsiz(void);"
} | regenerate "$common_bufsiz_h"
echo "malloc" >"$common_bufsiz_h.method"
$exitcmd
} }
# User does not want any funky stuff? # User does not want any funky stuff?
test x"$CONFIG_FEATURE_USE_BSS_TAIL" = x"y" || generate_std_and_exit test x"$CONFIG_FEATURE_USE_BSS_TAIL" = x"y" || generate_std_and_exit
test -f busybox_unstripped || { # The script is run two times: before compilation, when it needs to
# We did not try anything yet # (re)generate $common_bufsiz_h, and directly after successful build,
$debug && echo "Will try to fit bb_common_bufsiz1[] into _end[]" # when it needs to assess whether the build is ok to use at all (not buggy),
{ # and (re)generate $common_bufsiz_h for a future build.
echo "enum { COMMON_BUFSIZE = 1024 };"
echo "extern char _end[]; /* linker-provided label */" if $postcompile; then
echo "#define bb_common_bufsiz1 _end" # Postcompile needs to create/delete OK/FAIL files
echo "#define setup_common_bufsiz() ((void)0)"
} | regenerate "$common_bufsiz_h" test -f busybox_unstripped || exit 1
echo 1024 >"$common_bufsiz_h.BUFSIZE" test -f "$common_bufsiz_h.method" || exit 1
exit 0
} # How the build was done?
method=`cat -- "$common_bufsiz_h.method"`
# Get _end address # Get _end address
END=`$NM busybox_unstripped | grep ' . _end$'| cut -d' ' -f1` END=`$NM busybox_unstripped | grep ' . _end$'| cut -d' ' -f1`
@ -51,67 +86,68 @@ $debug && echo "END:0x$END $((0x$END))"
END=$((0x$END)) END=$((0x$END))
# Get PAGE_SIZE # Get PAGE_SIZE
echo "\ {
#include <sys/user.h> echo "#include <sys/user.h>"
#if defined(PAGE_SIZE) && PAGE_SIZE > 0 echo "#if defined(PAGE_SIZE) && PAGE_SIZE > 0"
char page_size[PAGE_SIZE]; echo "char page_size[PAGE_SIZE];"
#else echo "#endif"
char page_size[1]; } >page_size_$$.c
#endif $CC -c "page_size_$$.c" || exit 1
" >page_size_$$.c
$CC -c "page_size_$$.c" || generate_std_and_exit
PAGE_SIZE=`$NM --size-sort "page_size_$$.o" | cut -d' ' -f1` PAGE_SIZE=`$NM --size-sort "page_size_$$.o" | cut -d' ' -f1`
rm "page_size_$$.c" "page_size_$$.o" rm "page_size_$$.c" "page_size_$$.o"
test x"$PAGE_SIZE" = x"" && generate_std_and_exit test x"$PAGE_SIZE" = x"" && exit 1
$debug && echo "PAGE_SIZE:0x$PAGE_SIZE $((0x$PAGE_SIZE))" $debug && echo "PAGE_SIZE:0x$PAGE_SIZE $((0x$PAGE_SIZE))"
PAGE_SIZE=$((0x$PAGE_SIZE)) PAGE_SIZE=$((0x$PAGE_SIZE))
test $PAGE_SIZE -lt 1024 && generate_std_and_exit test $PAGE_SIZE -lt 512 && exit 1
# How much space between _end[] and next page? # How much space between _end[] and next page?
PAGE_MASK=$((PAGE_SIZE-1)) PAGE_MASK=$((PAGE_SIZE-1))
REM=$(( (-END) & PAGE_MASK )) COMMON_BUFSIZE=$(( (-END) & PAGE_MASK ))
$debug && echo "REM:$REM" echo "COMMON_BUFSIZE = $COMMON_BUFSIZE bytes"
if test $REM -lt 1024; then if test x"$method" = x"1k"; then
# _end[] has no enough space for bb_common_bufsiz1[], if test $COMMON_BUFSIZE -lt 1024; then
# users will need to malloc it. # _end[] has no enough space for bb_common_bufsiz1[]
{ rm -- "$common_bufsiz_h.1k.OK" 2>/dev/null
echo "enum { COMMON_BUFSIZE = 1024 };" { md5sum <.config | cut -d' ' -f1; stat -c "%Y" .config; } >"$common_bufsiz_h.1k.FAIL"
echo "extern char *const bb_common_bufsiz1;" echo "Warning! Space in _end[] is too small ($COMMON_BUFSIZE bytes)!"
echo "void setup_common_bufsiz(void);"
} | regenerate "$common_bufsiz_h"
# Check that we aren't left with a buggy binary:
if test -f "$common_bufsiz_h.BUFSIZE"; then
rm "$common_bufsiz_h.BUFSIZE"
echo "Warning! Space in _end[] is too small ($REM bytes)!"
echo "Rerun make to build a binary which doesn't use it!" echo "Rerun make to build a binary which doesn't use it!"
exit 1 rm busybox_unstripped
fi exitcmd="exit 1"
echo "COMMON_BUFSIZE = 1024 bytes, the buffer will be malloced"
exit 0
fi
# _end[] has REM bytes for bb_common_bufsiz1[]
OLD=1024
test -f "$common_bufsiz_h.BUFSIZE" && OLD=`cat "$common_bufsiz_h.BUFSIZE"`
$debug && echo "OLD:$OLD"
{
echo "enum { COMMON_BUFSIZE = $REM };"
echo "extern char _end[]; /* linker-provided label */"
echo "#define bb_common_bufsiz1 _end"
echo "#define setup_common_bufsiz() ((void)0)"
} | regenerate "$common_bufsiz_h"
echo $REM >"$common_bufsiz_h.BUFSIZE"
# Check that code did not grow too much and thus _end[] did not shrink:
if test $OLD -gt $REM; then
echo "Warning! Space in _end[] has decreased from $OLD to $REM bytes!"
echo "Rerun make!"
exit 1
fi
if test $OLD != $REM; then
echo "Space in _end[] is $REM bytes. Rerun make to use larger COMMON_BUFSIZE."
else else
echo "COMMON_BUFSIZE = $REM bytes" rm -- "$common_bufsiz_h.1k.FAIL" 2>/dev/null
echo $COMMON_BUFSIZE >"$common_bufsiz_h.1k.OK"
test $COMMON_BUFSIZE -gt $((1024+32)) && echo "Rerun make to use larger COMMON_BUFSIZE"
fi fi
fi
fi
# Based on past success/fail of 1k build, decide next build type
if test -f "$common_bufsiz_h.1k.OK"; then
# Previous build succeeded fitting 1k into _end[].
# Try bigger COMMON_BUFSIZE if possible.
COMMON_BUFSIZE=`cat -- "$common_bufsiz_h.1k.OK"`
# Round down a bit
COMMON_BUFSIZE=$(( (COMMON_BUFSIZE-32) & 0xfffffe0 ))
COMMON_BUFSIZE=$(( COMMON_BUFSIZE < 1024 ? 1024 : COMMON_BUFSIZE ))
test $COMMON_BUFSIZE = 1024 && generate_1k_and_exit
generate_big_and_exit $COMMON_BUFSIZE "big"
fi
if test -f "$common_bufsiz_h.1k.FAIL"; then
# Previous build FAILED to fit 1k into _end[].
# Was it with same .config?
oldcfg=`cat -- "$common_bufsiz_h.1k.FAIL"`
curcfg=`md5sum <.config | cut -d' ' -f1; stat -c "%Y" .config`
# If yes, then build a "malloced" version
if test x"$oldcfg" = x"$curcfg"; then
echo "Will not try 1k build, it failed before. Touch .config to override"
generate_malloc_and_exit
fi
# else: try 1k version
echo "New .config, will try 1k build"
rm -- "$common_bufsiz_h.1k.FAIL"
generate_1k_and_exit
fi
# There was no 1k build yet. Try it.
generate_1k_and_exit