summaryrefslogtreecommitdiffstats
path: root/configure
diff options
context:
space:
mode:
Diffstat (limited to 'configure')
-rwxr-xr-xconfigure3156
1 files changed, 3156 insertions, 0 deletions
diff --git a/configure b/configure
new file mode 100755
index 00000000..4b69712c
--- /dev/null
+++ b/configure
@@ -0,0 +1,3156 @@
+#!/bin/sh
+# The purpose of this script is to check for all external tools, headers, and
+# libraries VBox OSE depends on.
+
+#
+# Copyright (C) 2006-2023 Oracle and/or its affiliates.
+#
+# This file is part of VirtualBox base platform packages, as
+# available from https://www.virtualbox.org.
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation, in version 3 of the
+# License.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, see <https://www.gnu.org/licenses>.
+#
+# SPDX-License-Identifier: GPL-3.0-only
+#
+
+LC_ALL=C
+export LC_ALL
+
+# append some extra paths
+PATH="$PATH:/opt/gnome/bin"
+# Solaris (order of paths important for tr, grep, sed to work)
+PATH="/usr/xpg4/bin:$PATH:/usr/local/bin:/usr/sfw/bin:/usr/ccs/bin"
+ORGPATH=$PATH
+
+# Wrapper for ancient /usr/bin/which on darwin that always returns 0
+which_wrapper()
+{
+ if [ -z "$have_ancient_which" ]; then
+ if which /bin/___cErTaINly_a_nOn_eXisTing_fIle___ 2> /dev/null > /dev/null; then
+ have_ancient_which="yes"
+ else
+ have_ancient_which="no"
+ fi
+ fi
+ if [ "$have_ancient_which" = "yes" ]; then
+ retval=`which $* 2>/dev/null`
+ echo "$retval"
+ test -n "$retval" -a -x "$retval"
+ unset retval
+ else
+ which $* 2> /dev/null
+ fi
+}
+
+OS=`uname -s | sed -e 's/GNU\/Linux/Linux/g' | tr '[:upper:]' '[:lower:]'`
+case "$OS" in
+ linux)
+ ;;
+ darwin)
+ ;;
+ freebsd)
+ ;;
+ netbsd)
+ ;;
+ sunos)
+ OS='solaris'
+ ;;
+ haiku)
+ ;;
+ *)
+ echo "Cannot determine OS!"
+ exit 1
+ ;;
+esac
+
+#
+# Defaults
+#
+OSE=1
+ODIR="`pwd`/"
+ODIR_OVERRIDE=0
+OUT_BASE_PATH=""
+OUT_BASE_PATH_OVERRIDE=0
+SETUP_WINE=
+ONLY_ADDITIONS=0
+TARGET_MACHINE=""
+TARGET_CPU=""
+WITH_XPCOM=1
+WITH_PYTHON=1
+WITH_JAVA=1
+WITH_VMMRAW=1
+WITH_LIBIDL=1
+WITH_QT5=1
+WITH_SDL=1
+WITH_SDL_TTF=1
+WITH_X11=1
+WITH_ALSA=1
+WITH_PULSE=1
+WITH_DBUS=1
+WITH_DEVMAPPER=1
+WITH_KMODS=1
+WITH_OPENGL=1
+WITH_HARDENING=1
+WITH_UDPTUNNEL=1
+WITH_VDE=0
+WITH_VNC=0
+WITH_EXTPACK=1
+WITH_DOCS=1
+WITH_LIBVPX=1
+WITH_LIBOGG=0
+WITH_LIBVORBIS=0
+WITH_LIBTPMS=1
+WITH_LIBLZMA=1
+BUILD_LIBXML2=
+BUILD_LIBCURL=
+BUILD_LIBSSL=
+BUILD_LIBVPX=
+BUILD_LIBTPMS=
+BUILD_LIBLZMA=
+PASSIVE_MESA=0
+CC="gcc"
+CC32=""
+CC64=""
+CXX="g++"
+CXX32=""
+CXX64=""
+YASM="yasm"
+IASL="iasl"
+XSLTPROC="xsltproc"
+INCCRYPTO=""
+LIBCRYPTO="-lssl -lcrypto"
+LIBPTHREAD="-lpthread"
+LIBCAP="-lcap"
+GSOAP=""
+GSOAP_IMPORT=""
+INCX11="/usr/local/include"
+LIBX11="-L/usr/X11R6/lib -L/usr/X11R6/lib64 -L/usr/local/lib -lXext -lX11"
+LIBXCURSOR="-lXcursor"
+LIBXMU="-lXmu"
+LIBXINERAMA="-lXinerama"
+LIBXRANDR="-lXrandr"
+MAKESELF="makeself"
+MESA="-lGL"
+INCZ=""
+LIBZ="-lz"
+INCLZF="/usr/include/liblzf"
+LIBLZF="-llzf"
+INCVNCSERVER=""
+LIBVNCSERVER="-lvncserver"
+INCDEVMAPPER=""
+LIBDEVMAPPER="-ldevmapper"
+CXX_FLAGS=""
+if [ "$OS" = "freebsd" ]; then
+ INCCURL="-I/usr/local/include"
+ LIBCURL="-L/usr/local/lib -lcurl"
+ INCPULSE="-I/usr/local/include"
+ LIBPULSE="-L/usr/local/lib"
+ INCPNG="-I/usr/local/include"
+ LIBPNG="-L/usr/local/lib -lpng"
+else
+ INCCURL=""
+ LIBCURL="-lcurl"
+ INCPNG=""
+ LIBPNG="-lpng"
+fi
+INCVPX=""
+LIBVPX="-lvpx"
+PKGCONFIG="`which_wrapper pkg-config`"
+PYTHONDIR="/usr /usr/local"
+QT5DIR="/usr/lib/qt5 /usr/share/qt5 /usr/lib64/qt5 /usr /usr/local"
+QT5DIR_PKGCONFIG=1
+QT5MAJ=5
+QT5MIN=9
+KBUILDDIR="`cd \`dirname $0\`; pwd`/kBuild"
+DEVDIR="`cd \`dirname $0\`; pwd`/tools"
+if [ -d "/lib/modules/`uname -r`/build" ]; then
+ LINUX="/lib/modules/`uname -r`/build"
+elif [ "`echo /lib/modules/*`" != "/lib/modules/*" ]; then
+ # Get the most recent kernel headers if none match the current kernel.
+ for i in /lib/modules/*; do
+ if [ -r "$i/build" ]; then
+ LINUX="$i/build"
+ fi
+ done
+fi
+if [ -z "$LINUX" ]; then
+ LINUX="/usr/src/linux"
+fi
+KCHMVIEWER="kchmviewer"
+LOG="configure.log"
+CNF="AutoConfig.kmk"
+ENV="env.sh"
+BUILD_TYPE="release"
+# the restricting tool is ar (mri mode).
+INVALID_CHARS="[^A-Za-z0-9/\\$:._-]"
+
+if (cd `dirname $0`; pwd)|grep -q "$INVALID_CHARS"; then
+ echo "Error: VBox base path contains invalid characters!"
+ exit 1
+fi
+
+# Posix /bin/sh isn't supporting echo -n. Use printf instead.
+ECHO_N="printf"
+
+
+cleanup()
+{
+ rm -f $ODIR.tmp_src.cc $ODIR.tmp_src.c $ODIR.tmp_out $ODIR.test_execute.log
+ [ "$OS" = "darwin" ] && rm -rf $ODIR.tmp_out.dSYM
+ true
+}
+
+fail()
+{
+ if [ -z "$nofatal" -o "x$1" != "x" ]; then
+ cleanup
+ rm -f $ENV
+ echo "Check $LOG for details"
+ exit 1
+ fi
+}
+
+log()
+{
+ echo "$1"
+ echo "$1" >> $LOG
+}
+
+log_success()
+{
+ if [ -n "$1" ]; then $ECHO_N "$1, "; fi
+ echo "OK."
+ echo "$1" >> $LOG
+ echo >> $LOG
+ echo >> $LOG
+}
+
+log_failure()
+{
+ echo
+ echo " ** $1!"
+ echo "** $1!" >> $LOG
+ echo >> $LOG
+}
+
+cnf_append()
+{
+ printf "%-30s := %s\n" "$1" "$2" >> $CNF
+}
+
+strip_l()
+{
+ echo "$1"|$KBUILD_SED 's|-l\([^ ]\+\)|\1|g; s|^-[^l][^ ]*||g; s| -[^l][^ ]*||g; s|^ ||; s| *$||g'
+}
+
+strip_L()
+{
+ if [ "$OS" = "darwin" ]; then
+ echo "$1"|$KBUILD_SED 's|-F\([^ ]\+\)|\1|g; s|^-[^F][^ ]*||g; s| -[^F][^ ]*||g; s|^ ||; s| *$||g'
+ else
+ echo "$1"|$KBUILD_SED 's|-L\([^ ]\+\)|\1|g; s|^-[^L][^ ]*||g; s| -[^L][^ ]*||g; s|^ ||; s| *$||g'
+ fi
+}
+
+L_to_PATH()
+{
+echo $1 >> $LOG
+ if [ "$OS" = "darwin" ]; then
+ echo "$1"|$KBUILD_SED 's|-F\([^ ]\+\)|\1|g; s|^-[^F][^ ]*||g; s| -[^F][^ ]*||g; s|^ ||; s| *$||g; s| |:|g'
+ else
+ echo "$1"|$KBUILD_SED 's|-L\([^ ]\+\)|\1|g; s|^-[^L][^ ]*||g; s| -[^L][^ ]*||g; s|^ ||; s| *$||g; s| |:|g'
+ fi
+}
+
+strip_I()
+{
+ echo "$1"|$KBUILD_SED 's|-I\([^ ]\+\)|\1|g; s|^-[^I][^ ]*||g; s| -[^I][^ ]*||g; s|^ ||; s| *$||g'
+}
+
+prefix_I()
+{
+ echo "$1"|$KBUILD_SED 's|^\/|-I/|g; s| \/| -I/|g'
+}
+
+check_avail()
+{
+ if [ -z "$1" ]; then
+ log_failure "$2 is empty"
+ fail $3
+ return 1
+ elif which_wrapper $1 > /dev/null; then
+ return 0
+ else
+ log_failure "$1 (variable $2) not found"
+ fail $3
+ return 1
+ fi
+}
+
+
+# Prepare a test
+test_header()
+{
+ echo "***** Checking $1 *****" >> $LOG
+ $ECHO_N "Checking for $1: "
+}
+
+
+# Compile a test
+# $1 compile flags/libs
+# $2 library name
+# $3 package name
+# $4 if this argument is 'nofatal', don't abort
+test_compile()
+{
+ echo "compiling the following source file:" >> $LOG
+ cat $ODIR.tmp_src.cc >> $LOG
+ echo "using the following command line:" >> $LOG
+ echo "$CXX $CXX_FLAGS -fPIC -g -O -Wall -o $ODIR.tmp_out $ODIR.tmp_src.cc $1" >> $LOG
+ $CXX $CXX_FLAGS -fPIC -g -O -Wall -o $ODIR.tmp_out $ODIR.tmp_src.cc $1 >> $LOG 2>&1
+ if [ $? -ne 0 ]; then
+ if [ -z "$4" ]; then
+ echo
+ echo " $2 not found at $1 or $3 headers not found"
+ echo " Check the file $LOG for detailed error information."
+ fail
+ else
+ echo >> $LOG
+ echo >> $LOG
+ fi
+ return 1
+ fi
+ return 0
+}
+
+
+# Execute a compiled test binary
+test_execute()
+{
+ echo "executing the binary" >> $LOG
+ $ODIR.tmp_out > $ODIR.test_execute.log 2>&1
+ rc=$?
+ cat $ODIR.test_execute.log | tee -a $LOG
+ if [ $rc -ne 0 ]; then
+ fail $1
+ return 1
+ fi
+ echo >> $LOG
+ echo >> $LOG
+ return 0
+}
+
+
+# Execute a compiled test binary
+test_execute_path()
+{
+ ## LD_LIBRARY_PATH to set.
+ local_path="${1}"
+ ## Set this to non-empty to make this test non-fatal.
+ local_nofail="${2}"
+ echo "executing the binary (LD_LIBRARY_PATH=$1:$LD_LIBRARY_PATH)" >> $LOG
+ LD_LIBRARY_PATH="${local_path}:$LD_LIBRARY_PATH" $ODIR.tmp_out > $ODIR.test_execute.log 2>&1
+ rc=$?
+ cat $ODIR.test_execute.log | tee -a $LOG
+ if [ $rc -ne 0 ]; then
+ test -z "${local_nofail}" && fail
+ echo >> $LOG
+ echo >> $LOG
+ return 1
+ fi
+ echo >> $LOG
+ echo >> $LOG
+ return 0
+}
+
+
+#
+# Check for OS, MACHINE, CPU
+#
+check_environment()
+{
+ test_header environment
+ BUILD_CPU=`uname -m`
+ [ "$OS" = "solaris" ] && BUILD_CPU=`isainfo | cut -f 1 -d ' '`
+ case "$BUILD_CPU" in
+ i[3456789]86|x86|i86pc|BePC)
+ BUILD_MACHINE='x86'
+ LIB='lib'
+ ;;
+ x86_64|amd64)
+ BUILD_MACHINE='amd64'
+ BUILD_CPU='blend'
+ if [ "$OS" != "solaris" ]; then
+ # on AMD64 systems, 64bit libs are usually located in /usr/lib64
+ # see http://www.pathname.com/fhs/pub/fhs-2.3.html#LIB64
+ LIB='lib64'
+ else
+ # Solaris doesn't seem to subscribe to fhs, libs are usually in
+ # a '64' subdirectory of the standard 'lib' dirs while some 64-bit
+ # alternative binaries can be found in 'amd64' subdirs of the 'bin'
+ # ones. So, in order to find the right stuff (esp. sdl-config) we'll
+ # have to make sure the */bin/amd64 dirs are searched before the */bin
+ # ones. (The sed has some sideeffects, but they shouldn't harm us...)
+ echo "64-bit Solaris detected, hacking the PATH" >> $LOG
+ echo "old PATH: $PATH" >> $LOG
+ PATH=`echo ":$PATH:" | sed -e 's,\(:[^:]*/bin\):,\1/amd64:\1:,g' \
+ -e 's/^:*//' -e 's/:*$//g' -e 's/::*/:/g' `
+ export PATH
+ echo "new PATH: $PATH" >> $LOG
+ LIB='lib/64'
+ fi
+ ;;
+ sparc64|sparcv9)
+ BUILD_MACHINE='sparc64'
+ BUILD_CPU='blend'
+ ;;
+ sparc32|sparc|sparcv8|sparcv7|sparcv8e)
+ BUILD_MACHINE='sparc32'
+ BUILD_CPU='blend'
+ ;;
+ *)
+ log_failure "Cannot determine system"
+ exit 1
+ ;;
+ esac
+ [ -z "$TARGET_MACHINE" ] && TARGET_MACHINE=$BUILD_MACHINE
+ [ -z "$TARGET_CPU" ] && TARGET_CPU=$BUILD_CPU
+ DEVDIR_BIN="$DEVDIR/$OS.$BUILD_MACHINE/bin"
+ log_success "Determined build machine: $OS.$BUILD_MACHINE, target machine: $OS.$TARGET_MACHINE"
+
+ echo "KBUILD_HOST=\"$OS\"" >> $ENV
+ echo "KBUILD_HOST_ARCH=\"$BUILD_MACHINE\"" >> $ENV
+ echo "KBUILD_TARGET=\"$OS\"" >> $ENV
+ echo "KBUILD_TARGET_ARCH=\"$TARGET_MACHINE\"" >> $ENV
+ echo "KBUILD_TARGET_CPU=\"$TARGET_CPU\"" >> $ENV
+ echo "KBUILD_TYPE=\"$BUILD_TYPE\"" >> $ENV
+ echo 'export KBUILD_HOST KBUILD_HOST_ARCH KBUILD_TARGET KBUILD_TARGET_ARCH KBUILD_TARGET_CPU KBUILD_TYPE' >> $ENV
+
+ # obsolete legacy stuff:
+ echo '' >> $ENV
+ echo "# Legacy - do not use:" >> $ENV
+ echo 'BUILD_PLATFORM="$KBUILD_HOST"' >> $ENV
+ echo 'BUILD_PLATFORM_ARCH="$KBUILD_HOST_ARCH"' >> $ENV
+ echo 'BUILD_TARGET="$KBUILD_TARGET"' >> $ENV
+ echo 'BUILD_TARGET_ARCH="$KBUILD_TARGET_ARCH"' >> $ENV
+ echo 'BUILD_TARGET_CPU="$KBUILD_TARGET_CPU"' >> $ENV
+ echo 'BUILD_TYPE="$KBUILD_TYPE"' >> $ENV
+ echo 'export BUILD_PLATFORM BUILD_PLATFORM_ARCH BUILD_TARGET BUILD_TARGET_ARCH BUILD_TARGET_CPU BUILD_TYPE' >> $ENV
+ echo '' >> $ENV
+}
+
+#
+# Check for gcc with version >= 3.2.
+# We depend on a working gcc, if we fail terminate in every case.
+#
+check_gcc()
+{
+ test_header gcc
+ if check_avail "$CC" CC really; then
+ cc_ver=`$CC -dumpfullversion 2>/dev/null`
+ if [ $? -ne 0 ]; then
+ cc_ver=`$CC -dumpversion 2>/dev/null`
+ fi
+ if [ $? -ne 0 ]; then
+ log_failure "cannot execute '$CC -dumpversion'"
+ fail really
+ fi
+ if check_avail "$CXX" CXX really; then
+ cxx_ver=`$CXX -dumpfullversion 2>/dev/null`
+ if [ $? -ne 0 ]; then
+ cxx_ver=`$CXX -dumpversion 2>/dev/null`
+ fi
+ if [ $? -ne 0 ]; then
+ log_failure "cannot execute '$CXX -dumpversion'"
+ fail really
+ fi
+ cc_maj=`echo $cc_ver|cut -d. -f1`
+ cc_min=`echo $cc_ver|cut -d. -f2`
+ if [ "x$cc_ver" != "x$cxx_ver" ]; then
+ log_failure "gcc version $cc_ver does not match g++ version $cxx_ver"
+ fail really
+ elif [ $cc_maj -eq 4 -a $cc_min -eq 0 -a "$OS" = "darwin" ]; then
+ log_success "found version $cc_ver"
+ # gcc-4.0 is allowed for Darwin only
+ elif [ $cc_maj -eq 4 -a $cc_min -eq 2 -a "$OS" = "freebsd" ]; then
+ log_success "found version $cc_ver"
+ # gcc-4.2 is allowed for FreeBSD only
+ elif [ $cc_maj -lt 4 \
+ -o \( $cc_maj -eq 4 -a $cc_min -lt 4 -a "$OS" != "darwin" \) \
+ -o \( $cc_maj -eq 4 -a $cc_min -lt 2 -a "$OS" = "darwin" \) ]; then
+ log_failure "gcc version $cc_maj.$cc_min found, expected gcc 4.x or later"
+ fail really
+ else
+ log_success "found version $cc_ver"
+ fi
+ if [ "$BUILD_MACHINE" = "amd64" ]; then
+ [ -z "$CC32" ] && CC32="$CC -m32"
+ [ -z "$CXX32" ] && CXX32="$CXX -m32"
+ else
+ [ -z "$CC32" ] && CC32="$CC"
+ [ -z "$CXX32" ] && CXX32="$CXX"
+ fi
+ if [ "$BUILD_MACHINE" = "x86" -a "$TARGET_MACHINE" = "amd64" ]; then
+ [ -z "$CC64" ] && CC64="$CC -m64"
+ [ -z "$CXX64" ] && CXX64="$CXX -m64"
+ fi
+ if [ "$TARGET_MACHINE" = "amd64" -a $WITH_VMMRAW -eq 0 ]; then
+ CC32="undefined"
+ CXX32="undefined"
+ fi
+ if [ "$CC" != "gcc" ]; then
+ cnf_append "TOOL_GCC3_CC" "$CC"
+ cnf_append "TOOL_GCC3_AS" "$CC"
+ cnf_append "TOOL_GCC3_LD" "$CC"
+ cnf_append "TOOL_GXX3_CC" "$CC"
+ cnf_append "TOOL_GXX3_AS" "$CC"
+ fi
+ if [ "$CXX" != "g++" ]; then
+ cnf_append "TOOL_GCC3_CXX" "$CXX"
+ cnf_append "TOOL_GXX3_CXX" "$CXX"
+ cnf_append "TOOL_GXX3_LD" "$CXX"
+ fi
+ if [ "$CC32" != "gcc -m32" -a "$CC32" != "undefined" ]; then
+ cnf_append "TOOL_GCC32_CC" "$CC32"
+ cnf_append "TOOL_GCC32_AS" "$CC32"
+ cnf_append "TOOL_GCC32_LD" "$CC32"
+ cnf_append "TOOL_GXX32_CC" "$CC32"
+ cnf_append "TOOL_GXX32_AS" "$CC32"
+ fi
+ if [ "$CXX32" != "g++ -m32" -a "$CXX32" != "undefined" ]; then
+ cnf_append "TOOL_GCC32_CXX" "$CXX32"
+ cnf_append "TOOL_GXX32_CXX" "$CXX32"
+ cnf_append "TOOL_GXX32_LD" "$CXX32"
+ fi
+ # this isn't not necessary, there is not such tool.
+ if [ -n "$CC64" ]; then
+ cnf_append "TOOL_GCC64_CC" "$CC64"
+ cnf_append "TOOL_GCC64_AS" "$CC64"
+ cnf_append "TOOL_GCC64_LD" "$CC64"
+ cnf_append "TOOL_GXX64_CC" "$CC64"
+ cnf_append "TOOL_GXX64_AS" "$CC64"
+ fi
+ if [ -n "$CXX64" ]; then
+ cnf_append "TOOL_GCC64_CXX" "$CXX64"
+ cnf_append "TOOL_GXX64_CXX" "$CXX64"
+ cnf_append "TOOL_GXX64_LD" "$CXX64"
+ fi
+ if [ "$CC" != "gcc" ]; then
+ if [ -n "$CC64" ]; then
+ cnf_append "TOOL_Bs3Gcc64Elf64_CC" "$CC64"
+ else
+ cnf_append "TOOL_Bs3Gcc64Elf64_CC" "$CC"
+ fi
+ if [ -n "$CXX64" ]; then
+ cnf_append "TOOL_Bs3Gcc64Elf64_CXX" "$CXX64"
+ else
+ cnf_append "TOOL_Bs3Gcc64Elf64_CXX" "$CXX"
+ fi
+ fi
+ # Solaris sports a 32-bit gcc/g++.
+ if [ "$OS" = "solaris" -a "$BUILD_MACHINE" = "amd64" ]; then
+ [ "$CC" = "gcc" ] && CC="gcc -m64"
+ [ "$CXX" = "g++" ] && CXX="g++ -m64"
+ fi
+ fi
+ fi
+}
+
+
+#
+# Check for the OpenWatcom compiler, needed for compiling the BIOS
+#
+# If the system has Open Watcom installed, WATCOM will be set in the
+# environment. If the user has her/his own Open Watcom install it will be
+# pointed to by on the command line, which will set the WATCOM variable.
+# The only exception is detecting OpenWatcom in tools/common/openwatcom.
+#
+check_open_watcom()
+{
+ test_header "Open Watcom"
+
+ if [ -z "$WATCOM" ]; then
+ WATCOM=`/bin/ls -rd1 $DEVDIR/common/openwatcom/* 2> /dev/null | head -1`
+ if [ -z "$WATCOM" ]; then
+ if [ $OSE -eq 0 -a $OS = "linux" ]; then
+ log_failure "Open Watcom was not found"
+ exit 1
+ fi
+ log_failure "Open Watcom was not found, using alternative BIOS sources"
+ cnf_append "VBOX_WITH_OPEN_WATCOM" ""
+ return 0;
+ fi
+ fi
+
+ case "$OS" in
+ "darwin") wc_bin="binosx";; # ??
+ "dos") wc_bin="binw";;
+ "freebsd") wc_bin="binfbsd";; # ??
+ "linux") wc_bin="binl";;
+ "netbsd") wc_bin="binnbsd";; # ??
+ "solaris") wc_bin="binsol";; # ??
+ "os2") wc_bin="binp";;
+ "win") wc_bin="binnt";;
+ *) wc_bin="binl";;
+ esac
+
+ # Check that the tools we use are there.
+ for prog in wasm wcc wlink;
+ do
+ if [ ! -f "$WATCOM/$wc_bin/$prog" ]; then
+ log_failure "$WATCOM/$wc_bin/$prog does not exist or is not a regular file."
+ fail
+ fi
+ done
+
+ # Use WASM to get the version.
+ wasm_ver=`$WATCOM/$wc_bin/wasm -? 2>&1 | sed -e '1!d' -e 's/Open Watcom Assembler Version *//'`
+ if [ -z "$wasm_ver" ]; then
+ log_failure "$WATCOM/$wc_bin/wasm -? did not produce the expected response"
+ fail
+ fi
+ log_success "found version $wasm_ver"
+ cnf_append "PATH_TOOL_OPENWATCOM" "$WATCOM"
+ cnf_append "VBOX_WITH_OPEN_WATCOM" "1"
+
+ unset wasm_ver
+ unset wc_wasm
+ unset wc_bin
+}
+
+
+#
+# Check for yasm, needed to compile assembler files
+#
+check_yasm()
+{
+ test_header yasm
+ if check_avail "$YASM" YASM; then
+ yasm_ver=`$YASM --version|grep "^yasm"|sed 's+^yasm \(.*\)+\1+'`
+ if [ $? -ne 0 ]; then
+ log_failure "yasm not found"
+ fail
+ else
+ yasm_maj=`echo $yasm_ver|cut -d. -f1`
+ yasm_min=`echo $yasm_ver|cut -d. -f2`
+ yasm_rev=`echo $yasm_ver|cut -d. -f3`
+ yasm_ver_mul=`expr $yasm_maj \* 10000 + $yasm_min \* 100 + $yasm_rev`
+ if [ $yasm_ver_mul -lt 10300 ]; then
+ log_failure "found version $yasm_ver, expected at least 1.3.0"
+ fail
+ else
+ [ "$YASM" != "yasm" ] && cnf_append "PATH_TOOL_YASM" "`dirname $YASM`"
+ log_success "found version $yasm_ver"
+ fi
+ fi
+ fi
+}
+
+
+#
+# Check for the iasl ACPI compiler, needed to compile vbox.dsl
+#
+check_iasl()
+{
+ test_header iasl
+ if check_avail "$IASL" IASL; then
+ iasl_ver=`$IASL|grep "ASL.*version"|sed 's+^ASL.*version \([0-9]*\).*+\1+'`
+ if [ $? -ne 0 ]; then
+ log_failure "iasl not found"
+ fail
+ else
+ log_success "found version $iasl_ver"
+ cnf_append "VBOX_IASLCMD" "`which_wrapper $IASL`"
+ fi
+ fi
+}
+
+
+#
+# Check for xsltproc, needed by Main
+#
+check_xsltproc()
+{
+ if [ -n "$BUILD_LIBXSLT" ]; then
+ return 0;
+ fi
+ test_header xslt
+ if check_avail "$XSLTPROC" XSLTPROC; then
+ xsltproc_ver=`$XSLTPROC --version`
+ if [ $? -ne 0 ]; then
+ log_failure "xsltproc not found"
+ fail
+ else
+ log_success "found"
+ cnf_append "VBOX_XSLTPROC" "`which_wrapper $XSLTPROC`"
+ fi
+ fi
+}
+
+
+#
+# Check for libxml2, needed by the Runtime.
+# 2.6.24 is known to NOT work, 2.6.26 is known to work (there is no 2.6.25 release)
+#
+check_libxml2()
+{
+ if [ -z "$BUILD_LIBXML2" ]; then
+ test_header libxml2
+ if which_wrapper pkg-config > /dev/null; then
+ libxml2_ver=`pkg-config libxml-2.0 --modversion 2>> $LOG`
+ if [ $? -ne 0 ]; then
+ log_failure "libxml2 not found"
+ fail
+ else
+ FLGXML2=`pkg-config libxml-2.0 --cflags`
+ INCXML2=`strip_I "$FLGXML2"`
+ LIBXML2=`pkg-config libxml-2.0 --libs`
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <libxml/xmlversion.h>
+extern "C" int main(void)
+{
+ printf("found version %s", LIBXML_DOTTED_VERSION);
+#if LIBXML_VERSION >= 20626
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 2.6.26 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ [ -n "$INCXML2" ] && I_INCXML2=`prefix_I "$INCXML2"`
+ if test_compile "$LIBXML2 $LIBPTHREAD $I_INCXML2" xml2 xml2; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibXml2_DEFS" "_REENTRANT" ## @todo get defines from --cflags
+ cnf_append "SDK_VBoxLibXml2_INCS" "$INCXML2"
+ cnf_append "SDK_VBoxLibXml2_LIBS" "`strip_l "$LIBXML2"`"
+ fi
+ fi
+ fi
+ elif which_wrapper xml2-config; then
+ libxml2_ver=`xml2-config --version`
+ if [ $? -ne 0 ]; then
+ log_failure "xml2-config not found"
+ fail
+ else
+ log_success "found version $libxml2_ver"
+ FLGXML2=`xml2-config --cflags`
+ INCXML2=`strip_I "$FLGXML2"`
+ LIBXML2=`xml2-config --libs`
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <libxml/xmlversion.h>
+extern "C" int main(void)
+{
+ printf("found version %s", LIBXML_DOTTED_VERSION);
+#if LIBXML_VERSION >= 20626
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 2.6.26 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ [ -n "$INCXML2" ] && I_INCXML2=`prefix_I "$INCXML2"`
+ if test_compile "$LIBXML2 $LIBPTHREAD $I_INCXML2" xml2 xml2; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibXml2_DEFS" "_REENTRANT" ## @todo get defines from --cflags
+ cnf_append "SDK_VBoxLibXml2_INCS" "$INCXML2"
+ cnf_append "SDK_VBoxLibXml2_LIBS" "`strip_l "$LIBXML2"`"
+ fi
+ fi
+ fi
+ else
+ log_failure "neither pkg-config nor xml2-config found"
+ fail
+ fi
+ fi
+}
+
+
+#
+# Check for libIDL, needed by xpcom
+#
+check_libidl()
+{
+ test_header libIDL
+
+ if which_wrapper libIDL-config-2 > /dev/null; then
+ libidl_ver=`libIDL-config-2 --version`
+ if [ $? -ne 0 ]; then
+ log_failure "libIDL-config-2 not working"
+ fail
+ else
+ log_success "found version $libidl_ver"
+ cnf_append "VBOX_LIBIDL_CONFIG" \
+ "PKG_CONFIG_PATH=`libIDL-config-2 --prefix`/$LIB/pkgconfig `which_wrapper libIDL-config-2`"
+ fi
+ elif check_avail "libIDL-config" libIDL-config; then
+ libidl_ver=`libIDL-config --version`
+ if [ $? -ne 0 ]; then
+ log_failure "libIDL-config not working"
+ fail
+ else
+ log_success "found version $libidl_ver"
+ cnf_append "VBOX_LIBIDL_CONFIG" "`which_wrapper libIDL-config`"
+ fi
+ fi
+}
+
+
+#
+# Check for libdevmapper, needed by the VBoxVolInfo
+#
+check_libdevmapper()
+{
+ test_header libdevmapper
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+extern "C" {
+#define private
+#include <libdevmapper.h>
+int main()
+{
+ char version[80];
+
+ if (!dm_get_library_version(version, sizeof(version)))
+ {
+ printf("dm_get_library_version() failed.\n");
+ return 1;
+ }
+
+ const char* v=version;
+ unsigned int major = 0, minor = 0, micro = 0;
+
+ for (; *v !='.' && *v != '\0'; v++) major = major*10 + *v-'0';
+ if (*v == '.') v++;
+ for (; *v !='.' && *v != '\0'; v++) minor = minor*10 + *v-'0';
+ if (*v == '.') v++;
+ for (; *v !='.' && *v != '\0'; v++) micro = micro*10 + *v-'0';
+
+ printf("found version %s", version);
+ if (major*10000 + minor*100 + micro >= 10200)
+ {
+ printf(", OK.\n");
+ return 0;
+ }
+ else
+ {
+ printf(", expected version 1.02 or higher\n");
+ return 1;
+ }
+}
+}
+EOF
+ if test_compile "$LIBDEVMAPPER $INCDEVMAPPER" libdevmapper libdevmapper; then
+ if test_execute; then
+ cnf_append "VBOX_WITH_DEVMAPPER" "1"
+ fi
+ fi
+}
+
+
+#
+# Check for openssl, needed for RDP and S3
+#
+check_ssl()
+{
+ if [ -z "$BUILD_LIBSSL" ]; then
+ test_header ssl
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <openssl/opensslv.h>
+#include <openssl/ssl.h>
+extern "C" int main(void)
+{
+ printf("found version %s", OPENSSL_VERSION_TEXT);
+ SSL_library_init();
+#if OPENSSL_VERSION_NUMBER >= 0x10001000
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 1.0.1 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ if test_compile "$INCCRYPTO $LIBCRYPTO" libcrypto openssl; then
+ if test_execute nofatal; then
+ cnf_append "SDK_VBoxOpenSslStatic_INCS" "`strip_I "$INCCRYPTO"`"
+ cnf_append "SDK_VBoxOpenSslStatic_LIBS" "`strip_l "$LIBCRYPTO"`"
+ cnf_append "SDK_VBoxOpenSslBldProg_LIBS" "`strip_l "$LIBCRYPTO"`"
+ fi
+ fi
+ fi
+}
+
+
+#
+# Check for pthread, needed by VBoxSVC, frontends, ...
+#
+check_pthread()
+{
+ test_header pthread
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <pthread.h>
+extern "C" int main(void)
+{
+ pthread_mutex_t mutex;
+ if (pthread_mutex_init(&mutex, NULL)) {
+ printf("pthread_mutex_init() failed\n");
+ return 1;
+ }
+ if (pthread_mutex_lock(&mutex)) {
+ printf("pthread_mutex_lock() failed\n");
+ return 1;
+ }
+ if (pthread_mutex_unlock(&mutex)) {
+ printf("pthread_mutex_unlock() failed\n");
+ return 1;
+ }
+ printf("found, OK.\n");
+}
+EOF
+ if test_compile $LIBPTHREAD pthread pthread; then
+ if test_execute; then
+ cnf_append "LIB_PTHREAD" "`strip_l "$LIBPTHREAD"`"
+ fi
+ fi
+}
+
+
+#
+# Check for zlib, needed by VBoxSVC, Runtime, ...
+#
+check_z()
+{
+ test_header zlib
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <zlib.h>
+extern "C" int main(void)
+{
+ printf("found version %s", ZLIB_VERSION);
+#if ZLIB_VERNUM >= 0x1210
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 1.2.1 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ [ -n "$INCZ" ] && I_INCZ=`prefix_I "$INCZ"`
+ if test_compile "$LIBZ $I_INCZ" zlib zlib; then
+ if test_execute; then
+ echo "if1of (\$(KBUILD_TARGET),darwin freebsd haiku linux)" >> $CNF
+ cnf_append " SDK_VBoxZlib_LIBS" "`strip_l "$LIBZ"`"
+ cnf_append " SDK_VBoxZlib_INCS" "$INCZ"
+ echo "endif" >> $CNF
+ fi
+ fi
+}
+
+
+#
+# Check for liblzf, needed by VBoxSVC, Runtime, ...
+#
+check_lzf()
+{
+ test_header liblzf
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <lzf.h>
+extern "C" int main(void)
+{
+ printf("found LZF API version %u.%u", LZF_VERSION >> 8, LZF_VERSION & 0xff);
+#if LZF_VERSION >= 0x0105
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 1.5 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ [ -n "$INCLZF" ] && I_INCLZF=`prefix_I "$INCLZF"`
+ if test_compile "$LIBLZF $I_INCLZF" liblzf liblzf nofatal; then
+ if test_execute; then
+ echo "if1of (\$(KBUILD_TARGET),darwin freebsd haiku linux)" >> $CNF
+ cnf_append " SDK_VBoxLzf_LIBS" "`strip_l "$LIBLZF"`"
+ cnf_append " SDK_VBoxLzf_INCS" "$INCLZF"
+ echo "endif" >> $CNF
+ fi
+ else
+ echo "not found -- builing liblzf from in-tree code."
+ fi
+}
+
+
+#
+# Check for libpng, needed by kchmviewer
+#
+check_png()
+{
+ test_header libpng
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <png.h>
+extern "C" int main(void)
+{
+ printf("found version %s", PNG_LIBPNG_VER_STRING);
+#if PNG_LIBPNG_VER >= 10205
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 1.2.5 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ [ -n "$INCPNG" ] && I_INCPNG=`prefix_I "$INCPNG"`
+ if test_compile "$LIBPNG $I_INCPNG" libpng libpng; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibPng_LIBS" "`strip_l "$LIBPNG"`"
+ cnf_append "SDK_VBoxLibPng_INCS" "$INCPNG"
+ fi
+ fi
+}
+
+#
+# Check for libvncserver, needed for VNC in OSE
+#
+check_vncserver()
+{
+ test_header libvncserver
+ cat > $ODIR.tmp_src.cc <<EOF
+#include <cstdio>
+#include <rfb/rfbconfig.h>
+
+extern "C" int main()
+{
+ const char* v=LIBVNCSERVER_VERSION;
+ unsigned int major = 0, minor = 0, micro = 0;
+
+ for (; *v !='.' && *v != '\0'; v++) major = major*10 + *v-'0';
+ if (*v == '.') v++;
+ for (; *v !='.' && *v != '\0'; v++) minor = minor*10 + *v-'0';
+ if (*v == '.') v++;
+ for (; *v !='.' && *v != '\0'; v++) micro = micro*10 + *v-'0';
+
+ printf("found version %s", LIBVNCSERVER_PACKAGE_VERSION);
+ if (major*10000 + minor*100 + micro >= 900)
+ {
+ printf(", OK.\n");
+ return 0;
+ }
+ else
+ {
+ printf(", expected version 0.9 or higher\n");
+ return 1;
+ }
+}
+EOF
+ if test_compile "$LIBVNCSERVER $INCVNCSERVER" libvncserver libvncserver; then
+ if test_execute; then
+ cnf_append "VBOX_WITH_EXTPACK_VNC" "1"
+ fi
+ fi
+}
+
+#
+# Check for libcurl, needed by S3
+#
+check_curl()
+{
+ if [ -z "$BUILD_LIBCURL" ]; then
+ test_header libcurl
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <curl/curl.h>
+extern "C" int main(void)
+{
+ printf("found version %s", LIBCURL_VERSION);
+#if 10000*LIBCURL_VERSION_MAJOR + 100*LIBCURL_VERSION_MINOR + LIBCURL_VERSION_PATCH >= 71901
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 7.19.1 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ [ -n "$INCCURL" ] && I_INCCURL=`prefix_I "$INCCURL"`
+ if test_compile "$LIBCURL $I_INCCURL" libcurl libcurl; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibCurl_LIBS" "`strip_l "$LIBCURL"`"
+ cnf_append "SDK_VBoxLibCurl_INCS" "$INCCURL"
+ fi
+ fi
+ fi
+}
+
+
+#
+# Check for pam, needed by VRDPAuth
+# Version 79 was introduced in 9/2005, do we support older versions?
+# Debian/sarge uses 76
+# OpenSUSE comes with 0.99.xxx where they changed the versioning scheme.
+#
+check_pam()
+{
+ test_header pam
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <security/pam_appl.h>
+extern "C" int main(void)
+{
+ printf("found version %d", __LIBPAM_VERSION);
+ if (__LIBPAM_VERSION >= 76)
+ {
+ printf(", OK.\n");
+ return 0;
+ }
+ else
+ {
+ printf(", expected version 76 or higher\n");
+ return 1;
+ }
+}
+EOF
+ if test_compile "-lpam" pam pam nofatal; then
+ if test_execute nofatal; then
+ return 0;
+ fi
+ fi
+ echo "pam0.x not found"
+ test_header linux_pam
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <security/pam_appl.h>
+extern "C" int main(void)
+{
+ printf("found version %d.%d", __LINUX_PAM__, __LINUX_PAM_MINOR__);
+ if (__LINUX_PAM__ >= 1)
+ {
+ printf(", OK.\n");
+ return 0;
+ }
+ else
+ {
+ printf(", expected version 1.0 or higher\n");
+ return 1;
+ }
+}
+EOF
+ if test_compile "-lpam" pam pam; then
+ test_execute
+ fi
+}
+
+
+#
+# Check for the SDL library, needed by VBoxSDL and VirtualBox
+# We depend at least on version 1.2.7
+#
+check_sdl()
+{
+ test_header SDL
+ if [ "$OS" = "darwin" ]; then
+ if [ -f "/System/Library/Frameworks/SDL.framework/SDL" ]; then
+ PATH_SDK_LIBSDL="/System/Library/Frameworks/SDL.framework"
+ elif [ -f "/Library/Frameworks/SDL.framework/SDL" ]; then
+ PATH_SDK_LIBSDL="/Library/Frameworks/SDL.framework"
+ fi
+ if [ -n "$PATH_SDK_LIBSDL" ]; then
+ foundsdl=1
+ INCSDL="$PATH_SDK_LIBSDL/Headers"
+ FLDSDL="-framework SDL"
+ else
+ log_failure "SDL framework not found"
+ fail
+ fi
+ else
+ if which_wrapper sdl-config > /dev/null; then
+ FLGSDL=`sdl-config --cflags`
+ INCSDL=`strip_I "$FLGSDL"`
+ LIBSDL=`sdl-config --libs`
+ LIBSDLMAIN="-lSDLmain"
+ FLDSDL=
+ foundsdl=1
+ fi
+ fi
+ [ "$OS" = "linux" -o "$OS" = "darwin" -o "$OS" = "solaris" ] && LIBSDLMAIN=""
+ if [ -n "$foundsdl" ]; then
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <SDL.h>
+#include <SDL_main.h>
+#undef main
+extern "C" int main(int argc, char** argv)
+{
+ printf("found version %d.%d.%d",
+ SDL_MAJOR_VERSION, SDL_MINOR_VERSION, SDL_PATCHLEVEL);
+#if SDL_VERSION_ATLEAST(1,2,7)
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 1.2.7 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ [ -n "$INCSDL" ] && I_INCSDL=`prefix_I "$INCSDL"`
+ if test_compile "$LIBSDL $LIBSDLMAIN $I_INCSDL $FLDSDL" SDL SDL; then
+ if test_execute; then
+ cnf_append "LIB_SDK_LIBSDL_SDL" "`strip_l "$LIBSDL"`"
+ cnf_append "SDK_LIBSDL_LIBPATH" "`strip_L "$LIBSDL"`"
+ cnf_append "LIB_SDK_LIBSDL_SDLMAIN" "`strip_l "$LIBSDLMAIN"`"
+ [ -n "$INCSDL" ] && cnf_append "SDK_LIBSDL_INCS" "$INCSDL"
+ [ -n "$FLDSDL" ] && cnf_append "SDK_LIBSDL_LDFLAGS" "$FLDSDL"
+ fi
+ fi
+ else
+ log_failure "SDL not found (can be disabled using --disable-sdl)"
+ fail
+ fi
+}
+
+
+#
+# Check for the SDL_ttf library, needed by VBoxSDL (secure label)
+#
+check_sdl_ttf()
+{
+ test_header SDL_ttf
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <SDL_ttf.h>
+#ifndef SDL_TTF_MAJOR_VERSION
+#define SDL_TTF_MAJOR_VERSION TTF_MAJOR_VERSION
+#define SDL_TTF_MINOR_VERSION TTF_MINOR_VERSION
+#define SDL_TTF_PATCHLEVEL TTF_PATCHLEVEL
+#endif
+extern "C" int main(void)
+{
+ printf("found version %d.%d.%d",
+ SDL_TTF_MAJOR_VERSION, SDL_TTF_MINOR_VERSION, SDL_TTF_PATCHLEVEL);
+#if 10000*SDL_TTF_MAJOR_VERSION + 100*SDL_TTF_MINOR_VERSION + SDL_TTF_PATCHLEVEL >= 20006
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 2.0.6 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ if test_compile "-lSDL_ttf $I_INCSDL" SDL_ttf SDL_ttf nofatal; then
+ test_execute nofatal || \
+ cnf_append "VBOX_WITH_SECURELABEL" ""
+ else
+ echo "not found -- disabling VBoxSDL secure label."
+ cnf_append "VBOX_WITH_SECURELABEL" ""
+ fi
+}
+
+
+#
+# Check for libasound, needed by the ALSA audio backend
+#
+check_alsa()
+{
+ test_header ALSA
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <alsa/asoundlib.h>
+extern "C" int main(void)
+{
+ printf("found version %d.%d.%d",
+ SND_LIB_MAJOR, SND_LIB_MINOR, SND_LIB_SUBMINOR);
+#if 10000*SND_LIB_MAJOR + 100*SND_LIB_MINOR + SND_LIB_SUBMINOR >= 10014
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 1.0.14 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ if test_compile "-lasound" asound asound; then
+ test_execute
+ fi
+}
+
+
+#
+# Check for PulseAudio
+#
+check_pulse()
+{
+ test_header "PulseAudio"
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <pulse/version.h>
+extern "C" int main(void)
+{
+ printf("found version %s API version %d", pa_get_headers_version(), PA_API_VERSION);
+#if PA_API_VERSION >= 9
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 0.9.0 (API version 9) or higher\n");
+ return 1;
+#endif
+}
+EOF
+ if test_compile "$INCPULSE $LIBPULSE -lpulse" pulse pulse nofatal; then
+ if test_execute nofatal; then
+ cnf_append "VBOX_WITH_AUDIO_PULSE" "1"
+ else
+ cnf_append "VBOX_WITH_AUDIO_PULSE" ""
+ fi
+ else
+ cnf_append "VBOX_WITH_AUDIO_PULSE" ""
+ fi
+}
+
+
+#
+# Check for the X libraries (Xext, X11)
+#
+check_x()
+{
+ test_header "X libraries"
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <X11/Xlib.h>
+extern "C" int main(void)
+{
+ Display *dpy;
+ int scrn_num;
+ Screen *scrn;
+ Window win;
+
+ dpy = XOpenDisplay(NULL);
+ scrn_num = DefaultScreen(dpy);
+ scrn = ScreenOfDisplay(dpy, scrn_num);
+ win = XCreateWindow(dpy, RootWindowOfScreen(scrn), 0, 0, 100, 100,
+ 0, 16, InputOutput, CopyFromParent, 0, NULL);
+ XDestroyWindow(dpy, win);
+ XCloseDisplay(dpy);
+}
+EOF
+ [ -n "$INCX11" ] && I_INCX11=`prefix_I "$INCX11"`
+ if test_compile "$LIBX11 $I_INCX11" Xlibs Xlibs; then
+ log_success "found"
+ fi
+}
+
+
+#
+# Check for the Xcursor library, needed by VBoxSDL.
+#
+check_xcursor()
+{
+ test_header Xcursor
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <X11/Xlib.h>
+#include <X11/Xcursor/Xcursor.h>
+extern "C" int main(void)
+{
+ XcursorImage *cursor = XcursorImageCreate (10, 10);
+ XcursorImageDestroy(cursor);
+ return 0;
+}
+EOF
+ [ -n "$INCX11" ] && I_INCX11=`prefix_I "$INCX11"`
+ if test_compile "$LIBX11 $LIBXCURSOR $I_INCX11" Xcursor Xcursor; then
+ log_success "found"
+ cnf_append "VBOX_XCURSOR_LIBS" "`strip_l "$LIBXCURSOR"`"
+ fi
+}
+
+
+#
+# Check for the Xinerama library, needed by the Qt GUI
+#
+check_xinerama()
+{
+ test_header Xinerama
+ cat > $ODIR.tmp_src.cc << EOF
+#include <X11/Xlib.h>
+#include <X11/extensions/Xinerama.h>
+extern "C" int main(void)
+{
+ Display *dpy;
+ Bool flag;
+ dpy = XOpenDisplay(NULL);
+ if (dpy)
+ {
+ flag = XineramaIsActive(dpy);
+ XCloseDisplay(dpy);
+ }
+}
+EOF
+ [ -n "$INCX11" ] && I_INCX11=`prefix_I "$INCX11"`
+ if test_compile "$LIBX11 $LIBXINERAMA $I_INCX11" Xinerama Xinerama; then
+ log_success "found"
+ fi
+}
+
+
+#
+# Check for the XRandR library, needed by the Qt GUI
+#
+check_xrandr()
+{
+ test_header Xrandr
+ cat > $ODIR.tmp_src.cc << EOF
+#include <X11/Xlib.h>
+#include <X11/extensions/Xrandr.h>
+extern "C" int main(void)
+{
+ Display *dpy;
+ Bool flag;
+ int major, minor;
+ dpy = XOpenDisplay(NULL);
+ if (dpy)
+ {
+ flag = XRRQueryVersion(dpy, &major, &minor);
+ XCloseDisplay(dpy);
+ }
+}
+EOF
+ [ -n "$INCX11" ] && I_INCX11=`prefix_I "$INCX11"`
+ if test_compile "$LIBX11 $LIBXRANDR $I_INCX11" Xrandr Xrandr; then
+ log_success "found"
+ fi
+}
+
+
+#
+# Check for OpenGL
+#
+check_opengl()
+{
+ # On darwin this is a on/off decision only
+ if [ "$OS" = "darwin" ]; then
+ test_header "OpenGL support"
+ echo "enabled"
+ else
+ check_xmu
+ check_mesa
+ fi
+}
+
+
+#
+# Check for the Xmu library, needed by OpenGL
+#
+check_xmu()
+{
+ test_header Xmu
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <X11/Xatom.h>
+#include <X11/Xlib.h>
+#include <X11/Xutil.h>
+#include <X11/Xmu/StdCmap.h>
+extern "C" int main(void)
+{
+ Display *dpy;
+ int scrn_num;
+ Screen *scrn;
+
+ dpy = XOpenDisplay(NULL);
+ if (dpy)
+ {
+ scrn_num = DefaultScreen(dpy);
+ scrn = ScreenOfDisplay(dpy, scrn_num);
+ Status status = XmuLookupStandardColormap(dpy, RootWindowOfScreen(scrn), 0,
+ 24, XA_RGB_DEFAULT_MAP, False, True);
+ printf("Status = %x\n", status);
+ XCloseDisplay(dpy);
+ }
+ return 0;
+}
+EOF
+ [ -n "$INCX11" ] && I_INCX11=`prefix_I "$INCX11"`
+ if test_compile "$LIBX11 $LIBXMU $I_INCX11" Xmu Xmu; then
+ log_success "found"
+ cnf_append "VBOX_XMU_LIBS" "`strip_l "$LIBXMU"`"
+ fi
+}
+
+#
+# Check for Mesa, needed by OpenGL
+#
+check_mesa()
+{
+ test_header "Mesa / GLU"
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <X11/Xlib.h>
+#include <GL/glx.h>
+#include <GL/glu.h>
+extern "C" int main(void)
+{
+ Display *dpy;
+ int major, minor;
+
+ dpy = XOpenDisplay(NULL);
+ if (dpy)
+ {
+ Bool glx_version = glXQueryVersion(dpy, &major, &minor);
+ XCloseDisplay(dpy);
+ if (glx_version)
+ {
+ printf("found version %u.%u, OK.\n", major, minor);
+ return 0;
+ }
+ }
+ printf("found (inactive), OK.\n");
+ return 0;
+}
+EOF
+ [ -n "$INCX11" ] && I_INCX11=`prefix_I "$INCX11"`
+ if test_compile "$LIBX11 $MESA $I_INCX11" Mesa Mesa; then
+ [ $PASSIVE_MESA -eq 1 ] && unset DISPLAY
+ test_execute
+ fi
+}
+
+
+#
+# Check for the Qt5 library, needed by the VirtualBox frontend
+#
+# Currently not fatal.
+#
+check_qt5()
+{
+ foundqt5=
+ test_header Qt5
+ cat > $ODIR.tmp_src.cc << EOF
+#include <QtGlobal>
+extern "C" int main(void)
+{
+EOF
+ echo "#if QT_VERSION >= $(($QT5MAJ*65536+$QT5MIN*256))" >> $ODIR.tmp_src.cc
+ cat >> $ODIR.tmp_src.cc << EOF
+ return 0;
+#else
+ return 1;
+#endif
+}
+EOF
+ if [ "$OS" = "darwin" ]; then
+ # First check if there is the internal version of Qt. If yes nothing else
+ # has to be done.
+ QT_INTERNAL=`/bin/ls -rd1 $DEVDIR/$BUILD_TARGET.$BUILD_PLATFORM_ARCH/qt/* 2> /dev/null`
+ for t in $QT_INTERNAL; do
+ if [ -f "$t/Frameworks/QtCoreVBox.framework/QtCoreVBox" ]; then
+ cnf_append "VBOX_WITH_ORACLE_QT" "1"
+ log_success "use internal version"
+ return
+ fi
+ done
+ # Now try the user provided directory and some of the standard directories.
+ QT_TRIES="$QT5DIR /System/Library /Library"
+ for t in $QT_TRIES; do
+ if [ -f "$t/Frameworks/QtCore.framework/QtCore" -o -f "$t/clang_64/lib/QtCore.framework/QtCore" ]; then
+ PATH_SDK_QT5="$t"
+ foundqt5=1
+ break
+ fi
+ done
+ # Add the necessary params for building the test application
+ if [ -n "$PATH_SDK_QT5" ]; then
+ if [ -f "$t/clang_64/lib/QtCore.framework/QtCore" ]; then
+ INCQT5=-I$PATH_SDK_QT5/clang_64/lib/QtCore.framework/Headers
+ LIBQT5=-F$PATH_SDK_QT5/clang_64/lib
+ SDKQT5=$PATH_SDK_QT5/clang_64
+ else
+ INCQT5=-I$PATH_SDK_QT5/Frameworks/QtCore.framework/Headers
+ LIBQT5=-F$PATH_SDK_QT5/Frameworks
+ SDKQT5=$PATH_SDK_QT5
+ fi
+ FLGQT5="-framework QtCore -std=c++11 -Wl,-rpath,`L_to_PATH "$LIBQT5"`"
+ else
+ log_failure "Qt5 framework not found (can be disabled using --disable-qt)"
+ fail
+ fi
+ else # !darwin
+ if [ $QT5DIR_PKGCONFIG -eq 1 ]; then
+ # Default is to use pkg-config:
+ if which_wrapper pkg-config > /dev/null; then
+ qt5_ver=`pkg-config Qt5Core --modversion 2>> $LOG`
+ if [ $? -eq 0 ]; then
+ echo "(Qt5 from pkg-config)" >> $LOG
+ FLGQT5=`pkg-config Qt5Core --cflags`
+ # gcc 4.8 is able to compile with C++11 (see also VBOX_GCC_std in Config.kmk)
+ [ $(($cc_maj * 100 + $cc_min)) -ge 408 ] && FLGQT5="$FLGQT5 -std=c++11"
+ INCQT5=`strip_I "$FLGQT5"`
+ LIBDIR5=`pkg-config Qt5Core --variable=libdir`
+ LIBQT5=`pkg-config Qt5Core Qt5Gui --libs`
+ LIBQT5="-L$LIBDIR5 $LIBQT5"
+ TOOLQT5=`pkg-config Qt5Core --variable=prefix`
+ TOOLQT5BIN=`pkg-config Qt5Core --variable=host_bins`
+ if test_compile "$LIBQT5 $LIBPTHREAD $FLGQT5" qt5 qt5 nofatal; then
+ test_execute_path "`L_to_PATH "$LIBQT5"`" nofatal && foundqt5=3 # pkg-config
+ fi
+ fi
+ else
+ log_failure "pkg-config not found"
+ fail
+ fi
+ fi
+ if [ -z "$foundqt5" ]; then
+ # Do it the old way (e.g. user has specified QT5DIR):
+ for q in $QT5DIR "$DEVDIR/linux.$TARGET_MACHINE"/qt/v5.*; do
+ echo "(Qt5 from '$q')" >> $LOG
+ INCQT5="$q/include $q/include/QtCore"
+ FLGQT5="-DQT_SHARED -std=c++11"
+ I_INCQT5=`prefix_I "$INCQT5"`
+ LIBQT5="-L$q/lib -lQt5CoreVBox -lQt5GuiVBox"
+ TOOLQT5="$q"
+ if test_compile "$LIBQT5 $LIBPTHREAD $I_INCQT5 $FLGQT5" qt5 qt5 nofatal &&
+ test_execute_path "`L_to_PATH "$LIBQT5"`" nofatal; then
+ foundqt5=2 # internal
+ break;
+ fi
+ LIBQT5="-L$q/lib -lQt5Core -lQt5Gui"
+ if test_compile "$LIBQT5 $LIBPTHREAD $I_INCQT5 $FLGQT5" qt5 qt5 nofatal &&
+ test_execute_path "`L_to_PATH "$LIBQT5"`" nofatal; then
+ foundqt5=1 # no pkg-config, Qt directory
+ break;
+ fi
+ done
+ fi
+ fi
+ if [ -n "$foundqt5" ]; then
+ # We decided which version of Qt to use, now enforce the version requirement:
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <QtGlobal>
+extern "C" int main(void)
+{
+ printf("found version %s", QT_VERSION_STR);
+EOF
+ echo "#if QT_VERSION >= $(($QT5MAJ*65536+$QT5MIN*256))" >> $ODIR.tmp_src.cc
+ cat >> $ODIR.tmp_src.cc << EOF
+ printf(", OK.\n");
+ return 0;
+#else
+EOF
+echo " printf(\", expected version $QT5MAJ.$QT5MIN or higher\\\\n\");" >> $ODIR.tmp_src.cc
+ cat >> $ODIR.tmp_src.cc << EOF
+ return 1;
+#endif
+}
+EOF
+ [ -n "$INCQT5" ] && I_INCQT5=`prefix_I "$INCQT5"`
+ if test_compile "$LIBQT5 $LIBPTHREAD $I_INCQT5 $FLGQT5" qt5 qt5 nofatal; then
+ if test_execute_path "`L_to_PATH "$LIBQT5"`"; then
+ if [ "$OS" = "darwin" ]; then
+ # Successful build & run the test application so add the necessary
+ # params to AutoConfig.kmk:
+ cnf_append "PATH_SDK_QT5_INC" "`L_to_PATH "$LIBQT5"`"
+ cnf_append "PATH_SDK_QT5_LIB" "`L_to_PATH "$LIBQT5"`"
+ cnf_append "PATH_SDK_QT5" "$SDKQT5"
+ # Check for the moc tool in the Qt directory found & some standard
+ # directories.
+ for q in $PATH_SDK_QT5 $PATH_SDK_QT5/clang_64 /usr /Developer/Tools/Qt; do
+ if which_wrapper "$q/bin/moc" > /dev/null; then
+ cnf_append "PATH_TOOL_QT5_BIN" "$q/bin"
+ fi
+ done
+ else
+ # Strip .../QtCore as we add components ourself:
+ INCQT5=`echo "$INCQT5"|$KBUILD_SED 's|\([^ ]*\)/QtCore|\1|g; s| $||g'`
+ # store only the first path, remove all other paths
+ # most likely pkg-config gave us -I/usr/include/qt5 -I/usr/include/qt5/QtCore
+ INCQT5=`echo "$INCQT5"|$KBUILD_SED 's|\([^ ]*\) .*|\1|'`
+ cnf_append "VBOX_PATH_QT_LIB" "`strip_L "$LIBQT5"`"
+ cnf_append "PATH_SDK_QT5_INC" "$INCQT5"
+ # This is not quite right since the qt libpath does not have to be first...
+ cnf_append "PATH_SDK_QT5_LIB" '$'"(firstword `strip_L "$LIBQT5"`)"
+ if [ "$foundqt5" = "2" ]; then
+ cnf_append "VBOX_WITH_ORACLE_QT" "1"
+ fi
+ if [ "$foundqt5" != "3" ]; then
+ TOOLQT5BIN="$TOOLQT5/bin"
+ fi
+ test_header "Qt5 devtools"
+ # Try it with a suffix, some platforms use that
+ if which_wrapper "$TOOLQT5BIN/moc-qt5" > /dev/null; then
+ QT5BINSUFF="-qt5"
+ else
+ QT5BINSUFF=""
+ fi
+ moc_ver=`$TOOLQT5BIN/moc$QT5BINSUFF -v 2>&1|sed 's+^.*(Qt \(.*\))+\1+'`
+ if [ $? -ne 0 ]; then
+ log_failure "moc$QT5BINSUFF not working"
+ fail
+ else
+ log_success "found version $moc_ver"
+ cnf_append "VBOX_PATH_QT" "$TOOLQT5"
+ cnf_append "PATH_SDK_QT5" "$TOOLQT5"
+ cnf_append "PATH_TOOL_QT5_BIN" "$TOOLQT5BIN"
+ [ -n "$QT5BINSUFF" ] && cnf_append "TOOL_QT5_BIN_SUFF" "$QT5BINSUFF"
+ fi
+ fi
+ fi
+ else
+ log_failure "qt5 not working"
+ fail
+ fi
+ else
+ log_failure "qt5 not found"
+ fail
+ fi
+}
+
+
+#
+# Check for libvpx
+#
+check_vpx()
+{
+ if [ -z "$BUILD_LIBVPX" ]; then
+ test_header libvpx
+ if which_wrapper pkg-config > /dev/null; then
+ libvpx_ver=`pkg-config vpx --modversion 2>> $LOG`
+ if [ $? -eq 0 ]; then
+ FLGVPX=`pkg-config vpx --cflags`
+ INCVPX=`strip_I "$FLGVPX"`
+ LIBVPX=`pkg-config vpx --libs`
+ fi
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <vpx/vpx_codec.h>
+extern "C" int main(void)
+{
+ int version = vpx_codec_version();
+ int verMajor = VPX_VERSION_MAJOR(version);
+ int verMinor = VPX_VERSION_MINOR(version);
+ int verPatch = VPX_VERSION_PATCH(version);
+ printf("found version %d.%d.%d", verMajor, verMinor, verPatch);
+ if ( verMajor == 1 && verMinor >= 0
+ || verMajor == 0 && verMinor == 9 && verPatch >= 5)
+ {
+ printf(", OK.\n");
+ return 0;
+ }
+ else
+ {
+ printf(", expected version 0.9.5 or higher\n");
+ return 1;
+ }
+}
+EOF
+ [ -n "$INCVPX" ] && I_INCVPX=`prefix_I "$INCVPX"`
+ if test_compile "$LIBVPX $I_INCVPX" vpx vpx; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibVpx_INCS" "$INCVPX"
+ cnf_append "SDK_VBoxLibVpx_LIBS" "`strip_l "$LIBVPX"`"
+ fi
+ fi
+ fi
+ fi
+}
+
+
+#
+# Check for libtpms
+#
+check_libtpms()
+{
+ if [ -z "$BUILD_LIBTPMS" ]; then
+ test_header libtpms
+ if which_wrapper pkg-config > /dev/null; then
+ libtpms_ver=`pkg-config libtpms --modversion 2>> $LOG`
+ if [ $? -eq 0 ]; then
+ FLGTPMS=`pkg-config libtpms --cflags`
+ INCTPMS=`strip_I "$FLGTPMS"`
+ LIBTPMS=`pkg-config libtpms --libs`
+ fi
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <libtpms/tpm_library.h>
+extern "C" int main(void)
+{
+ TPMLIB_MainInit();
+ printf("found, OK.\n");
+}
+EOF
+ [ -n "$INCTPMS" ] && I_INCTPMS=`prefix_I "$INCTPMS"`
+ if test_compile "$LIBTPMS $I_INCTPMS" libtpms libtpms nofatal; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibTpms_INCS" "$INCTPMS"
+ cnf_append "SDK_VBoxLibTpms_LIBS" "`strip_l "$LIBTPMS"`"
+ fi
+ else
+ echo "not found -- building libtpms from in-tree code."
+ fi
+ fi
+ fi
+}
+
+
+#
+# Check for liblzma
+#
+check_liblzma()
+{
+ if [ -z "$BUILD_LIBLZMA" ]; then
+ test_header liblzma
+ if which_wrapper pkg-config > /dev/null; then
+ liblzma_ver=`pkg-config liblzma --modversion 2>> $LOG`
+ if [ $? -eq 0 ]; then
+ FLGLZMA=`pkg-config liblzma --cflags`
+ INCLZMA=`strip_I "$FLGLZMA"`
+ LIBLZMA=`pkg-config liblzma --libs`
+ fi
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <lzma.h>
+extern "C" int main(void)
+{
+ lzma_stream strm = LZMA_STREAM_INIT;
+ uint32_t preset;
+ lzma_ret ret = lzma_easy_encoder(&strm, preset, LZMA_CHECK_CRC64);
+ printf("found, OK.\n");
+}
+EOF
+ [ -n "$INCLZMA" ] && I_INCLZMA=`prefix_I "$INCLZMA"`
+ if test_compile "$LIBLZMA $I_INCLZMA" liblzma liblzma nofatal; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibLzma_INCS" "$INCLZMA"
+ cnf_append "SDK_VBoxLibLzma_LIBS" "`strip_l "$LIBLZMA"`"
+ fi
+ else
+ echo "not found -- building liblzma from in-tree code."
+ fi
+ fi
+ fi
+}
+
+
+#
+# Check for libvorbis
+#
+check_libvorbis()
+{
+ test_header libvorbis
+ if which_wrapper pkg-config > /dev/null; then
+ libvorbis_ver=`pkg-config vorbis --modversion 2>> $LOG`
+ if [ $? -eq 0 ]; then
+ FLGVRB=`pkg-config vorbis --cflags`
+ INCVRB=`strip_I "$FLGVRB"`
+ LIBVRB=`pkg-config vorbis --libs`
+ fi
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <vorbis/vorbisenc.h>
+extern "C" int main(void)
+{
+ vorbis_info v;
+ vorbis_info_init(&v);
+ printf("found, OK.\n");
+ return 0;
+}
+EOF
+ [ -n "$INCVRB" ] && I_INCVRB=`prefix_I "$INCVRB"`
+ if test_compile "$LIBVRB $I_INCVRB" vorbis vorbis nofatal; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibVorbis_INCS" "$INCVRB"
+ cnf_append "SDK_VBoxLibVorbis_LIBS" "`strip_l "$LIBVRB"`"
+ fi
+ else
+ echo "not found -- building libvorbis from in-tree code."
+ fi
+ fi
+}
+
+
+#
+# Check for libogg
+#
+check_libogg()
+{
+ test_header libogg
+ if which_wrapper pkg-config > /dev/null; then
+ libogg_ver=`pkg-config ogg --modversion 2>> $LOG`
+ if [ $? -eq 0 ]; then
+ FLGOGG=`pkg-config ogg --cflags`
+ INCOGG=`strip_I "$FLGOGG"`
+ LIBOGG=`pkg-config ogg --libs`
+ fi
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <ogg/ogg.h>
+extern "C" int main(void)
+{
+ oggpack_buffer o;
+ oggpack_get_buffer(&o);
+ printf("found, OK.\n");
+ return 0;
+}
+EOF
+ [ -n "$INCOGG" ] && I_INCVRB=`prefix_I "$INCOGG"`
+ if test_compile "$LIBOGG $I_INCOGG" ogg ogg nofatal; then
+ if test_execute; then
+ cnf_append "SDK_VBoxLibOgg_INCS" "$INCOGG"
+ cnf_append "SDK_VBoxLibOgg_LIBS" "`strip_l "$LIBOGG"`"
+ fi
+ else
+ echo "not found -- building libogg from in-tree code."
+ fi
+ fi
+}
+
+
+#
+# Check whether static libstdc++ is installed. This library is required
+# for the Linux guest additions.
+#
+check_staticlibstdcxx()
+{
+ test_header "static stc++ library"
+ libstdcxx=`$CXX -print-file-name=libstdc++.a`
+ cat > $ODIR.tmp_src.cc << EOF
+#include <string>
+
+extern "C" int main(void)
+{
+ std::string s = "test";
+ return 0;
+}
+EOF
+ if test_compile "$libstdcxx" libstdc++ libstdc++; then
+ log_success "found"
+ fi
+}
+
+
+#
+# Check for Linux sources
+#
+check_linux()
+{
+ test_header "Linux kernel sources"
+ cat > $ODIR.tmp_src.c << EOF
+#include <linux/version.h>
+int printf(const char *format, ...);
+int main(void)
+{
+ printf("found version %d.%d.%d", LINUX_VERSION_CODE / 65536,
+ (LINUX_VERSION_CODE % 65536) / 256,
+ LINUX_VERSION_CODE % 256);
+#if LINUX_VERSION_CODE > KERNEL_VERSION(2,4,0)
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 2.4.0 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ echo "compiling the following source file:" >> $LOG
+ cat $ODIR.tmp_src.c >> $LOG
+ echo "using the following command line:" >> $LOG
+ echo "$CC -O -Wall -o $ODIR.tmp_out $ODIR.tmp_src.c -nostdinc -I$LINUX/include " \
+ "-I$LINUX/include/generated/uapi" >> $LOG
+ $CC -O -Wall -o $ODIR.tmp_out $ODIR.tmp_src.c -nostdinc -I$LINUX/include \
+ -I$LINUX/include/generated/uapi >> $LOG 2>&1
+ if [ $? -ne 0 ]; then
+ echo
+ echo " Linux kernel headers not found at $LINUX"
+ echo " Check the file $LOG for detailed error information."
+ fail
+ else
+ if test_execute; then
+ cnf_append "VBOX_LINUX_SRC" "`cd $LINUX ; pwd`"
+ fi
+ fi
+}
+
+#
+# Check for kchmviewer, needed to display the online help
+# (unused as we ship kchmviewer)
+#
+check_kchmviewer()
+{
+ test_header kchmviewer
+ if check_avail "$KCHMVIEWER" KCHMVIEWER; then
+ kchmviewer_ver=`$KCHMVIEWER --version|grep "^KchmViewer:"|sed 's+^KchmViewer: \(.*\)+\1+'`
+ if [ $? -ne 0 ]; then
+ log_failure "kchmviewer not working"
+ fail
+ else
+ log_success "found version $kchmviewer_ver"
+ fi
+ fi
+}
+
+
+#
+# Check for the kBuild tools, we don't support GNU make
+#
+check_kbuild()
+{
+ test_header kBuild
+ if which_wrapper "$KBUILDDIR/bin/$OS.$BUILD_MACHINE/kmk" > /dev/null; then
+ KBUILDDIR_BIN="$KBUILDDIR/bin/$OS.$BUILD_MACHINE"
+
+ echo "KBUILD_PATH=\"`cd $KBUILDDIR ; pwd`\"" >> $ENV
+ echo "KBUILD_DEVTOOLS=\"$DEVDIR\"" >> $ENV
+ echo 'path_kbuild_bin="$KBUILD_PATH/bin/$BUILD_TARGET.$BUILD_PLATFORM_ARCH"' >> $ENV
+ echo 'path_tools_bin="$KBUILD_DEVTOOLS/$BUILD_TARGET.$BUILD_PLATFORM_ARCH/bin"' >> $ENV
+
+ if [ "$OS" = "solaris" ]; then
+ # Because of sh being non-default shell in Solaris we need to export PATH again when
+ # sourcing env.sh. Simply exporting from ./configure does not export PATH correctly.
+ echo "PATH=\"$ORGPATH\"" >> $ENV
+ echo "echo \"\$PATH\" | /usr/sfw/bin/ggrep -q \"\$path_kbuild_bin\" || PATH=\"\$path_kbuild_bin:\$PATH\"" >> $ENV
+ echo "echo \"\$PATH\" | /usr/sfw/bin/ggrep -q \"\$path_tools_bin\" || PATH=\"\$path_tools_bin:\$PATH\"" >> $ENV
+ else
+ echo "echo \"\$PATH\" | grep -q \"\$path_kbuild_bin\" || PATH=\"\$path_kbuild_bin:\$PATH\"" >> $ENV
+ echo "echo \"\$PATH\" | grep -q \"\$path_tools_bin\" || PATH=\"\$path_tools_bin:\$PATH\"" >> $ENV
+ fi
+ echo "export KBUILD_PATH KBUILD_DEVTOOLS PATH" >> $ENV
+ echo "unset path_kbuild_bin path_tools_bin" >> $ENV
+ KBUILD_SED="$KBUILDDIR_BIN/kmk_sed"
+
+ echo '' >> $ENV
+ echo "# Legacy - do not use:" >> $ENV
+ echo 'PATH_KBUILD=${KBUILD_PATH}' >> $ENV
+ echo 'PATH_DEVTOOLS=${KBUILD_DEVTOOLS}' >> $ENV
+ echo 'export PATH_KBUILD PATH_DEVTOOLS' >> $ENV
+ echo '' >> $ENV
+ elif check_avail "kmk" KBUILDDIR really; then
+ # check for installed kBuild
+ KBUILD_SED="`which_wrapper kmk_sed`"
+ else
+ fail
+ fi
+ log_success "found"
+}
+
+
+#
+# Check for compiler.h
+# Some Linux distributions include "compiler.h" in their libc linux
+# headers package, some don't. Most don't need it, building might (!)
+# not succeed on openSUSE without it.
+#
+# See http://www.mail-archive.com/qemu-devel%40nongnu.org/msg07980.html
+#
+check_compiler_h()
+{
+ test_header compiler.h
+ if test ! -f "/usr/include/linux/compiler.h"; then
+ log_success "compiler.h not found"
+ else
+ cnf_append "VBOX_WITH_LINUX_COMPILER_H" "1"
+ log_success "compiler.h found"
+ fi
+}
+
+#
+# Check for libcap.
+# Required to pass CAP_NET_RAW to our binaries to allow to open SOCK_RAW
+# sockets for doing ICMP requests.
+#
+check_libcap()
+{
+ test_header "libcap library"
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <sys/types.h>
+#include <linux/types.h>
+#include <sys/capability.h>
+
+extern "C" int main(void)
+{
+ char buf[1024];
+ cap_t caps = cap_get_proc();
+ snprintf(buf, sizeof(buf), "Current caps are '%s'\n", cap_to_text(caps, NULL));
+ return 0;
+}
+EOF
+ if test_compile $LIBCAP libcap libcap; then
+ if test_execute; then
+ log_success "found"
+ fi
+ fi
+}
+
+#
+# Check if we are able to build 32-bit applications (needed for the guest additions)
+#
+check_32bit()
+{
+ test_header "32-bit support"
+ cat > $ODIR.tmp_src.c << EOF
+#include <stdint.h>
+int main(void)
+{
+ return 0;
+}
+EOF
+ echo "compiling the following source file:" >> $LOG
+ cat $ODIR.tmp_src.c >> $LOG
+ echo "using the following command line:" >> $LOG
+ echo "$CC -m32 -O -Wall -o $ODIR.tmp_out $ODIR.tmp_src.c" >> $LOG
+ $CC -m32 -O -Wall -o $ODIR.tmp_out $ODIR.tmp_src.c >> $LOG 2>&1
+ if [ $? -ne 0 ]; then
+ echo
+ echo " Cannot compile 32-bit applications (missing headers and/or libraries)!"
+ echo " Check the file $LOG for detailed error information."
+ fail
+ else
+ echo "executing the binary" >> $LOG
+ $ODIR.tmp_out 2> $ODIR.test_execute.log
+ rc=$?
+ cat $ODIR.test_execute.log >> $LOG
+ if [ $rc -ne 0 ]; then
+ echo
+ echo " Cannot execute 32-bit applications! Either enable 32-bit support in the"
+ echo " kernel configuration or use --disable-vmmraw to disable 32-bit guests."
+ fail
+ return 1
+ fi
+ fi
+ log_success ""
+}
+
+
+#
+# Check for Python
+#
+check_python()
+{
+ test_header "Python support"
+
+ # On darwin this is a on/off decision only
+ if [ "$OS" = "darwin" ]; then
+ echo "enabled"
+ cnf_append "VBOX_WITH_PYTHON" "1"
+ return
+ fi
+
+ cat > $ODIR.tmp_src.cc << EOF
+#include <cstdio>
+#include <Python.h>
+extern "C" int main(void)
+{
+ Py_Initialize();
+ printf("found version %s", PY_VERSION);
+#if PY_VERSION_HEX >= 0x02060000
+ printf(", OK.\n");
+ return 0;
+#else
+ printf(", expected version 2.6 or higher\n");
+ return 1;
+#endif
+}
+EOF
+ found=
+ SUPPYTHONLIBS="python2.7 python2.6 python3.1 python3.2 python3.3 python3.4 python3.4m python3.5 python3.5m python3.6 python3.6m python3.7 python3.7m python3.8 python3.9 python3.10 python3.11 python3.12"
+ for p in $PYTHONDIR; do
+ for d in $SUPPYTHONLIBS; do
+ for b in lib/x86_64-linux-gnu lib/i386-linux-gnu lib64 lib/64 lib; do
+ echo "compiling the following source file:" >> $LOG
+ cat $ODIR.tmp_src.cc >> $LOG
+ echo "using the following command line:" >> $LOG
+ echo "$CXX -O -Wall -o $ODIR.tmp_out $ODIR.tmp_src.cc -I$p/include/$d $p/$b/lib$d.so" >> $LOG
+ $CXX -O -Wall -o $ODIR.tmp_out $ODIR.tmp_src.cc -I$p/include/$d $p/$b/lib$d.so >> $LOG 2>&1
+ if [ $? -eq 0 ]; then
+ found=1
+ break
+ fi
+ done
+ if [ -n "$found" ]; then break; fi
+ done
+ if [ -n "$found" ]; then break; fi
+ done
+ if [ -n "$found" ]; then
+ if test_execute; then
+ cnf_append "VBOX_WITH_PYTHON" "1"
+ cnf_append "VBOX_PATH_PYTHON_INC" "$p/include/$d"
+ cnf_append "VBOX_LIB_PYTHON" "$p/$b/lib$d.so"
+ else
+ log_failure "Python not working"
+ fail
+ fi
+ else
+ log_failure "Python not found"
+ fail
+ fi
+}
+
+
+#
+# Check for Java
+#
+check_java()
+{
+ test_header "Java support"
+ log_success
+}
+
+
+#
+# Setup wine
+#
+setup_wine()
+{
+ test_header "Wine support"
+ if ! which_wrapper wine > /dev/null; then
+ echo " wine binary not found"
+ fail
+ fi
+ if ! which_wrapper wine > /dev/null; then
+ echo " wine not found"
+ fail
+ fi
+ wine_version="`wine --version`"
+ case "`expr "$wine_version" : 'wine-\([0-9.]*\)' '>' 1.1.43`" in
+ "0")
+ if ! which_wrapper wineprefixcreate > /dev/null; then
+ echo " wineprefixcreate not found"
+ fail
+ fi
+ ;;
+ *) eval "wineprefixcreate() { true ; }" ;; # now created automatically
+ esac
+ export WINEPREFIX="${ODIR}wine.$BUILD_MACHINE"
+ echo "WINEPREFIX=\"${ODIR}wine.$BUILD_MACHINE\"" >> $ENV
+ echo "export WINEPREFIX" >> $ENV
+ rm -rf $WINEPREFIX
+ mkdir -p $WINEPREFIX
+ touch $WINEPREFIX/.no_prelaunch_window_flag
+ if ! wineprefixcreate -q > /dev/null 2>&1; then
+ echo " wineprefixcreate failed"
+ fail
+ fi
+ tmp=.tmp.wine.reg
+ rm -f $tmp
+ echo 'REGEDIT4' > $tmp
+ echo '' >> $tmp
+ echo '[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment]' >> $tmp
+ echo "\"PATH\"=\"c:\\\\\\\\windows\\\\\\\\system32;c:\\\\\\\\windows;z:$DEVDIR/win.x86/vcc/v8/bin/Microsoft.VC80.CRT;z:$DEVDIR/win.x86/HTML_Help_Workshop/v1.3\"" >> $tmp
+ echo '' >> $tmp
+ echo '[HKEY_CURRENT_USER\Software\Wine\AppDefaults\hhc.exe\DllOverrides]' >> $tmp
+ echo '"itss"="native"' >> $tmp
+ echo '' >> $tmp
+ echo '[HKEY_CURRENT_USER\Software\Wine\AppDefaults\hhw.exe\DllOverrides]' >> $tmp
+ echo '"itss"="native"' >> $tmp
+ echo '' >> $tmp
+ if ! wine regedit $tmp > /dev/null 2>&1; then
+ rm -f $tmp
+ echo " failed to load registry changes (path)."
+ fail
+ fi
+ rm -f $tmp
+ log_success "found"
+}
+
+
+#
+# Check for gSOAP.
+#
+check_gsoap()
+{
+ test_header "GSOAP compiler"
+ if [ -z "$GSOAP" -a -z "$GSOAP_IMPORT" ]; then
+ if which_wrapper pkg-config > /dev/null; then
+ GSOAP_CXX_LIBS=`pkg-config gsoapssl++ --libs 2>> $LOG`
+ if [ $? -eq 0 ]; then
+ GSOAP=`pkg-config gsoapssl++ --variable=exec_prefix`
+ GSOAP_IMPORT="$GSOAP/share/gsoap/import"
+ if [ ! -d "$GSOAP_IMPORT" -a -d "$GSOAP/include/gsoap" ]; then
+ GSOAP_IMPORT="$GSOAP/include/gsoap"
+ fi
+ cnf_append "VBOX_GSOAP_INSTALLED" "1"
+ cnf_append "VBOX_PATH_GSOAP" "$GSOAP"
+ cnf_append "VBOX_PATH_GSOAP_IMPORT" "$GSOAP_IMPORT"
+ if [ -f "$GSOAP/share/gsoap/stdsoap2.cpp" ]; then
+ cnf_append "VBOX_GSOAP_CXX_SOURCES" "$GSOAP/share/gsoap/stdsoap2.cpp"
+ else
+ cnf_append "VBOX_GSOAP_CXX_SOURCES" ""
+ fi
+ cnf_append "VBOX_GSOAP_CXX_LIBS" "`strip_l "$GSOAP_CXX_LIBS"`"
+ gsoap_version=`pkg-config gsoapssl++ --modversion`
+ log_success "found version $gsoap_version"
+ return
+ fi
+ fi
+ if [ -d "$DEVDIR/common/gsoap" ]; then
+ GSOAP_DIR=`ls -d1 "$DEVDIR"/common/gsoap/v* 2>/dev/null | tail -1`
+ if [ -n "$GSOAP_DIR" -a -d "$GSOAP_DIR" ]; then
+ gsoap_version=`echo "$GSOAP_DIR" | sed -ne 's/^.*\/v\([1-9][0-9.]*\).*$/\1/p'`
+ log_success "found gSOAP tool version $gsoap_version"
+ # No need to configure anything, the build system knows what to do.
+ return
+ fi
+ fi
+ fi
+ if [ -z "$GSOAP" ]; then
+ GSOAP="/usr"
+ fi
+ if which_wrapper "$GSOAP/bin/soapcpp2" > /dev/null; then
+ if which_wrapper "$GSOAP/bin/wsdl2h" > /dev/null; then
+ if [ -f "$GSOAP/include/stdsoap2.h" ]; then
+ # TODO: Check for libgsoap++.a/so
+
+ if [ -z "$GSOAP_IMPORT" ]; then
+ GSOAP_IMPORT="$GSOAP/share/gsoap/import"
+ if [ ! -d "$GSOAP_IMPORT" -a -d "$GSOAP/include/gsoap" ]; then
+ GSOAP_IMPORT="$GSOAP/include/gsoap"
+ fi
+ fi
+ if [ -f "$GSOAP_IMPORT/stlvector.h" ]; then
+ cnf_append "VBOX_GSOAP_INSTALLED" "1"
+ cnf_append "VBOX_PATH_GSOAP" "$GSOAP"
+ cnf_append "VBOX_PATH_GSOAP_IMPORT" "$GSOAP_IMPORT"
+ if [ -f "$GSOAP/share/gsoap/stdsoap2.cpp" ]; then
+ cnf_append "VBOX_GSOAP_CXX_SOURCES" "$GSOAP/share/gsoap/stdsoap2.cpp"
+ else
+ cnf_append "VBOX_GSOAP_CXX_SOURCES" ""
+ fi
+ cnf_append "VBOX_GSOAP_CXX_LIBS" "libgsoapssl++"
+ log_success "found"
+ else
+ log_failure "stlvector.h not found -- disabling webservice"
+ cnf_append "VBOX_WITH_WEBSERVICES" ""
+ fi
+ else
+ log_failure "stdsoap2.h not found -- disabling webservice"
+ cnf_append "VBOX_WITH_WEBSERVICES" ""
+ fi
+ else
+ log_failure "wsdl2h not found -- disabling webservice"
+ cnf_append "VBOX_WITH_WEBSERVICES" ""
+ fi
+ else
+ log_failure "soapcpp2 not found -- disabling webservice"
+ cnf_append "VBOX_WITH_WEBSERVICES" ""
+ fi
+}
+
+
+#
+# Determines the Darwin version.
+#
+check_darwinversion()
+{
+ test_header "Darwin version"
+ darwin_ver=`uname -r`
+ case "$darwin_ver" in
+ 20\.*)
+ darwin_ver="11.0" # Big Sur
+ ;;
+ 19\.*)
+ darwin_ver="10.15" # Catalina
+ ;;
+ 18\.*)
+ darwin_ver="10.14" # Mojave
+ ;;
+ 17\.*)
+ darwin_ver="10.13" # High Sierra
+ ;;
+ 16\.*)
+ darwin_ver="10.12" # Sierra
+ ;;
+ 15\.*)
+ darwin_ver="10.11" # El Capitan
+ ;;
+ 14\.*)
+ darwin_ver="10.10" # Yosemite
+ ;;
+ 13\.*)
+ darwin_ver="10.9" # Mavericks
+ ;;
+ *)
+ echo " failed to determine Darwin version. (uname -r: $darwin_ver)"
+ fail
+ darwin_ver="unknown"
+ ;;
+ esac
+
+ log_success "found version $darwin_ver"
+}
+
+#
+# Check Xcode path
+#
+check_xcode_path()
+{
+ # Check if WITH_XCODE_DIR is set.
+ if [ -z "$WITH_XCODE_DIR" ]; then
+ if [ -d "/Library/Developer/CommandLineTools" -a -f "/Library/Developer/CommandLineTools/usr/bin/clang" ]; then
+ return 1
+ else
+ echo "Please specify --with-xcode-dir option."
+ return 0
+ fi
+ fi
+
+ # Check if specified path exists and is a directory containing Xcode.
+ if [ -d "$1" -a -f "$1/Contents/Developer/usr/bin/xcodebuild" ]; then
+ return 1
+ else
+ echo "Xcode path [$1] not found."
+ return 0
+ fi
+}
+
+check_xcode()
+{
+ test_header "Xcode and SDK"
+ check_xcode_path "$WITH_XCODE_DIR"
+ [ $? -eq 1 ] || fail
+
+ # Pick the oldest SDK offered by Xcode, to get maximum compatibility
+ if [ -z "$WITH_XCODE_DIR" ]; then
+ devel_subdir="/Library/Developer/CommandLineTools"
+ sdk_subdir="$devel_subdir/SDKs"
+ else
+ devel_subdir="$WITH_XCODE_DIR/Contents/Developer"
+ sdk_subdir="$devel_subdir/Platforms/MacOSX.platform/Developer/SDKs"
+ fi
+ sdk_tries="$sdk_subdir"/MacOSX10.?.sdk" $sdk_subdir"/MacOSX10.??.sdk" $sdk_subdir"/MacOSX.sdk
+ for t in $sdk_tries; do
+ if [ -f "$t/SDKSettings.plist" ]; then
+ sdk="$t"
+ sdk_ver=`defaults read "$t/SDKSettings.plist" Version`
+ break
+ fi
+ done
+ if [ -z "$sdk" ]; then
+ echo " failed to determine SDK directory. ($sdk_subdir/MacOSX*.sdk/SDKSettings.plist should exist)"
+ fail
+ fi
+ xcode_ver=`$devel_subdir/usr/bin/clang --version | sed -n 's/^.*version \([0-9]\{1,\}\.[0-9]\{1,\}\.[0-9]\{1,\}\).*$/\1/p'`
+ if [ $? -ne 0 -o -z "$xcode_ver" ]; then
+ echo " failed to determine Xcode version."
+ fail
+ fi
+
+ if [ -z "$WITH_XCODE_DIR" ]; then
+ cnf_append "VBOX_WITH_EVEN_NEWER_XCODE" "1"
+ else
+ cnf_append "VBOX_WITH_MACOSX_COMPILERS_FROM_DEVEL" "1"
+ cnf_append "PATH_TOOL_VBoxXcode62" "$devel_subdir"
+ cnf_append "VBOX_PATH_MACOSX_DEVEL_ROOT" "$devel_subdir"
+ fi
+ cnf_append "VBOX_PATH_MACOSX_SDK" "$sdk"
+ if [ -n "$sdk_ver" ]; then
+ cnf_append "VBOX_DEF_MACOSX_VERSION_MIN" "$sdk_ver"
+ cnf_append "VBOX_WITHOUT_VBOXPYTHON_FOR_OSX_10_6" "1"
+ fi
+
+ log_success "found version $xcode_ver (SDK: $sdk)"
+}
+
+
+check_makeself()
+{
+ test_header "makeself"
+ if check_avail "$MAKESELF" makeself; then
+ makeself_ver=`$MAKESELF --version|grep version|sed 's+^Makeself.*version \([0-9\.]*\).*+\1+'`
+ if [ $? -ne 0 ]; then
+ log_failure "makeself not working"
+ fail
+ else
+ log_success "found version $makeself_ver"
+ cnf_append "VBOX_MAKESELF" "`which_wrapper $MAKESELF`"
+ fi
+ fi
+}
+
+
+#
+# Show help
+#
+show_help()
+{
+cat << EOF
+Usage: ./configure [OPTIONS]...
+
+Configuration:
+ -h, --help display this help and exit
+ --nofatal don't abort on errors
+EOF
+[ $WITH_XPCOM -eq 1 ] && echo " --disable-xpcom disable XPCOM and related stuff"
+[ $WITH_PYTHON -eq 1 ] && echo " --disable-python disable python bindings"
+[ $WITH_JAVA -eq 1 ] && echo " --disable-java disable java bindings"
+[ $WITH_VMMRAW -eq 1 ] && echo " --disable-vmmraw disable VMM raw mode (VT-x/AMD-V mandatory!)"
+[ $WITH_SDL_TTF -eq 1 ] && echo " --disable-sdl-ttf disable SDL_ttf detection"
+[ $WITH_QT5 -eq 1 ] && echo " --disable-qt disable Qt detection"
+[ $WITH_ALSA -eq 1 ] && echo " --disable-alsa disable the ALSA sound backend"
+[ $WITH_PULSE -eq 1 ] && echo " --disable-pulse disable the PulseAudio backend"
+[ $WITH_DBUS -eq 1 ] && echo " --disable-dbus don't use DBus and hal for hardware detection"
+[ $WITH_KMODS -eq 1 ] && echo " --disable-kmods don't build Linux kernel modules (host and guest)"
+[ $WITH_OPENGL -eq 1 ] && echo " --disable-opengl disable OpenGL support (2D & 3D)"
+[ $WITH_QT5 -eq 0 ] && echo " --enable-qt5 enable Qt5 detection"
+[ $OSE -eq 1 ] && echo " --enable-vnc enable the VNC server"
+[ $OSE -eq 0 ] && echo " --disable-extpack don't build the extpack"
+[ $WITH_DOCS -eq 1 ] && echo " --disable-docs don't build the documentation"
+[ $WITH_LIBVPX -eq 1 ] && echo " --disable-libvpx don't use libvpx for video capturing"
+[ $WITH_LIBVORBIS -eq 0 ] && echo " --enable-libvorbis enable system libvorbis"
+[ $WITH_LIBOGG -eq 0 ] && echo " --enable-libogg enable system libogg"
+[ $WITH_LIBTPMS -eq 1 ] && echo " --disable-libtpms don't use libtpms for TPM emulation"
+[ $WITH_LIBLZMA -eq 1 ] && echo " --disable-liblzma don't use liblzma"
+[ "$OS" = "linux" -o "$OS" = "freebsd" ] && echo " --enable-vde enable VDE networking"
+cat << EOF
+ --disable-udptunnel disable UDP tunnel networking
+ --disable-devmapper disable device mapper library access
+ --disable-hardening don't be strict about /dev/vboxdrv access
+ --build-libxml2 build libxml2 from sources
+ --build-libssl build openssl from sources
+ --build-libtpms build libtpms from sources
+ --build-liblzma build liblzma from sources
+EOF
+[ $OSE -eq 0 ] && cat << EOF
+ --build-libcurl build libcurl from sources
+ --build-libvpx build libvpx from sources
+EOF
+[ "$OS" != "darwin" ] && echo " --setup-wine setup a Wine directory and register the hhc hack"
+cat << EOF
+ --only-additions only build the Guest Additions
+
+Paths:
+ --with-gcc=PATH location of the gcc compiler [$CC]
+ --with-g++=PATH location of the g++ compiler [$CXX]
+ --with-kbuild=DIR kbuild directory [$KBUILDDIR]
+ --with-iasl=PATH location of the iasl compiler [$IASL]
+ --with-yasm=PATH location of the iasl compiler [$YASM]
+ --with-makeself=PATH location of makeself [$MAKESELF]
+EOF
+[ "$OS" = "darwin" ] && echo " --with-xcode-dir=DIR custom path to Xcode root directory; it is assumed that Xcode"
+[ "$OS" = "darwin" ] && echo " contains OS X 10.6 SDK (required for Mountain Lion and newer hosts"
+[ "$OS" = "darwin" ] && echo " only, ignored for the rest)"
+[ "$OS" = "linux" ] && echo " --with-linux=DIR Linux kernel source directory [$LINUX]"
+[ $WITH_QT5 -eq 1 ] && echo " --with-qt-dir=DIR directory for Qt headers/libraries [pkgconfig]"
+cat << EOF
+ --with-gsoap-dir=PATH directory for gSOAP compiler/headers/libraries
+ (soapcpp2 and wsdl2h, soapstd2.h, libgsoap++.a/so)
+ --with-gsoap-import=PATH directory for gSOAP import files (stlvector.h)
+ --with-openssl-dir=DIR directory for OpenSSL headers/libraries
+ --with-ow-dir=DIR directory where Open Watcom can be found [$WATCOM]
+ --out-base-dir=DIR directory where configuration and build output
+ should go, in subdirectory out
+
+Build type:
+ -d, --build-debug build with debugging symbols and assertions
+ --build-profile build with profiling support
+ --build-headless build headless (without any GUI frontend)
+EOF
+ exit 0
+}
+
+
+#
+# The body.
+#
+
+# test if we are OSE
+if [ $OSE -eq 1 -a -r "`cd \`dirname $0\`; pwd`/src/VBox/RDP/server/server.cpp" ]; then
+ OSE=0
+ # Set this as a reminder to print a log message once we know the path of the
+ # log file
+ NOT_OSE=1
+fi
+
+# Change OS specific defaults; must be before all other stuff
+if [ "$OS" = "darwin" ]; then
+ WITH_SDL=0
+ WITH_SDL_TTF=0
+ WITH_X11=0
+ WITH_ALSA=0
+ WITH_PULSE=0
+ WITH_DBUS=0
+ WITH_KMODS=0
+ BUILD_LIBXML2=1
+ BUILD_LIBSSL=1
+ BUILD_LIBVPX=1
+ [ $OSE -eq 1 ] || BUILD_LIBCURL=1
+ [ $OSE -eq 1 ] && WITH_LIBVPX=0
+ [ $OSE -eq 1 ] && WITH_LIBOGG=0
+ [ $OSE -eq 1 ] && WITH_LIBVORBIS=0
+ WITH_XCODE_DIR=""
+elif [ "$OS" = "haiku" ]; then
+ #WITH_SDL=0
+ WITH_SDL_TTF=0
+ WITH_X11=0
+ WITH_ALSA=0
+ WITH_PULSE=0
+ WITH_DBUS=0
+ WITH_KMODS=0
+ WITH_LIBIDL=0
+ WITH_XPCOM=0
+ BUILD_LIBXSLT=1
+ BUILD_LIBXML2=1
+ WITH_LIBVPX=0
+ WITH_LIBOGG=0
+ WITH_LIBVORBIS=0
+ # but the script wants something
+ LIBPTHREAD="-lroot"
+ #[ $OSE -eq 1 ] || BUILD_LIBCURL=1
+ [ $OSE -eq 1 ] || BUILD_LIBSSL=1
+elif [ "$OS" = "solaris" ]; then
+ [ $OSE -eq 1 ] && WITH_LIBVPX=0
+ [ $OSE -eq 1 ] && WITH_LIBOGG=0
+ [ $OSE -eq 1 ] && WITH_LIBVORBIS=0
+fi
+
+# scan command line options
+for option in "$@"; do
+ case "$option" in
+ --help|-help|-h)
+ show_help
+ ;;
+ --nofatal)
+ nofatal=1
+ ;;
+ --env-only)
+ ENV_ONLY=1
+ ;;
+ --with-gcc=*)
+ CC=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-g++=*)
+ CXX=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-kbuild=*)
+ KBUILDDIR=`echo $option | cut -d'=' -f2`
+ if echo $KBUILDDIR|grep -q "$INVALID_CHARS"; then
+ echo "Error: KBUILDDIR contains invalid characters!"
+ exit 1
+ fi
+ ;;
+ --with-qt-dir=*)
+ [ $WITH_QT5 -eq 1 ] && QT5DIR=`echo $option | cut -d'=' -f2`
+ [ $WITH_QT5 -eq 1 ] && QT5DIR_PKGCONFIG=0
+ ;;
+ --with-qt5-minor=*)
+ QT5MIN=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-qt5-major=*)
+ QT5MAJ=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-openssl-dir=*)
+ OPENSSLDIR=`echo $option | cut -d'=' -f2`
+ INCCRYPTO="-I${OPENSSLDIR}/include"
+ LIBCRYPTO="${OPENSSLDIR}/lib/libssl.a ${OPENSSLDIR}/lib/libcrypto.a"
+ # On Darwin (at least for macports) static OpenSSL also needs zlib.
+ [ "$OS" = "darwin" ] && LIBCRYPTO="$LIBCRYPTO ${OPENSSLDIR}/lib/libz.a"
+ # On Linux static OpenSSL typically needs a few additional libraries.
+ [ "$OS" = "linux" ] && LIBCRYPTO="-ldl $LIBPTHREAD -lm"
+ ;;
+ --with-ow-dir=*)
+ WATCOM=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-gsoap-dir=*)
+ GSOAP=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-gsoap-import=*)
+ GSOAP_IMPORT=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-iasl=*)
+ IASL=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-yasm=*)
+ YASM=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-xcode-dir=*)
+ WITH_XCODE_DIR=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-linux=*)
+ LINUX=`echo $option | cut -d'=' -f2`
+ ;;
+ --with-makeself=*)
+ MAKESELF=`echo $option | cut -d'=' -f2`
+ ;;
+ --target-arch=*)
+ TARGET_MACHINE=`echo $option | cut -d'=' -f2`
+ ;;
+ --disable-xpcom)
+ [ $WITH_XPCOM -eq 1 ] && WITH_XPCOM=0
+ ;;
+ --disable-python)
+ [ $WITH_PYTHON -eq 1 ] && WITH_PYTHON=0
+ ;;
+ --disable-java)
+ [ $WITH_JAVA -eq 1 ] && WITH_JAVA=0
+ ;;
+ --disable-vmmraw)
+ [ $WITH_VMMRAW -eq 1 ] && WITH_VMMRAW=0
+ ;;
+ --disable-sdl-ttf)
+ [ $WITH_SDL_TTF -eq 1 ] && WITH_SDL_TTF=0
+ ;;
+ --disable-qt)
+ [ $WITH_QT5 -eq 1 ] && WITH_QT5=0
+ ;;
+ --enable-qt5)
+ [ $WITH_QT5 -eq 0 ] && WITH_QT5=1
+ ;;
+ --passive-mesa)
+ PASSIVE_MESA=1
+ ;;
+ --disable-alsa)
+ [ $WITH_ALSA -eq 1 ] && WITH_ALSA=0
+ ;;
+ --disable-pulse)
+ [ $WITH_PULSE -eq 1 ] && WITH_PULSE=0
+ ;;
+ --enable-pulse)
+ WITH_PULSE=2
+ ;;
+ --disable-dbus)
+ [ $WITH_DBUS -eq 1 ] && WITH_DBUS=0
+ ;;
+ --disable-kmods)
+ [ $WITH_KMODS -eq 1 ] && WITH_KMODS=0
+ ;;
+ --disable-opengl)
+ [ $WITH_OPENGL -eq 1 ] && WITH_OPENGL=0
+ ;;
+ --enable-webservice)
+ ;;
+ --enable-vnc)
+ WITH_VNC=1
+ ;;
+ --disable-hardening)
+ WITH_HARDENING=0
+ ;;
+ --disable-extpack)
+ WITH_EXTPACK=0
+ ;;
+ --disable-docs)
+ WITH_DOCS=0
+ ;;
+ --enable-hardening)
+ WITH_HARDENING=2
+ ;;
+ --disable-udptunnel)
+ WITH_UDPTUNNEL=0
+ ;;
+ --enable-vde)
+ WITH_VDE=1
+ ;;
+ --disable-devmapper)
+ WITH_DEVMAPPER=0
+ ;;
+ --disable-libvpx)
+ WITH_LIBVPX=0
+ ;;
+ --disable-libtpms)
+ WITH_LIBTPMS=0
+ ;;
+ --disable-liblzma)
+ WITH_LIBLZMA=0
+ ;;
+ --enable-libogg)
+ WITH_LIBOGG=1
+ ;;
+ --enable-libvorbis)
+ WITH_LIBVORBIS=1
+ ;;
+ --disable-sdl)
+ WITH_SDL=0
+ ;;
+ --build-debug|-d)
+ BUILD_TYPE=debug
+ ;;
+ --build-profile)
+ BUILD_TYPE=profile
+ ;;
+ --build-libxml2)
+ BUILD_LIBXML2=1
+ ;;
+ --build-libssl)
+ BUILD_LIBSSL=1
+ ;;
+ --build-libcurl)
+ BUILD_LIBCURL=1
+ ;;
+ --build-libvpx)
+ BUILD_LIBVPX=1
+ ;;
+ --build-libtpms)
+ BUILD_LIBTPMS=1
+ ;;
+ --build-liblzma)
+ BUILD_LIBLZMA=1
+ ;;
+ --build-headless)
+ HEADLESS=1
+ WITH_SDL=0
+ WITH_SDL_TTF=0
+ WITH_X11=0
+ WITH_OPENGL=0
+ WITH_QT5=0
+ ;;
+ --ose)
+ OSE=2
+ ;;
+ --odir=*)
+ ODIR="`echo $option | cut -d'=' -f2`/"
+ ODIR_OVERRIDE=1
+ ;;
+ --out-base-dir=*)
+ out_base_dir="`echo $option | cut -d'=' -f2`/"
+ if [ -d $out_base_dir ]; then
+ saved_pwd="$PWD"
+ cd $out_base_dir
+ OUT_BASE_PATH="`pwd`"
+ cd $saved_pwd
+ OUT_BASE_PATH_OVERRIDE=1
+ if [ $ODIR_OVERRIDE -eq 0 ]; then
+ # This variable has not *yet* been overridden. That can still happen.
+ ODIR=$OUT_BASE_PATH/
+ ODIR_OVERRIDE=1
+ fi
+ else
+ echo "Error: invalid folder \"$out_base_dir\" in option \"$option\""
+ exit 1
+ fi
+ ;;
+ --setup-wine)
+ [ "$OS" != "darwin" ] && SETUP_WINE=1
+ ;;
+ --only-additions)
+ ONLY_ADDITIONS=1
+ ;;
+ *)
+ echo
+ echo "Unrecognized option \"$option\""
+ echo
+ show_help
+ ;;
+ esac
+done
+
+LOG="$ODIR$LOG"
+ENV="$ODIR$ENV"
+CNF="$ODIR$CNF"
+
+# initialize output files
+cat > $LOG << EOF
+# Log file generated by
+#
+# '$0 $*'
+#
+
+EOF
+cat > $CNF << EOF
+# -*- Makefile -*-
+#
+# automatically generated by
+#
+# '$0 $*'
+#
+# It will be completely overwritten if configure is executed again.
+#
+
+EOF
+cat > $ENV << EOF
+#!/bin/bash
+#
+# automatically generated by
+#
+# '$0 $*'
+#
+# It will be completely overwritten if configure is executed again.
+# Make sure you source this file once before you start to build VBox.
+#
+
+EOF
+
+# Print log warning about OSE if necessary
+if [ -n "$NOT_OSE" ]; then
+ echo "Found RDP server, assuming VBOX_OSE = FALSE" >> $LOG
+ echo >> $LOG
+fi
+
+
+if [ "$BUILD_TYPE" = "debug" ]; then
+ echo "Creating DEBUG build!" >> $LOG
+elif [ "$BUILD_TYPE" = "profile" ]; then
+ echo "Creating PROFILE build!" >> $LOG
+fi
+
+# first determine our environment
+check_environment
+check_kbuild
+
+[ -n "$ENV_ONLY" ] && exit 0
+
+# append the tools directory to the default search path
+echo "$PATH" | grep -q "$DEVDIR_BIN" || PATH="$PATH:$DEVDIR_BIN"
+export PATH
+
+# if we will be writing to a different out directory then set this up now
+if [ $ODIR_OVERRIDE -eq 1 ]; then
+ echo "AUTOCFG=$CNF" >> $ENV
+ echo "export AUTOCFG" >> $ENV
+fi
+if [ $OUT_BASE_PATH_OVERRIDE -eq 1 ]; then
+ echo "PATH_OUT_BASE=$OUT_BASE_PATH" >> $ENV
+ echo "export PATH_OUT_BASE" >> $ENV
+fi
+
+# don't bother people with -Werror
+cnf_append "VBOX_GCC_WERR" "\$(NO_SUCH_VARIABLE)"
+
+# some things are not available in for OSE
+if [ $OSE -ge 1 ]; then
+ cnf_append "VBOX_OSE" "1"
+ cnf_append "VBOX_WITH_VALIDATIONKIT" ""
+ cnf_append "VBOX_WITH_WIN32_ADDITIONS" ""
+
+ if [ "$OS" = "linux" ]; then
+ cnf_append "VBOX_WITH_LINUX_ADDITIONS" "1"
+ else
+ cnf_append "VBOX_WITH_LINUX_ADDITIONS" ""
+ fi
+ echo >> $CNF
+fi
+
+# extpack
+if [ $ONLY_ADDITIONS -eq 1 ]; then
+ cnf_append "VBOX_WITH_EXTPACK_PUEL_BUILD" ""
+elif [ $OSE -eq 0 ]; then
+ if [ $WITH_EXTPACK -eq 1 ]; then
+ BUILD_LIBSSL=1
+ else
+ cnf_append "VBOX_WITH_EXTPACK_PUEL_BUILD" ""
+ fi
+fi
+
+# headless
+if [ -n "$HEADLESS" ]; then
+ cnf_append "VBOX_HEADLESS" "1"
+fi
+
+# emit disable directives corresponding to any --disable-xxx options.
+if [ $WITH_OPENGL -eq 0 ]; then
+ cnf_append "VBOX_WITH_VMSVGA3D" ""
+ cnf_append "VBOX_WITH_3D_ACCELERATION" ""
+ cnf_append "VBOX_WITH_VIDEOHWACCEL" ""
+ cnf_append "VBOX_GUI_USE_QGL" ""
+fi
+[ $WITH_XPCOM -eq 0 ] && cnf_append "VBOX_WITH_MAIN" ""
+[ $WITH_QT5 -eq 0 ] && cnf_append "VBOX_WITH_QTGUI" ""
+[ $WITH_SDL_TTF -eq 0 ] && cnf_append "VBOX_WITH_SECURELABEL" ""
+[ $WITH_PYTHON -eq 0 ] && cnf_append "VBOX_WITH_PYTHON" ""
+[ $WITH_JAVA -eq 0 ] && cnf_append "VBOX_WITH_JXPCOM" ""
+[ $WITH_JAVA -eq 0 ] && cnf_append "VBOX_WITH_JWS" ""
+[ $WITH_HARDENING -eq 0 ] && cnf_append "VBOX_WITHOUT_HARDENING" "1"
+[ $WITH_HARDENING -eq 2 ] && cnf_append "VBOX_WITH_HARDENING" "2"
+[ $WITH_VMMRAW -eq 0 ] && cnf_append "VBOX_WITH_RAW_MODE" ""
+[ $WITH_LIBTPMS -eq 0 ] && cnf_append "VBOX_WITH_LIBTPMS" ""
+[ $WITH_LIBLZMA -eq 0 ] && cnf_append "VBOX_WITH_LIBLZMA" ""
+if [ $WITH_LIBVPX -eq 0 ]; then
+ cnf_append "VBOX_WITH_LIBVPX" ""
+ cnf_append "VBOX_WITH_RECORDING" ""
+fi
+if [ $WITH_LIBOGG -eq 0 -o $WITH_LIBVORBIS -eq 0 ]; then
+ cnf_append "VBOX_WITH_LIBOGG" ""
+ cnf_append "VBOX_WITH_LIBVORBIS" ""
+ cnf_append "VBOX_WITH_AUDIO_RECORDING" ""
+fi
+
+# Darwin-specific
+[ "$OS" = "darwin" ] && check_darwinversion
+# the tools
+[ "$OS" != "darwin" ] && check_gcc
+[ "$OS" = "darwin" ] && check_xcode
+if [ $ONLY_ADDITIONS -eq 0 ]; then
+ check_open_watcom
+ [ "$OS" != "darwin" ] && check_iasl
+ [ $OSE -ge 1 ] && check_yasm
+ [ "$OS" != "darwin" ] && check_xsltproc
+fi
+
+# the libraries
+if [ $ONLY_ADDITIONS -eq 0 ]; then
+ [ "$OS" != "darwin" ] && check_pthread
+ check_libxml2
+ [ $WITH_LIBIDL -eq 1 ] && check_libidl
+ check_z
+ check_lzf
+ check_ssl
+ check_curl
+ [ $WITH_LIBVPX -eq 1 ] && check_vpx
+ [ $WITH_LIBOGG -eq 1 ] && check_libogg
+ [ $WITH_LIBVORBIS -eq 1 ] && check_libvorbis
+ [ $WITH_LIBTPMS -eq 1 ] && check_libtpms
+ [ $WITH_LIBLZMA -eq 1 ] && check_liblzma
+ [ "$OS" != "darwin" ] && check_png
+ [ $OSE -eq 0 -a "$OS" = "linux" ] && check_pam
+ if [ $WITH_SDL -eq 1 ]; then
+ check_sdl
+ else
+ cnf_append "VBOX_WITH_VBOXSDL" ""
+ fi
+ [ $WITH_SDL_TTF -eq 1 -a $OSE -eq 0 ] && check_sdl_ttf
+ [ $WITH_X11 -eq 1 ] && check_x
+ # TODO check for xcomposite-dev (X11/extensions/Xcomposite.h, additions only)
+ # TODO check for libxdamange-dev (X11/extensions/Xdamage.h, additions only)
+ [ $WITH_X11 -eq 1 ] && check_xcursor
+ [ $WITH_X11 -eq 1 ] && check_xinerama
+ [ $WITH_X11 -eq 1 ] && check_xrandr
+ [ $WITH_OPENGL -eq 1 ] && check_opengl
+ [ $WITH_QT5 -eq 1 ] && check_qt5
+ [ $WITH_PYTHON -eq 1 ] && check_python
+ [ $WITH_JAVA -eq 1 ] && check_java
+
+ # PulseAudio
+ if [ $WITH_PULSE -eq 1 ]; then
+ check_pulse
+ elif [ $WITH_PULSE -eq 0 ]; then # Force disabling PulseAudio.
+ cnf_append "VBOX_WITH_AUDIO_PULSE" ""
+ elif [ $WITH_PULSE -eq 2 ]; then # --enable-pulse was passed, force PulseAudio.
+ cnf_append "VBOX_WITH_AUDIO_PULSE" "1"
+ fi
+fi
+
+# Linux-specific
+if [ "$OS" = "linux" ]; then
+ # don't check for the static libstdc++ in the PUEL version as we build the
+ # additions at a dedicated box
+ [ $OSE -ge 1 ] && check_staticlibstdcxx
+ if [ $WITH_KMODS -eq 1 ]; then
+ check_linux
+ else
+ cnf_append "VBOX_LINUX_SRC" ""
+ cnf_append "VBOX_WITHOUT_LINUX_TEST_BUILDS" "1"
+ fi
+ if [ $ONLY_ADDITIONS -eq 0 ]; then
+ if [ $WITH_ALSA -eq 1 ]; then
+ check_alsa
+ else
+ cnf_append "VBOX_WITH_AUDIO_ALSA" ""
+ fi
+ if [ $WITH_DBUS -eq 0 ]; then
+ cnf_append "VBOX_WITH_DBUS" ""
+ fi
+ if [ $WITH_DEVMAPPER -eq 1 ]; then
+ check_libdevmapper
+ else
+ cnf_append "VBOX_WITH_DEVMAPPER" ""
+ fi
+ check_libcap
+ fi
+ check_compiler_h
+ [ $ONLY_ADDITIONS -eq 0 -a "$BUILD_MACHINE" = "amd64" -a $WITH_VMMRAW -eq 1 ] && check_32bit
+ # tools/common/makeself*
+ [ $OSE -ge 1 ] && check_makeself
+fi
+
+[ -n "$SETUP_WINE" ] && setup_wine
+
+if [ $ONLY_ADDITIONS -eq 0 ]; then
+ check_gsoap
+else
+ cnf_append "VBOX_WITH_WEBSERVICES" ""
+fi
+
+# UDPTUNNEL
+if [ $ONLY_ADDITIONS -eq 0 -a $WITH_UDPTUNNEL -eq 0 ]; then
+ cnf_append "VBOX_WITH_UDPTUNNEL" ""
+fi
+
+# VDE
+if [ $ONLY_ADDITIONS -eq 0 -a "$OS" = "linux" -o "$OS" = "freebsd" ]; then
+ if [ $WITH_VDE -eq 1 ]; then
+ cnf_append "VBOX_WITH_VDE" "1"
+ fi
+fi
+
+# DOCS
+if [ $ONLY_ADDITIONS -eq 1 -o $WITH_DOCS -eq 0 ]; then
+ cnf_append "VBOX_WITH_DOCS" ""
+ cnf_append "VBOX_WITH_DOCS_PACKING" ""
+fi
+
+# VNC server support
+if [ $ONLY_ADDITIONS -eq 0 -a $OSE -ge 1 ]; then
+ if [ $WITH_VNC = 1 ]; then
+ check_vncserver
+ else
+ cnf_append "VBOX_WITH_EXTPACK_VNC" ""
+ fi
+fi
+
+if [ $ONLY_ADDITIONS -eq 1 ]; then
+ cnf_append "VBOX_ONLY_ADDITIONS" "1"
+fi
+
+# success!
+echo
+echo "Successfully generated '$CNF' and '$ENV'."
+echo "Source '$ENV' once before you start to build VBox:"
+echo ""
+echo " source $ENV"
+echo " kmk"
+echo ""
+if [ "$OS" = "linux" ]; then
+ if [ $OUT_BASE_PATH_OVERRIDE -eq 1 ]; then
+ out_base_dir=$OUT_BASE_PATH
+ else
+ out_base_dir=.
+ fi
+ echo "To compile the kernel modules, do:"
+ echo ""
+ echo " cd $out_base_dir/out/$OS.$TARGET_MACHINE/$BUILD_TYPE/bin/src"
+ echo " make"
+ echo ""
+fi
+if [ $ONLY_ADDITIONS -eq 1 ]; then
+ echo ""
+ echo " Tree configured to build only the Guest Additions"
+ echo ""
+elif [ $WITH_HARDENING -gt 0 ]; then
+ echo ""
+ echo " +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++"
+ echo " Hardening is enabled which means that the VBox binaries will not run from"
+ echo " the binary directory. The binaries have to be installed suid root and some"
+ echo " more prerequisites have to be fulfilled which is normally done by installing"
+ echo " the final package. For development, the hardening feature can be disabled"
+ echo " by specifying the --disable-hardening parameter. Please never disable that"
+ echo " feature for the final distribution!"
+ echo " +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++"
+ echo ""
+else
+ echo ""
+ echo " +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++"
+ echo " Hardening is disabled. Please do NOT build packages for distribution with"
+ echo " disabled hardening!"
+ echo " +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++ WARNING +++"
+ echo ""
+fi
+echo "Enjoy!"
+cleanup