X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=scripts%2Flttng-ust%2Fbuild.sh;h=7ce27392a3574fa99838fcb49693563ecf779512;hb=6871000cbd00b2dd074a3bd313e8dfba24c83ffc;hp=7341b0c63347581246859a193141babebb0f37be;hpb=0b93ba404150839c81cd046cf6ad35951fa01eb1;p=lttng-ci.git diff --git a/scripts/lttng-ust/build.sh b/scripts/lttng-ust/build.sh index 7341b0c..7ce2739 100755 --- a/scripts/lttng-ust/build.sh +++ b/scripts/lttng-ust/build.sh @@ -25,6 +25,8 @@ vercomp () { return 0 fi local IFS=. + # Ignore the shellcheck warning, we want splitting to happen based on IFS. + # shellcheck disable=SC2206 local i ver1=($1) ver2=($2) # fill empty fields in ver1 with zeros for ((i=${#ver1[@]}; i<${#ver2[@]}; i++)); do @@ -84,7 +86,7 @@ failed_configure() { # Required variables WORKSPACE=${WORKSPACE:-} -arch=${arch:-} +platform=${platform:-} conf=${conf:-} build=${build:-} cc=${cc:-} @@ -92,8 +94,21 @@ cc=${cc:-} # Controls if the tests are run LTTNG_UST_RUN_TESTS="${LTTNG_UST_RUN_TESTS:=yes}" +SRCDIR="$WORKSPACE/src/lttng-ust" +TMPDIR="$WORKSPACE/tmp" +PREFIX="/build" +LIBDIR="lib" + +# RHEL and SLES both use lib64 but don't bother shipping a default autoconf +# site config that matches this. +if [[ ( -f /etc/redhat-release || -f /etc/SuSE-release ) && ( "$(uname -m)" == "x86_64" ) ]]; then + LIBDIR_ARCH="${LIBDIR}64" +else + LIBDIR_ARCH="$LIBDIR" +fi + DEPS_INC="$WORKSPACE/deps/build/include" -DEPS_LIB="$WORKSPACE/deps/build/lib" +DEPS_LIB="$WORKSPACE/deps/build/$LIBDIR_ARCH" DEPS_PKGCONFIG="$DEPS_LIB/pkgconfig" #DEPS_BIN="$WORKSPACE/deps/build/bin" #DEPS_JAVA="$WORKSPACE/deps/build/share/java" @@ -103,10 +118,6 @@ export PKG_CONFIG_PATH="$DEPS_PKGCONFIG" export CPPFLAGS="-I$DEPS_INC" export LDFLAGS="-L$DEPS_LIB" -SRCDIR="$WORKSPACE/src/lttng-ust" -TMPDIR="$WORKSPACE/tmp" -PREFIX="/build" - # Create tmp directory rm -rf "$TMPDIR" mkdir -p "$TMPDIR" @@ -145,7 +156,7 @@ if [ "x${CC:-}" != "x" ]; then fi # Set platform variables -case "$arch" in +case "$platform" in freebsd*) export MAKE=gmake export TAR=tar @@ -184,7 +195,7 @@ PACKAGE_VERSION=${PACKAGE_VERSION//\-pre*/} # Gerrit will trigger build on FreeBSD regardless of the branch, exit # successfuly when the version is < 2.13. -if [[ $arch == freebsd* ]] && verlt "$PACKAGE_VERSION" "2.13"; then +if [[ $platform == freebsd* ]] && verlt "$PACKAGE_VERSION" "2.13"; then mkdir -p "$WORKSPACE/tap/no-log" echo "1..1" > "$WORKSPACE/tap/no-log/tests.log" echo "ok 1 - FreeBSD build unsupported in < 2.13" >> "$WORKSPACE/tap/no-log/tests.log" @@ -193,7 +204,7 @@ fi # Set configure options and environment variables for each build # configuration. -CONF_OPTS=("--prefix=$PREFIX") +CONF_OPTS=("--prefix=$PREFIX" "--libdir=$PREFIX/$LIBDIR_ARCH") case "$conf" in static) echo "Static lib only configuration" @@ -222,6 +233,11 @@ debug-rcu) *) echo "Standard configuration" + + # Something is broken in docbook-xml on yocto + if [[ "$platform" = yocto* ]]; then + CONF_OPTS+=("--disable-man-pages") + fi ;; esac @@ -326,10 +342,10 @@ $MAKE clean # Cleanup rpath in executables and shared libraries #find "$WORKSPACE/$PREFIX/bin" -type f -perm -0500 -exec chrpath --delete {} \; -find "$WORKSPACE/$PREFIX/lib" -name "*.so" -exec chrpath --delete {} \; +find "$WORKSPACE/$PREFIX/$LIBDIR_ARCH" -name "*.so" -exec chrpath --delete {} \; # Remove libtool .la files -find "$WORKSPACE/$PREFIX/lib" -name "*.la" -exec rm -f {} \; +find "$WORKSPACE/$PREFIX/$LIBDIR_ARCH" -name "*.la" -exec rm -f {} \; # Exit with failure if any of the tests failed exit $failed_tests