2010-11-03 05:58:24 +08:00
|
|
|
#!/bin/bash
|
2010-11-03 20:41:28 +08:00
|
|
|
#
|
|
|
|
# Automated OpenWrt package dependency checker
|
|
|
|
#
|
|
|
|
# Copyright (C) 2009-2010 OpenWrt.org
|
|
|
|
#
|
|
|
|
# This is free software, licensed under the GNU General Public License v2.
|
|
|
|
# See /LICENSE for more information.
|
|
|
|
#
|
2010-11-03 05:58:24 +08:00
|
|
|
|
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"
|
2010-11-04 02:48:03 +08:00
|
|
|
KERNEL_BUILD_DIR="$DIR/build_dir/linux"
|
|
|
|
STAGING_DIR="$DIR/staging_dir/target"
|
|
|
|
STAGING_DIR_HOST="$DIR/staging_dir/host"
|
2010-11-03 07:22:34 +08:00
|
|
|
STAGING_DIR_HOST_TMPL="$DIR/staging_dir_host_tmpl"
|
2010-11-04 02:48:03 +08:00
|
|
|
BIN_DIR="$DIR/staging_dir/bin_dir"
|
2010-12-06 18:49:37 +08:00
|
|
|
LOG_DIR_NAME="logs"
|
|
|
|
LOG_DIR="$DIR/$LOG_DIR_NAME"
|
2009-05-27 03:12:00 +08:00
|
|
|
|
2010-11-03 06:48:29 +08:00
|
|
|
die()
|
|
|
|
{
|
|
|
|
echo "$@"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2010-11-03 22:44:31 +08:00
|
|
|
usage()
|
|
|
|
{
|
|
|
|
echo "deptest.sh [OPTIONS] [PACKAGES]"
|
|
|
|
echo
|
|
|
|
echo "OPTIONS:"
|
|
|
|
echo " --lean Run a lean test. Do not clean the build directory for each"
|
|
|
|
echo " package test."
|
2010-11-03 23:18:53 +08:00
|
|
|
echo " --force Force a test, even if a success/blacklist stamp is available"
|
2010-11-04 02:48:03 +08:00
|
|
|
echo " -j X Number of make jobs"
|
2010-11-03 22:44:31 +08:00
|
|
|
echo
|
|
|
|
echo "PACKAGES are packages to test. If not specified, all installed packages"
|
|
|
|
echo "will be tested."
|
|
|
|
}
|
|
|
|
|
2010-11-04 02:48:03 +08:00
|
|
|
deptest_make()
|
|
|
|
{
|
|
|
|
local target="$1"
|
|
|
|
shift
|
|
|
|
local logfile="$1"
|
|
|
|
shift
|
|
|
|
make -j$nrjobs "$target" \
|
|
|
|
BUILD_DIR="$BUILD_DIR" \
|
|
|
|
BUILD_DIR_HOST="$BUILD_DIR_HOST" \
|
|
|
|
KERNEL_BUILD_DIR="$KERNEL_BUILD_DIR" \
|
|
|
|
BIN_DIR="$BIN_DIR" \
|
|
|
|
STAGING_DIR="$STAGING_DIR" \
|
|
|
|
STAGING_DIR_HOST="$STAGING_DIR_HOST" \
|
|
|
|
FORCE_HOST_INSTALL=1 \
|
|
|
|
V=99 "$@" >"$LOG_DIR/$logfile" 2>&1
|
|
|
|
}
|
|
|
|
|
|
|
|
clean_kernel_build_dir()
|
|
|
|
{
|
|
|
|
# delete everything, except the kernel build dir "linux-X.X.X"
|
|
|
|
(
|
|
|
|
cd "$KERNEL_BUILD_DIR" || die "Failed to enter kernel build dir"
|
|
|
|
for entry in *; do
|
|
|
|
[ -z "$(echo "$entry" | egrep -e '^linux-*.*.*$')" ] || continue
|
|
|
|
rm -rf "$entry" || die "Failed to clean kernel build dir"
|
|
|
|
done
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2010-12-09 00:08:14 +08:00
|
|
|
stamp_exists() # $1=stamp
|
|
|
|
{
|
|
|
|
[ -e "$1" -o -L "$1" ]
|
|
|
|
}
|
|
|
|
|
2010-11-03 20:41:28 +08:00
|
|
|
test_package() # $1=pkgname
|
|
|
|
{
|
|
|
|
local pkg="$1"
|
2010-11-03 22:44:31 +08:00
|
|
|
[ -n "$pkg" -a -z "$(echo "$pkg" | grep -e '/')" -a "$pkg" != "." -a "$pkg" != ".." ] || \
|
2010-11-03 20:49:38 +08:00
|
|
|
die "Package name \"$pkg\" contains illegal characters"
|
2010-11-03 20:41:28 +08:00
|
|
|
local SELECTED=
|
2010-11-03 05:57:03 +08:00
|
|
|
for conf in `grep CONFIG_PACKAGE tmp/.packagedeps | grep -E "[ /]$pkg\$" | sed -e 's,package-$(\(CONFIG_PACKAGE_.*\)).*,\1,'`; do
|
2010-11-03 20:41:28 +08:00
|
|
|
grep "$conf=" .config > /dev/null && SELECTED=1 && break
|
2010-11-03 05:57:03 +08:00
|
|
|
done
|
2010-11-03 20:41:28 +08:00
|
|
|
local STAMP_SUCCESS="$STAMP_DIR_SUCCESS/$pkg"
|
|
|
|
local STAMP_FAILED="$STAMP_DIR_FAILED/$pkg"
|
|
|
|
local STAMP_BLACKLIST="$STAMP_DIR_BLACKLIST/$pkg"
|
2010-11-03 06:36:32 +08:00
|
|
|
rm -f "$STAMP_FAILED"
|
2010-12-09 00:08:14 +08:00
|
|
|
stamp_exists "$STAMP_SUCCESS" && [ $force -eq 0 ] && return
|
2010-11-03 23:01:03 +08:00
|
|
|
rm -f "$STAMP_SUCCESS"
|
2010-11-03 05:57:03 +08:00
|
|
|
[ -n "$SELECTED" ] || {
|
|
|
|
echo "Package $pkg is not selected"
|
2010-11-03 20:41:28 +08:00
|
|
|
return
|
2010-11-03 05:57:03 +08:00
|
|
|
}
|
2010-12-09 00:08:14 +08:00
|
|
|
stamp_exists "$STAMP_BLACKLIST" && [ $force -eq 0 ] && {
|
2010-11-03 09:10:52 +08:00
|
|
|
echo "Package $pkg is blacklisted"
|
2010-11-03 20:41:28 +08:00
|
|
|
return
|
2010-11-03 09:10:52 +08:00
|
|
|
}
|
2010-11-03 05:57:03 +08:00
|
|
|
echo "Testing package $pkg..."
|
2010-11-04 02:48:03 +08:00
|
|
|
rm -rf "$STAGING_DIR" "$STAGING_DIR_HOST"
|
2010-11-03 05:57:03 +08:00
|
|
|
mkdir -p "$STAGING_DIR"
|
|
|
|
cp -al "$STAGING_DIR_HOST_TMPL" "$STAGING_DIR_HOST"
|
2010-11-04 02:48:03 +08:00
|
|
|
[ $lean_test -eq 0 ] && {
|
|
|
|
rm -rf "$BUILD_DIR" "$BUILD_DIR_HOST"
|
|
|
|
clean_kernel_build_dir
|
|
|
|
}
|
2010-11-03 22:44:31 +08:00
|
|
|
mkdir -p "$BUILD_DIR" "$BUILD_DIR_HOST"
|
2010-12-06 18:49:37 +08:00
|
|
|
local logfile="$(basename $pkg).log"
|
|
|
|
deptest_make "package/$pkg/compile" "$logfile"
|
2010-11-03 06:36:32 +08:00
|
|
|
if [ $? -eq 0 ]; then
|
2010-12-06 18:49:37 +08:00
|
|
|
( cd "$STAMP_DIR_SUCCESS"; ln -s "../$LOG_DIR_NAME/$logfile" "./$pkg" )
|
2010-11-03 06:36:32 +08:00
|
|
|
else
|
2010-12-06 18:49:37 +08:00
|
|
|
( cd "$STAMP_DIR_FAILED"; ln -s "../$LOG_DIR_NAME/$logfile" "./$pkg" )
|
2010-11-04 19:30:10 +08:00
|
|
|
echo "Building package $pkg FAILED"
|
2010-11-03 06:36:32 +08:00
|
|
|
fi
|
2010-11-03 20:41:28 +08:00
|
|
|
}
|
|
|
|
|
2010-11-03 22:44:31 +08:00
|
|
|
# parse commandline options
|
|
|
|
packages=
|
|
|
|
lean_test=0
|
2010-11-03 23:01:03 +08:00
|
|
|
force=0
|
2010-11-04 02:48:03 +08:00
|
|
|
nrjobs=1
|
2010-11-03 22:44:31 +08:00
|
|
|
while [ $# -ne 0 ]; do
|
|
|
|
case "$1" in
|
|
|
|
--help|-h)
|
|
|
|
usage
|
|
|
|
exit 0
|
|
|
|
;;
|
|
|
|
--lean)
|
|
|
|
lean_test=1
|
|
|
|
;;
|
2010-11-03 23:01:03 +08:00
|
|
|
--force)
|
|
|
|
force=1
|
|
|
|
;;
|
2010-11-04 02:48:03 +08:00
|
|
|
-j*)
|
|
|
|
if [ -n "${1:2}" ]; then
|
|
|
|
nrjobs="${1:2}"
|
|
|
|
else
|
|
|
|
shift
|
|
|
|
nrjobs="$1"
|
|
|
|
fi
|
|
|
|
;;
|
2010-11-03 22:44:31 +08:00
|
|
|
*)
|
|
|
|
packages="$packages $1"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
2010-11-03 20:41:28 +08:00
|
|
|
[ -f "$BASEDIR/include/toplevel.mk" ] || \
|
|
|
|
die "Error: Could not find buildsystem base directory"
|
|
|
|
[ -f "$BASEDIR/.config" ] || \
|
|
|
|
die "The buildsystem is not configured. Please run make menuconfig."
|
|
|
|
cd "$BASEDIR" || die "Failed to enter base directory"
|
|
|
|
|
2010-11-04 02:48:03 +08:00
|
|
|
mkdir -p "$STAMP_DIR_SUCCESS" "$STAMP_DIR_FAILED" "$STAMP_DIR_BLACKLIST" \
|
|
|
|
"$BIN_DIR" "$LOG_DIR"
|
|
|
|
|
|
|
|
bootstrap_deptest_make()
|
|
|
|
{
|
|
|
|
local target="$1"
|
|
|
|
shift
|
|
|
|
local logfile="bootstrap-deptest-$(echo "$target" | tr / -).log"
|
|
|
|
echo "deptest-make $target"
|
|
|
|
deptest_make "$target" "$logfile" "$@" || \
|
|
|
|
die "make $target failed, please check $logfile"
|
|
|
|
}
|
|
|
|
|
|
|
|
bootstrap_native_make()
|
|
|
|
{
|
|
|
|
local target="$1"
|
|
|
|
shift
|
|
|
|
local logfile="bootstrap-native-$(echo "$target" | tr / -).log"
|
|
|
|
echo "make $target"
|
|
|
|
make -j$nrjobs "$target" \
|
|
|
|
V=99 "$@" >"$LOG_DIR/$logfile" 2>&1 || \
|
|
|
|
die "make $target failed, please check $logfile"
|
|
|
|
}
|
2010-11-03 20:41:28 +08:00
|
|
|
|
|
|
|
[ -d "$STAGING_DIR_HOST_TMPL" ] || {
|
2010-11-04 02:48:03 +08:00
|
|
|
echo "Bootstrapping build environment..."
|
|
|
|
rm -rf "$STAGING_DIR" "$STAGING_DIR_HOST" "$BUILD_DIR" "$BUILD_DIR_HOST" "$KERNEL_BUILD_DIR"
|
|
|
|
mkdir -p "$STAGING_DIR" "$STAGING_DIR_HOST" \
|
|
|
|
"$BUILD_DIR" "$BUILD_DIR_HOST" "$KERNEL_BUILD_DIR"
|
|
|
|
bootstrap_native_make tools/install
|
|
|
|
bootstrap_native_make toolchain/install
|
|
|
|
bootstrap_deptest_make tools/install
|
|
|
|
bootstrap_deptest_make target/linux/install
|
|
|
|
cp -al "$STAGING_DIR_HOST" "$STAGING_DIR_HOST_TMPL"
|
|
|
|
rm -rf "$STAGING_DIR" "$STAGING_DIR_HOST" "$BUILD_DIR" "$BUILD_DIR_HOST"
|
|
|
|
echo "Build environment OK."
|
2010-11-03 20:41:28 +08:00
|
|
|
}
|
|
|
|
|
2010-11-03 22:44:31 +08:00
|
|
|
if [ -z "$packages" ]; then
|
2010-11-03 20:41:28 +08:00
|
|
|
# iterate over all packages
|
|
|
|
for pkg in `cat tmp/.packagedeps | grep CONFIG_PACKAGE | grep -v curdir | sed -e 's,.*[/=]\s*,,' | sort -u`; do
|
|
|
|
test_package "$pkg"
|
|
|
|
done
|
|
|
|
else
|
2010-11-03 22:44:31 +08:00
|
|
|
# only check the specified packages
|
|
|
|
for pkg in $packages; do
|
|
|
|
test_package "$pkg"
|
2010-11-03 20:41:28 +08:00
|
|
|
done
|
|
|
|
fi
|