2010-11-03 05:58:24 +08:00
|
|
|
#!/bin/bash
|
|
|
|
|
2010-11-03 07:22:34 +08:00
|
|
|
SCRIPTDIR="$(dirname "$0")"
|
|
|
|
[ "${SCRIPTDIR:0:1}" = "/" ] || SCRIPTDIR="$PWD/$SCRIPTDIR"
|
|
|
|
BASEDIR="$SCRIPTDIR/.."
|
|
|
|
|
|
|
|
DIR="$BASEDIR/tmp/deptest"
|
2010-11-03 06:36:32 +08:00
|
|
|
STAMP_DIR_SUCCESS="$DIR/stamp-success"
|
|
|
|
STAMP_DIR_FAILED="$DIR/stamp-failed"
|
2010-11-03 09:10:52 +08:00
|
|
|
STAMP_DIR_BLACKLIST="$DIR/stamp-blacklist"
|
2010-11-03 07:22:34 +08:00
|
|
|
BUILD_DIR="$DIR/build_dir/target"
|
|
|
|
BUILD_DIR_HOST="$DIR/build_dir/host"
|
|
|
|
STAGING_DIR="$DIR/staging_dir"
|
|
|
|
STAGING_DIR_HOST="$DIR/staging_dir_host"
|
|
|
|
STAGING_DIR_HOST_TMPL="$DIR/staging_dir_host_tmpl"
|
2009-05-27 03:12:00 +08:00
|
|
|
LOG_DIR="$DIR/logs"
|
|
|
|
|
2010-11-03 06:48:29 +08:00
|
|
|
die()
|
|
|
|
{
|
|
|
|
echo "$@"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2010-11-03 07:22:34 +08:00
|
|
|
[ -f "$BASEDIR/include/toplevel.mk" ] || \
|
|
|
|
die "Error: Could not find buildsystem base directory"
|
2010-11-03 08:27:50 +08:00
|
|
|
[ -f "$BASEDIR/.config" ] || \
|
|
|
|
die "The buildsystem is not configured. Please run make menuconfig."
|
2010-11-03 07:22:34 +08:00
|
|
|
cd "$BASEDIR" || die "Failed to enter base directory"
|
|
|
|
|
2010-11-03 09:10:52 +08:00
|
|
|
mkdir -p "$STAMP_DIR_SUCCESS" "$STAMP_DIR_FAILED" "$STAMP_DIR_BLACKLIST" \
|
|
|
|
"$BUILD_DIR" "$BUILD_DIR_HOST" "$LOG_DIR"
|
2010-11-03 07:22:34 +08:00
|
|
|
|
2009-05-27 03:12:00 +08:00
|
|
|
[ -d "$STAGING_DIR_HOST_TMPL" ] || {
|
|
|
|
rm -rf staging_dir/host
|
2010-11-03 06:48:29 +08:00
|
|
|
make tools/install V=99 || die "make tools/install failed, please check"
|
2009-05-27 03:12:00 +08:00
|
|
|
cp -al staging_dir/host "$STAGING_DIR_HOST_TMPL"
|
2010-11-03 06:48:29 +08:00
|
|
|
make toolchain/install V=99 || die "make toolchain/install failed, please check"
|
2010-11-03 08:24:12 +08:00
|
|
|
make target/linux/install V=99 || die "make target/linux/install failed, please check"
|
2009-05-27 03:12:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
for pkg in `cat tmp/.packagedeps | grep CONFIG_PACKAGE | grep -v curdir | sed -e 's,.*[/=]\s*,,' | sort -u`; do
|
2010-11-03 05:57:03 +08:00
|
|
|
SELECTED=
|
|
|
|
for conf in `grep CONFIG_PACKAGE tmp/.packagedeps | grep -E "[ /]$pkg\$" | sed -e 's,package-$(\(CONFIG_PACKAGE_.*\)).*,\1,'`; do
|
|
|
|
grep "$conf=" .config > /dev/null && SELECTED=1
|
|
|
|
done
|
2010-11-03 06:36:32 +08:00
|
|
|
STAMP_SUCCESS="$STAMP_DIR_SUCCESS/$pkg"
|
|
|
|
STAMP_FAILED="$STAMP_DIR_FAILED/$pkg"
|
2010-11-03 09:10:52 +08:00
|
|
|
STAMP_BLACKLIST="$STAMP_DIR_BLACKLIST/$pkg"
|
2010-11-03 06:36:32 +08:00
|
|
|
rm -f "$STAMP_FAILED"
|
|
|
|
[ -f "$STAMP_SUCCESS" ] && continue
|
2010-11-03 05:57:03 +08:00
|
|
|
[ -n "$SELECTED" ] || {
|
|
|
|
echo "Package $pkg is not selected"
|
|
|
|
continue
|
|
|
|
}
|
2010-11-03 09:10:52 +08:00
|
|
|
[ -f "$STAMP_BLACKLIST" ] && {
|
|
|
|
echo "Package $pkg is blacklisted"
|
|
|
|
continue
|
|
|
|
}
|
2010-11-03 05:57:03 +08:00
|
|
|
echo "Testing package $pkg..."
|
|
|
|
rm -rf "$STAGING_DIR"
|
|
|
|
mkdir -p "$STAGING_DIR"
|
|
|
|
rm -rf "$STAGING_DIR_HOST"
|
|
|
|
cp -al "$STAGING_DIR_HOST_TMPL" "$STAGING_DIR_HOST"
|
|
|
|
make package/$pkg/compile \
|
|
|
|
BUILD_DIR="$BUILD_DIR" \
|
|
|
|
BUILD_DIR_HOST="$BUILD_DIR_HOST" \
|
|
|
|
STAGING_DIR="$STAGING_DIR" \
|
|
|
|
STAGING_DIR_HOST="$STAGING_DIR_HOST" \
|
2010-11-03 06:36:32 +08:00
|
|
|
V=99 >"$LOG_DIR/$(basename $pkg).log" 2>&1
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
touch "$STAMP_SUCCESS"
|
|
|
|
else
|
|
|
|
touch "$STAMP_FAILED"
|
2010-11-03 05:57:03 +08:00
|
|
|
echo "Building package $pkg failed!"
|
2010-11-03 06:36:32 +08:00
|
|
|
fi
|
2009-05-27 03:12:00 +08:00
|
|
|
done
|