# ***************************************************************************
# bootstrap : Set up config.mak
# ***************************************************************************
-# Copyright (C) 2003-2007 the VideoLAN team
+# Copyright (C) 2003-2009 the VideoLAN team
# $Id$
#
# Authors: Christophe Massiot <massiot@via.ecp.fr>
# Derk-Jan Hartman <hartman at videolan dot org>
-# Felix Kühne <fkuehne@users.sourceforge.net>
+# Felix Paul Kühne <fkuehne at videolan dot 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
LANG=C
export LANG
set -e
-set -x
+set +x
BUILD=`gcc -dumpmachine`
if test "$#" -ge "1"; then
STRIP="${HOST}-strip"
fi
+case $HOST in
+ *powerpc*|*ppc*)
+ ARCH="ppc"
+ ;;
+ *86_64*)
+ ARCH="x86_64"
+ ;;
+ *86*)
+ ARCH="i386"
+ ;;
+ arm*eabi)
+ ARCH="armel"
+ ;;
+esac
+echo "ARCH = $ARCH" >> config.mak
+
# Check the HAVE_{OS}
case $HOST in
*darwin*)
*wince*)
echo "HAVE_WINCE = 1" >> config.mak
;;
- *beos*)
- echo "HAVE_BEOS = 1" >> config.mak
- ;;
esac
case $HOST in
ppc-darwin)
-# Mac OS X < 10.4
+ # Mac OS X < 10.4
echo "Your version of Mac OS X is too old!" >&2
- echo "Compiling VLC requires 10.4.x or later" >&2
+ echo "Compiling VLC requires 10.5.x or later" >&2
exit 1
;;
- powerpc-apple-darwin8)
-# Mac OS X 10.4 or 10.5 with Xcode 2.5
-# Makefile cross compiling is only supported with gcc-4.0
-# ENVP defines the oldest environment on which the program will be able to run
- SDK_TARGET=10.4
- echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
- echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
- echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.4u.sdk" >> config.mak
- CFLAGS_TUNING=" -arch ppc -mtune=G4"
- EXTRA_CFLAGS=" -D\${ENVP} -mmacosx-version-min=\${SDK_TARGET}"
- CC="gcc -isysroot \${MACOSX_SDK}"
- CXX="g++ -isysroot \${MACOSX_SDK}"
- LD="ld -arch ppc -syslibroot \${MACOSX_SDK}"
- echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
- cat src/Distributions/darwin.mak >> distro.mak
- ;;
- i686-apple-darwin8)
- SDK_TARGET=10.4
- echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
- echo "HAVE_DARWIN_OS_ON_INTEL = 1" >> config.mak
- echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
- echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.4u.sdk" >> config.mak
- CFLAGS_TUNING=" -march=pentium-m -mtune=prescott"
- EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
- EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
- echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
- cat src/Distributions/darwin.mak >> distro.mak
+ *-apple-darwin8)
+ echo "Your version of Mac OS X is too old!" >&2
+ echo "Compiling and running VLC requires 10.5.x or later" >&2
+ exit 1
;;
powerpc-apple-darwin9)
-# Mac OS X 10.5 with Xcode 3, specific rules apply
- SDK_TARGET=10.4
+ SDK_TARGET=10.5
echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
- echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.4u.sdk" >> config.mak
+ echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.5.sdk" >> config.mak
echo "HAVE_DARWIN_9 = 1" >> config.mak
+ HAVE_DARWIN_9=1
+ HAVE_DARWIN_32=1
CFLAGS_TUNING=" -arch ppc -mtune=G4"
- EXTRA_CFLAGS=" -D\${ENVP} -mmacosx-version-min=\${SDK_TARGET}"
- CC="gcc -isysroot \${MACOSX_SDK}"
- CXX="g++ -isysroot \${MACOSX_SDK}"
- LD="ld -arch ppc -syslibroot \${MACOSX_SDK}"
+ EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
+ EXTRA_LDFLAGS=" -arch ppc -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET} -Wl,-syslibroot,\${MACOSX_SDK}"
+ CC="/Developer/usr/bin/gcc-4.2"
+ CXX="/Developer/usr/bin/g++-4.2"
+ LD="ld -arch ppc -syslibroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
echo "PATH = /bin:/usr/bin:/usr/local/bin:" >> config.mak
- cat src/Distributions/darwin.mak >> distro.mak
+ DISTRO=darwin
if test -e /Developer/SDKs; then
echo "SDKs found. Everything is fine." >&2
else
exit 1
fi
;;
- i686-apple-darwin9)
- SDK_TARGET=10.4
+ i686-apple-darwin*)
+ SDK_TARGET=10.5
MIN_LD_VERSION_WITH_TEXT_RELOCATION=81
echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
echo "HAVE_DARWIN_OS_ON_INTEL = 1" >> config.mak
echo "HAVE_DARWIN_9 = 1" >> config.mak
+ HAVE_DARWIN_9=1
if test `ld -v 2> /dev/stdout | sed -E 's/.*ld64-([0-9]+).*/\1/'` -lt ${MIN_LD_VERSION_WITH_TEXT_RELOCATION}; then
echo "ERROR: Your ld version is unable to compile VLC.\nUpdate to Xcode 3.1 or higher." >&2
exit 1
fi
echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
- echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.4u.sdk" >> config.mak
- CFLAGS_TUNING=" -march=pentium-m -mtune=prescott"
+ echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.5.sdk" >> config.mak
+ HAVE_DARWIN_32=1
+ CFLAGS_TUNING=" -march=prescott -mtune=generic -arch i386 -m32"
EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
- EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
+ EXTRA_LDFLAGS=" -arch i386 -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
+ CC="/Developer/usr/bin/gcc-4.2"
+ CXX="/Developer/usr/bin/g++-4.2"
echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
- cat src/Distributions/darwin.mak >> distro.mak
+ DISTRO=darwin
if test -e /Developer/SDKs; then
echo "SDKs found. Everything is fine." >&2
else
echo "ERROR:\nYour Developer Tools' SDKs were not found.\nYou need to add extra symbolic links to /Developer to achieve correctly\nbuilt contribs.\nHave a look at the OSX-Compile-HOWTO for details." >&2
exit 1
fi
+ if test $HOST = "i686-apple-darwin10"; then
+ echo "HAVE_DARWIN_10 = 1" >> config.mak
+ fi
;;
- i686-apple-darwin10d1)
- SDK_TARGET=10.6
+ x86_64-apple-darwin*)
+ SDK_TARGET=10.5
echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
echo "HAVE_DARWIN_OS_ON_INTEL = 1" >> config.mak
echo "HAVE_DARWIN_9 = 1" >> config.mak
- echo "HAVE_DARWIN_10 = 1" >> config.mak
echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
- echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.6.sdk" >> config.mak
- CFLAGS_TUNING=" -march=pentium-m -mtune=prescott"
+ echo "MACOSX_SDK = /Developer/SDKs/MacOSX${SDK_TARGET}.sdk" >> config.mak
+ HAVE_DARWIN_64=1
+ CFLAGS_TUNING=" -march=core2 -mtune=core2 -m64 -arch x86_64"
+ echo "HAVE_DARWIN_64 = 1" >> config.mak
EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
- EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
+ EXTRA_LDFLAGS=" -arch x86_64 -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
- cat src/Distributions/darwin.mak >> distro.mak
+ CC="/Developer/usr/bin/gcc-4.2"
+ CXX="/Developer/usr/bin/g++-4.2"
+ LD="ld"
+ RANLIB="ranlib"
+ AR="ar"
+ STRIP="strip"
+ DISTRO=darwin64
if test -e /Developer/SDKs; then
echo "SDKs found. Everything is fine." >&2
else
echo "ERROR:\nYour Developer Tools' SDKs were not found.\nYou need to add extra symbolic links to /Developer to achieve correctly\nbuilt contribs.\nHave a look at the OSX-Compile-HOWTO for details." >&2
exit 1
fi
- ;;
- i586-pc-beos)
- if test -f /boot/beos/system/lib/libbind.so; then
- EXTRA_LDFLAGS=" -lbind -lsocket"
- else
- EXTRA_LDFLAGS=" -lnet"
- fi
- if test "$HOST" = "$BUILD"; then
-# Compiling on BeOS
- PATH=".:/boot/home/config/bin:/bin:/boot/apps"
- PATH="${PATH}:/boot/preferences:/boot/beos/apps"
- PATH="${PATH}:/boot/beos/preferences"
- PATH="${PATH}:/boot/develop/tools/gnupro/bin"
- echo "PATH = ${PATH}" >> config.mak
- LIBRARY_PATH="${LIBRARY_PATH}:%A/lib:/boot/home/config/lib"
- LIBRARY_PATH="${LIBRARY_PATH}:/boot/beos/system/lib"
- echo "LIBRARY_PATH = ${LIBRARY_PATH}" >> config.mak
- else
-# Cross compiling from Linux
- PATH="/opt/beos-tools/bin:/opt/cross-tools/bin"
- PATH="${PATH}:/usr/bin:/bin"
- echo "PATH = ${PATH}" >> config.mak
+ if test $HOST = "x86_64-apple-darwin10"; then
+ echo "HAVE_DARWIN_10 = 1" >> config.mak
fi
- cat src/Distributions/beos.mak >> distro.mak
+ ;;
+ *mingw32ce)
+ echo "HAVE_WINCE = 1" >> config.mak
+ echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
+ EXTRA_CPPFLAGS=" -D_WIN32_WCE=0x0500"
+ DISTRO=wince
+ ;;
+ *64-*mingw*)
+ echo "HAVE_WIN64 = 1" >> config.mak
+ echo "HAVE_WIN32 = 1" >> config.mak
+ echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
+ EXTRA_CFLAGS="-O3"
+ DISTRO=win64
;;
*mingw32*)
echo "HAVE_WIN32 = 1" >> config.mak
echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
- EXTRA_CFLAGS="-O3"
- cat src/Distributions/win32.mak >> distro.mak
+ EXTRA_CFLAGS=" -O3 -march=i686 -mtune=generic"
+ DISTRO=win32
;;
i686-pc-cygwin)
echo "HAVE_WIN32 = 1" >> config.mak
EXTRA_CPPFLAGS=" -mno-cygwin -isystem /usr/include/mingw"
EXTRA_LDFLAGS=" -mno-cygwin"
echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
- cat src/Distributions/win32.mak >> distro.mak
+ DISTRO=win32
;;
arm-wince-pe)
echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
EXTRA_CPPFLAGS=" -D_WIN32_WCE"
- cat src/Distributions/wince.mak >> distro.mak
+ DISTRO=wince
;;
armeb-linux-uclibc)
echo "HAVE_UCLIBC = 1" >> config.mak
echo "HAVE_BIGENDIAN = 1" >> config.mak
EXTRA_CFLAGS="-Os -march=armv5 -msoft-float"
- if test ! -z "${DISTRO}"; then
- cat src/Distributions/${DISTRO}.mak >> distro.mak
+ ;;
+ arm-none-linux-gnueabi)
+ if test -f /etc/maemo_version; then
+ DISTRO=maemo
+ echo 'HAVE_MAEMO = 1' >> config.mak
+ EXTRA_CFLAGS=" -mcpu=cortex-a8 -mtune=cortex-a8 -march=armv7-a"
+ EXTRA_CFLAGS="$EXTRA_CFLAGS -mfpu=neon -mfloat-abi=softfp"
+ EXTRA_CFLAGS="$EXTRA_CFLAGS -O3 -fno-tree-vectorize"
else
- cat src/Distributions/unix.mak >> distro.mak
+ EXTRA_CFLAGS="-msoft-float"
fi
;;
- *)
- if test "$HOST" = "$BUILD"; then
- if test -d "/usr/lib/pkgconfig"; then
- if test -z "$PKG_CONFIG_PATH"; then
- echo "PKG_CONFIG_PATH = /usr/lib/pkgconfig" >> config.mak
- fi
- if test -z "$PKG_CONFIG_LIBDIR"; then
- echo "PKG_CONFIG_LIBDIR = /usr/lib/pkgconfig" >> config.mak
- fi
- fi
- # Try to match distribution
- if test -f /etc/fedora-release; then
- cat src/Distributions/fedora.mak >> distro.mak
- else
- # Default Unix-like systems
- cat src/Distributions/unix.mak >> distro.mak
- fi
- else # unknown distro
- if test ! -z "${DISTRO}"; then
- cat src/Distributions/${DISTRO}.mak >> distro.mak
- else
- cat src/Distributions/unix.mak >> distro.mak
- fi
- fi
+ *86_64*linux*)
+ EXTRA_CFLAGS=" -fPIC"
+ EXTRA_CPPFLAGS=" -fPIC"
+ EXTRA_LDFLAGS=" -L/usr/lib64"
+ echo "LIBRARY_PATH = /usr/lib64" >> config.mak
+ echo "PKG_CONFIG_PATH = /usr/lib64/pkgconfig" >> config.mak
+ echo "PKG_CONFIG_LIBDIR = /usr/lib64/pkgconfig" >> config.mak
;;
esac
+if test -z "${DISTRO}" -a "$HOST" = "$BUILD"; then
+ if test -d "/usr/lib/pkgconfig"; then
+ if test -z "$PKG_CONFIG_PATH"; then
+ echo "PKG_CONFIG_PATH = /usr/lib/pkgconfig" >> config.mak
+ fi
+ if test -z "$PKG_CONFIG_LIBDIR"; then
+ echo "PKG_CONFIG_LIBDIR = /usr/lib/pkgconfig" >> config.mak
+ fi
+ fi
+ # Try to match distribution
+ if test -f /etc/fedora-release; then
+ DISTRO=fedora
+ elif test -f /etc/maemo_version; then
+ DISTRO=maemo
+ echo 'HAVE_MAEMO = 1' >> config.mak
+ elif test -f /etc/debian_version; then
+ # NOTE: check for Debian *after* its derivatives
+ DISTRO=debian
+ fi
+fi
+
+# Default Unix-like systems
+test -z "${DISTRO}" && DISTRO=unix
+
+cat src/Distributions/"${DISTRO}".mak >> distro.mak
+
echo "BUILD = $BUILD" >> config.mak
echo "HOST = $HOST" >> config.mak
-echo "PREFIX = `pwd`" >> config.mak
+echo "PREFIX = `pwd`/hosts/$HOST" >> config.mak
+
+ln -sfn hosts/$HOST build
echo "CC = ${CC}" >> config.mak
echo "CXX = ${CXX}" >> config.mak
echo "EXTRA_LDFLAGS = ${EXTRA_LDFLAGS}" >> config.mak
echo "EXTRA_PATH = ${EXTRA_PATH}" >> config.mak
+#CMAKE
+if test "$HOST" != "$BUILD"; then
+if test ${DISTRO} = "win32"; then
+echo "SET(CMAKE_SYSTEM_NAME Windows)" >> toolchain.cmake
+fi
+echo "SET(CMAKE_C_COMPILER ${CC})" >> toolchain.cmake
+echo "SET(CMAKE_CXX_COMPILER ${CXX})" >> toolchain.cmake
+echo "SET(CMAKE_FIND_ROOT_PATH `pwd` )" >> toolchain.cmake
+echo "set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)" >> toolchain.cmake
+echo "set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)" >> toolchain.cmake
+echo "set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)" >> toolchain.cmake
+fi
+
if wget --version >/dev/null 2>&1; then
echo "WGET = `which wget` -c --passive" >> config.mak
elif test -z `curl --version >/dev/null 2>&1`; then
fi
if test -z "$CONTRIBS_RELEASE"; then
+ echo "EXTRA_CFLAGS += -DNDEBUG" >> config.mak
set +x
echo
- echo "***********************************************************"
- echo "* If you are building contribs for a release build of VLC *"
- echo "* Please run CONTRIBS_RELEASE=sexy ./bootstrap *"
- echo "***********************************************************"
-else
- echo "EXTRA_CFLAGS += -DNDEBUG" >> config.mak
+ echo "*****************************************************************"
+ echo "* If you need contribs with all debug information, run this *"
+ echo "* line and compile the libraries on your own. *"
+ echo "* CONTRIBS_RELEASE=no ./bootstrap *"
+ echo "*****************************************************************"
+fi
+
+if test $HAVE_DARWIN_9; then
+ set +x
+ echo
+ echo "*****************************************************************"
+ echo "* We are using GCC-4.2 on OS X, so compilation WILL FAIL if it *"
+ echo "* is NOT installed. *"
+ echo "*****************************************************************"
+fi
+
+if test $HAVE_DARWIN_32; then
+ set +x
+ echo
+ echo "*****************************************************************"
+ echo "* VLC will be compiled in 32bit mode. *"
+ echo "* *"
+ echo "* Re-run with the x86_64-apple-darwin* argument to turn on *"
+ echo "* 64bit compilation for Intel-based Macs, whereas * is either *"
+ echo "* 9 or 10 depending on your Darwin version. *"
+ echo "* There is NO PPC64 support right now. *"
+ echo "*****************************************************************"
+fi
+
+if test $HAVE_DARWIN_64; then
+ set +x
+ echo
+ echo "*****************************************************************"
+ echo "* VLC will be compiled in 64bit mode using the 10.5 SDK. *"
+ echo "*****************************************************************"
+ set -x
fi