3 # /bin/sh on Solaris is not a POSIX compatible shell, but /usr/bin/bash is.
4 if [ `uname -s` = 'SunOS' -a "${POSIX_SHELL}" != "true" ]; then
7 exec /usr/bin/env bash $0 "$@"
9 unset POSIX_SHELL # clear it so if we invoke other scripts, they run as bash as well
22 echo "configure: WARNING: $1"
26 echo "configure: error: $1"
43 if command -v $1 >/dev/null 2>&1
44 then msg "found program '$1'"
45 else err "program '$1' is missing, please install it"
59 msg "leaving $2 unchanged"
62 chmod u-w $2 # make copied artifact read-only
69 msg "leaving $2 unchanged"
72 chmod u-w $2 # make moved artifact read-only
82 printf "configure: %-20s := %.35s ...\n" $1 "$T"
84 printf "configure: %-20s := %s %s\n" $1 "$T" "$2"
86 printf "%-20s := %s\n" $1 "$T" >>config.tmp
95 printf "configure: %-20s := %.35s ...\n" $1 "$T"
97 printf "configure: %-20s := %s %s\n" $1 "$T" "$2"
101 printf "%-20s := \n" $1 >>config.tmp
103 printf "%-20s := \"%s\"\n" $1 "$T" >>config.tmp
114 T=$(command -v $P 2>&1)
117 VER0=$($P --version 2>/dev/null \
118 | grep -o '[vV]\?[0-9][0-9.][a-z0-9.-]*' | head -1 )
119 if [ $? -eq 0 -a "x${VER0}" != "x" ]
142 err "$V needed, but unable to find any of: $*"
147 for arg in $CFG_CONFIGURE_ARGS
150 for option in $BOOL_OPTIONS
152 if test --disable-$option = $arg
156 if test --enable-$option = $arg
161 for option in $VAL_OPTIONS
163 if echo "$arg" | grep -q -- "--$option="
168 if [ "$arg" = "--help" ]
171 echo "No more help available for Configure options,"
172 echo "check the Wiki or join our IRC channel"
175 if test $isArgValid -eq 0
177 err "Option '$arg' is not recognized"
183 # `valopt OPTION_NAME DEFAULT DOC` extracts a string-valued option
184 # from command line, using provided default value for the option if
185 # not present, and saves it to the generated config.mk.
187 # `valopt_nosave` is much the same, except that it does not save the
188 # result to config.mk (instead the script should use `putvar` itself
189 # later on to save it). `valopt_core` is the core upon which the
190 # other two are built.
193 VAL_OPTIONS="$VAL_OPTIONS $2"
204 local UOP=$(echo $OP | tr '[:lower:]' '[:upper:]' | tr '\-' '\_')
206 local V_PROVIDED="${V}_PROVIDED"
208 for arg in $CFG_CONFIGURE_ARGS
210 if echo "$arg" | grep -q -- "--$OP="
212 val=$(echo "$arg" | cut -f2 -d=)
217 if [ "$SAVE" = "save" ]
226 OP="${OP}=[${DEFAULT}]"
227 printf " --%-30s %s\n" "$OP" "$DOC"
232 valopt_core nosave "$@"
236 valopt_core save "$@"
239 # `opt OPTION_NAME DEFAULT DOC` extracts a boolean-valued option from
240 # command line, using the provided default value (0/1) for the option
241 # if not present, and saves it to the generated config.mk.
243 # `opt_nosave` is much the same, except that it does not save the
244 # result to config.mk (instead the script should use `putvar` itself
245 # later on to save it). `opt_core` is the core upon which the other
249 BOOL_OPTIONS="$BOOL_OPTIONS $2"
260 if [ $DEFAULT -eq 0 ]
263 DEFAULT_FLAG="disable"
266 DEFAULT_FLAG="enable"
272 for arg in $CFG_CONFIGURE_ARGS
274 if [ "$arg" = "--${FLAG}-${OP}" ]
276 OP=$(echo $OP | tr 'a-z-' 'A-Z_')
277 FLAG=$(echo $FLAG | tr 'a-z' 'A-Z')
278 local V="CFG_${FLAG}_${OP}"
279 local V_PROVIDED="CFG_${FLAG}_${OP}_PROVIDED"
282 if [ "$SAVE" = "save" ]
286 elif [ "$arg" = "--${DEFAULT_FLAG}-${OP}" ]
288 OP=$(echo $OP | tr 'a-z-' 'A-Z_')
289 DEFAULT_FLAG=$(echo $DEFAULT_FLAG | tr 'a-z' 'A-Z')
290 local V_PROVIDED="CFG_${DEFAULT_FLAG}_${OP}_PROVIDED"
299 printf " --%-30s %s\n" "$FLAG-$OP" "$DOC"
313 local V="CFG_${NAME}"
316 # If configure didn't set a value already, then check environment.
318 # (It is recommended that the configure script always check the
319 # environment before setting any values to envopt variables; see
320 # e.g. how CFG_CC is handled, where it first checks `-z "$CC"`,
321 # and issues msg if it ends up employing that provided value.)
328 # If script or environment provided a value, save it.
335 enable_if_not_disabled() {
337 local UOP=$(echo $OP | tr '[:lower:]' '[:upper:]' | tr '\-' '\_')
338 local ENAB_V="CFG_ENABLE_$UOP"
339 local EXPLICITLY_DISABLED="CFG_DISABLE_${UOP}_PROVIDED"
340 eval VV=\$$EXPLICITLY_DISABLED
341 if [ -z "$VV" ]; then
348 i686-pc-windows-gnu) echo i686-w64-mingw32 ;;
349 x86_64-pc-windows-gnu) echo x86_64-w64-mingw32 ;;
354 # Prints the absolute path of a directory to stdout
357 # Unset CDPATH because it causes havok: it makes the destination unpredictable
358 # and triggers 'cd' to print the path to stdout. Route `cd`'s output to /dev/null
360 (unset CDPATH && cd "$_path" > /dev/null && pwd)
370 msg "looking for configure programs"
387 msg "inspecting environment"
389 CFG_OSTYPE=$(uname -s)
390 CFG_CPUTYPE=$(uname -m)
392 if [ $CFG_OSTYPE = Darwin -a $CFG_CPUTYPE = i386 ]
394 # Darwin's `uname -s` lies and always returns i386. We have to use sysctl
396 if sysctl hw.optional.x86_64 | grep -q ': 1'
402 # The goal here is to come up with the same triple as LLVM would,
403 # at least for the subset of platforms we're willing to target.
408 CFG_OSTYPE=unknown-linux-gnu
412 CFG_OSTYPE=unknown-freebsd
416 CFG_OSTYPE=unknown-dragonfly
420 CFG_OSTYPE=unknown-bitrig
424 CFG_OSTYPE=unknown-openbsd
428 CFG_OSTYPE=unknown-netbsd
432 CFG_OSTYPE=apple-darwin
436 CFG_OSTYPE=sun-solaris
437 CFG_CPUTYPE=$(isainfo -n)
441 CFG_OSTYPE=unknown-haiku
445 # msys' `uname` does not print gcc configuration, but prints msys
446 # configuration. so we cannot believe `uname -m`:
447 # msys1 is always i686 and msys2 is always x86_64.
448 # instead, msys defines $MSYSTEM which is MINGW32 on i686 and
451 CFG_OSTYPE=pc-windows-gnu
452 if [ "$MSYSTEM" = MINGW64 ]
459 CFG_OSTYPE=pc-windows-gnu
462 # Thad's Cygwin identifiers below
466 CFG_OSTYPE=pc-windows-gnu
472 CFG_OSTYPE=pc-windows-gnu
478 CFG_OSTYPE=pc-windows-gnu
484 CFG_OSTYPE=pc-windows-gnu
488 # Win 8 # uname -s on 64-bit cygwin does not contain WOW64, so simply use uname -m to detect arch (works in my install)
490 CFG_OSTYPE=pc-windows-gnu
492 # We do not detect other OS such as XP/2003 using 64 bit using uname.
493 # If we want to in the future, we will need to use Cygwin - Chuck's csih helper in /usr/lib/csih/winProductName.exe or alternative.
495 err "unknown OS type: $CFG_OSTYPE"
502 i386 | i486 | i686 | i786 | x86)
512 CFG_OSTYPE="${CFG_OSTYPE}eabihf"
517 CFG_OSTYPE="${CFG_OSTYPE}eabihf"
529 CFG_CPUTYPE=powerpc64
532 powerpc64le | ppc64le)
533 CFG_CPUTYPE=powerpc64le
540 x86_64 | x86-64 | x64 | amd64)
545 if [ "$CFG_CPUTYPE" = "mips64" ]; then
546 CFG_OSTYPE="${CFG_OSTYPE}abi64"
548 ENDIAN=$(printf '\1' | od -dAn)
549 if [ "$ENDIAN" -eq 1 ]; then
550 CFG_CPUTYPE="${CFG_CPUTYPE}el"
551 elif [ "$ENDIAN" -ne 256 ]; then
552 err "unknown endianness: $ENDIAN (expecting 1 for little or 256 for big)"
561 err "unknown CPU type: $CFG_CPUTYPE"
564 # Detect 64 bit linux systems with 32 bit userland and force 32 bit compilation
565 if [ $CFG_OSTYPE = unknown-linux-gnu -a $CFG_CPUTYPE = x86_64 ]
567 # $SHELL does not exist in standard 'sh', so probably only exists
568 # if configure is running in an interactive bash shell. /usr/bin/env
569 # exists *everywhere*.
570 BIN_TO_PROBE="$SHELL"
571 if [ ! -r "$BIN_TO_PROBE" ]; then
572 if [ -r "/usr/bin/env" ]; then
573 BIN_TO_PROBE="/usr/bin/env"
575 warn "Cannot check if the userland is i686 or x86_64"
578 file -L "$BIN_TO_PROBE" | grep -q "x86[_-]64"
580 msg "i686 userland on x86_64 Linux kernel"
586 DEFAULT_BUILD="${CFG_CPUTYPE}-${CFG_OSTYPE}"
588 CFG_SRC_DIR="$(abs_path $(dirname $0))/"
589 CFG_SRC_DIR_RELATIVE="$(dirname $0)/"
590 CFG_BUILD_DIR="$(pwd)/"
592 CFG_CONFIGURE_ARGS="$@"
595 case "${CFG_SRC_DIR}" in
597 err "The path to the rust source directory contains spaces, which is not supported"
608 echo "Usage: $CFG_SELF [options]"
613 msg "recreating config.tmp"
616 step_msg "processing $CFG_SELF args"
622 opt debug 0 "debug mode; disables optimization unless \`--enable-optimize\` given"
623 opt valgrind 0 "run tests with valgrind (memcheck by default)"
624 opt helgrind 0 "run tests with helgrind instead of memcheck"
625 opt valgrind-rpass 1 "run rpass-valgrind tests with valgrind"
626 opt docs 1 "build standard library documentation"
627 opt compiler-docs 0 "build compiler documentation"
628 opt optimize-tests 1 "build tests with optimizations"
629 opt debuginfo-tests 0 "build tests with debugger metadata"
630 opt quiet-tests 0 "enable quieter output when running tests"
631 opt libcpp 1 "build llvm with libc++ instead of libstdc++ when using clang"
632 opt llvm-assertions 0 "build LLVM with assertions"
633 opt debug-assertions 0 "build with debugging assertions"
634 opt fast-make 0 "use .gitmodules as timestamp for submodule deps"
635 opt ccache 0 "invoke gcc/clang via ccache to reuse object files between builds"
636 opt sccache 0 "invoke gcc/clang via sccache to reuse object files between builds"
637 opt local-rust 0 "use an installed rustc rather than downloading a snapshot"
638 opt local-rebuild 0 "assume local-rust matches the current version, for rebuilds; implies local-rust, and is implied if local-rust already matches the current version"
639 opt llvm-static-stdcpp 0 "statically link to libstdc++ for LLVM"
640 opt llvm-link-shared 0 "prefer shared linking to LLVM (llvm-config --link-shared)"
641 opt rpath 1 "build rpaths into rustc itself"
642 opt stage0-landing-pads 1 "enable landing pads during bootstrap with stage0"
643 # This is used by the automation to produce single-target nightlies
644 opt dist-host-only 0 "only install bins for the host architecture"
645 opt inject-std-version 1 "inject the current compiler version of libstd into programs"
646 opt llvm-version-check 1 "check if the LLVM version is supported, build anyway"
647 opt rustbuild 1 "use the rust and cargo based build system"
648 opt codegen-tests 1 "run the src/test/codegen tests"
649 opt option-checking 1 "complain about unrecognized options in this configure script"
650 opt ninja 0 "build LLVM using the Ninja generator (for MSVC, requires building in the correct environment)"
651 opt vendor 0 "enable usage of vendored Rust crates"
653 # Optimization and debugging options. These may be overridden by the release channel, etc.
654 opt_nosave optimize 1 "build optimized rust code"
655 opt_nosave optimize-cxx 1 "build optimized C++ code"
656 opt_nosave optimize-llvm 1 "build optimized LLVM"
657 opt_nosave llvm-assertions 0 "build LLVM with assertions"
658 opt_nosave debug-assertions 0 "build with debugging assertions"
659 opt_nosave llvm-release-debuginfo 0 "build LLVM with debugger metadata"
660 opt_nosave debuginfo 0 "build with debugger metadata"
661 opt_nosave debuginfo-lines 0 "build with line number debugger metadata"
662 opt_nosave debuginfo-only-std 0 "build only libstd with debugging information"
663 opt_nosave debug-jemalloc 0 "build jemalloc with --enable-debug --enable-fill"
665 valopt localstatedir "/var/lib" "local state directory"
666 valopt sysconfdir "/etc" "install system configuration files"
668 valopt datadir "${CFG_PREFIX}/share" "install data"
669 valopt infodir "${CFG_PREFIX}/share/info" "install additional info"
670 valopt llvm-root "" "set LLVM root"
671 valopt python "" "set path to python"
672 valopt jemalloc-root "" "set directory where libjemalloc_pic.a is located"
673 valopt build "${DEFAULT_BUILD}" "GNUs ./configure syntax LLVM build triple"
674 valopt android-cross-path "" "Android NDK standalone path (deprecated)"
675 valopt i686-linux-android-ndk "" "i686-linux-android NDK standalone path"
676 valopt arm-linux-androideabi-ndk "" "arm-linux-androideabi NDK standalone path"
677 valopt armv7-linux-androideabi-ndk "" "armv7-linux-androideabi NDK standalone path"
678 valopt aarch64-linux-android-ndk "" "aarch64-linux-android NDK standalone path"
679 valopt nacl-cross-path "" "NaCl SDK path (Pepper Canary is recommended). Must be absolute!"
680 valopt musl-root "/usr/local" "MUSL root installation directory (deprecated)"
681 valopt musl-root-x86_64 "" "x86_64-unknown-linux-musl install directory"
682 valopt musl-root-i686 "" "i686-unknown-linux-musl install directory"
683 valopt musl-root-arm "" "arm-unknown-linux-musleabi install directory"
684 valopt musl-root-armhf "" "arm-unknown-linux-musleabihf install directory"
685 valopt musl-root-armv7 "" "armv7-unknown-linux-musleabihf install directory"
686 valopt extra-filename "" "Additional data that is hashed and passed to the -C extra-filename flag"
688 if [ -e ${CFG_SRC_DIR}.git ]
690 valopt release-channel "dev" "the name of the release channel to build"
692 # If we have no git directory then we are probably a tarball distribution
693 # and should default to stable channel - Issue 28322
695 msg "git: no git directory. Changing default release channel to stable"
696 valopt release-channel "stable" "the name of the release channel to build"
699 # Used on systems where "cc" and "ar" are unavailable
700 valopt default-linker "cc" "the default linker"
701 valopt default-ar "ar" "the default ar"
703 # Many of these are saved below during the "writing configuration" step
704 # (others are conditionally saved).
705 opt_nosave manage-submodules 1 "let the build manage the git submodules"
706 opt_nosave clang 0 "prefer clang to gcc for building the runtime"
707 opt_nosave jemalloc 1 "build liballoc with jemalloc"
708 opt elf-tls 1 "elf thread local storage on platforms where supported"
709 opt full-bootstrap 0 "build three compilers instead of two"
710 opt extended 0 "build an extended rust tool set"
712 valopt_nosave prefix "/usr/local" "set installation prefix"
713 valopt_nosave local-rust-root "/usr/local" "set prefix for local rust binary"
714 valopt_nosave host "${CFG_BUILD}" "GNUs ./configure syntax LLVM host triples"
715 valopt_nosave target "${CFG_HOST}" "GNUs ./configure syntax LLVM target triples"
716 valopt_nosave mandir "${CFG_PREFIX}/share/man" "install man pages in PATH"
717 valopt_nosave docdir "${CFG_PREFIX}/share/doc/rust" "install documentation in PATH"
719 # On Windows this determines root of the subtree for target libraries.
720 # Host runtime libs always go to 'bin'.
721 valopt libdir "${CFG_PREFIX}/lib" "install libraries"
723 case "$CFG_LIBDIR" in
724 "$CFG_PREFIX"/*) CAT_INC=2;;
725 "$CFG_PREFIX"*) CAT_INC=1;;
727 err "libdir must begin with the prefix. Use --prefix to set it accordingly.";;
730 CFG_LIBDIR_RELATIVE=`echo ${CFG_LIBDIR} | cut -c$((${#CFG_PREFIX}+${CAT_INC}))-`
739 if [ -z "$CFG_DISABLE_OPTION_CHECKING" ]
741 step_msg "validating $CFG_SELF args"
745 # Validate the release channel, and configure options
746 case "$CFG_RELEASE_CHANNEL" in
748 msg "overriding settings for $CFG_RELEASE_CHANNEL"
749 enable_if_not_disabled llvm-assertions
750 # FIXME(stage0) re-enable this on the next stage0 now that #35566 is
756 CFG_ENABLE_DEBUGINFO_LINES=1
757 CFG_ENABLE_DEBUGINFO_ONLY_STD=1
763 msg "overriding settings for $CFG_RELEASE_CHANNEL"
768 CFG_ENABLE_DEBUGINFO_LINES=1
769 CFG_ENABLE_DEBUGINFO_ONLY_STD=1
776 err "release channel must be 'dev', 'nightly', 'beta' or 'stable'"
780 # Adjust perf and debug options for debug mode
781 if [ -n "$CFG_ENABLE_DEBUG" ]; then
782 msg "debug mode enabled, setting performance options"
783 if [ -z "$CFG_ENABLE_OPTIMIZE_PROVIDED" ]; then
784 msg "optimization not explicitly enabled, disabling optimization"
785 CFG_DISABLE_OPTIMIZE=1
786 CFG_DISABLE_OPTIMIZE_CXX=1
789 # Set following variables to 1 unless setting already provided
790 enable_if_not_disabled debug-assertions
791 enable_if_not_disabled debug-jemalloc
792 enable_if_not_disabled debuginfo
793 enable_if_not_disabled llvm-assertions
796 # OK, now write the debugging options
797 if [ -n "$CFG_DISABLE_OPTIMIZE" ]; then putvar CFG_DISABLE_OPTIMIZE; fi
798 if [ -n "$CFG_DISABLE_OPTIMIZE_CXX" ]; then putvar CFG_DISABLE_OPTIMIZE_CXX; fi
799 if [ -n "$CFG_DISABLE_OPTIMIZE_LLVM" ]; then putvar CFG_DISABLE_OPTIMIZE_LLVM; fi
800 if [ -n "$CFG_ENABLE_LLVM_ASSERTIONS" ]; then putvar CFG_ENABLE_LLVM_ASSERTIONS; fi
801 if [ -n "$CFG_ENABLE_DEBUG_ASSERTIONS" ]; then putvar CFG_ENABLE_DEBUG_ASSERTIONS; fi
802 if [ -n "$CFG_ENABLE_LLVM_RELEASE_DEBUGINFO" ]; then putvar CFG_ENABLE_LLVM_RELEASE_DEBUGINFO; fi
803 if [ -n "$CFG_ENABLE_DEBUGINFO" ]; then putvar CFG_ENABLE_DEBUGINFO; fi
804 if [ -n "$CFG_ENABLE_DEBUGINFO_LINES" ]; then putvar CFG_ENABLE_DEBUGINFO_LINES; fi
805 if [ -n "$CFG_ENABLE_DEBUGINFO_ONLY_STD" ]; then putvar CFG_ENABLE_DEBUGINFO_ONLY_STD; fi
806 if [ -n "$CFG_ENABLE_DEBUG_JEMALLOC" ]; then putvar CFG_ENABLE_DEBUG_JEMALLOC; fi
808 step_msg "looking for build programs"
810 probe_need CFG_CURL curl
811 if [ -z "$CFG_PYTHON_PROVIDED" ]; then
812 probe_need CFG_PYTHON python2.7 python2 python
815 python_version=$($CFG_PYTHON -V 2>&1)
816 if [ $(echo $python_version | grep -c '^Python 2\.7') -ne 1 ]; then
817 err "Found $python_version, but Python 2.7 is required"
820 # If we have no git directory then we are probably a tarball distribution
821 # and shouldn't attempt to load submodules
822 if [ ! -e ${CFG_SRC_DIR}.git ]
825 msg "git: no git directory. disabling submodules"
826 CFG_DISABLE_MANAGE_SUBMODULES=1
828 probe_need CFG_GIT git
831 # Use `md5sum` on GNU platforms, or `md5 -q` on BSD
833 probe CFG_MD5SUM md5sum
836 CFG_HASH_COMMAND="$CFG_MD5 -q | cut -c 1-8"
837 elif [ -n "$CFG_MD5SUM" ]
839 CFG_HASH_COMMAND="$CFG_MD5SUM | cut -c 1-8"
841 err 'could not find one of: md5 md5sum'
843 putvar CFG_HASH_COMMAND
845 probe CFG_CLANG clang++
846 probe CFG_CCACHE ccache
849 probe CFG_VALGRIND valgrind
852 probe CFG_ANTLR4 antlr4
855 probe CFG_BISON bison
859 if [ -n "$CFG_ENABLE_NINJA" ]
861 probe CFG_NINJA ninja
862 if [ -z "$CFG_NINJA" ]
864 # On Debian and Fedora, the `ninja` binary is an IRC bot, so the build tool was
865 # renamed. Handle this case.
866 probe CFG_NINJA ninja-build
871 if [ -z "$CFG_LLVM_ROOT" ]
873 probe_need CFG_CMAKE cmake
876 # On MacOS X, invoking `javac` pops up a dialog if the JDK is not
877 # installed. Since `javac` is only used if `antlr4` is available,
878 # probe for it only in this case.
879 if [ -n "$CFG_ANTLR4" ]
881 CFG_ANTLR4_JAR="\"$(find /usr/ -name antlr-complete.jar 2>/dev/null | head -n 1)\""
882 if [ "x" = "x$CFG_ANTLR4_JAR" ]
884 CFG_ANTLR4_JAR="\"$(find ~ -name antlr-complete.jar 2>/dev/null | head -n 1)\""
886 putvar CFG_ANTLR4_JAR $CFG_ANTLR4_JAR
887 probe CFG_JAVAC javac
890 # the valgrind rpass tests will fail if you don't have a valgrind, but they're
891 # only disabled if you opt out.
892 if [ -z "$CFG_VALGRIND" ]
894 # If the user has explicitly asked for valgrind tests, then fail
895 if [ -n "$CFG_ENABLE_VALGRIND" ] && [ -n "$CFG_ENABLE_VALGRIND_PROVIDED" ]
897 err "No valgrind present, but valgrind tests explicitly requested"
899 CFG_DISABLE_VALGRIND_RPASS=1
900 putvar CFG_DISABLE_VALGRIND_RPASS
904 if [ -n "$CFG_LLDB" ]
906 # Store LLDB's version
907 CFG_LLDB_VERSION=$($CFG_LLDB --version 2>/dev/null | head -1)
908 putvar CFG_LLDB_VERSION
910 # If CFG_LLDB_PYTHON_DIR is not already set from the outside and valid, try to read it from
911 # LLDB via the -P commandline options.
912 if [ -z "$CFG_LLDB_PYTHON_DIR" ] || [ ! -d "$CFG_LLDB_PYTHON_DIR" ]
914 CFG_LLDB_PYTHON_DIR=$($CFG_LLDB -P)
916 # If CFG_LLDB_PYTHON_DIR is not a valid directory, set it to something more readable
917 if [ ! -d "$CFG_LLDB_PYTHON_DIR" ]
919 CFG_LLDB_PYTHON_DIR="LLDB_PYTHON_DIRECTORY_NOT_FOUND"
922 putvar CFG_LLDB_PYTHON_DIR
926 # LLDB tests on OSX require /usr/bin/python, not something like Homebrew's
927 # /usr/local/bin/python. We're loading a compiled module for LLDB tests which is
928 # only compatible with the system.
931 CFG_LLDB_PYTHON=/usr/bin/python
934 CFG_LLDB_PYTHON=$CFG_PYTHON
937 putvar CFG_LLDB_PYTHON
939 # Do some sanity checks if running on buildbot
940 # (these env vars are set by rust-buildbot)
941 if [ -n "$RUST_DIST_SERVER" -a -n "$ALLOW_NONZERO_RLIMIT_CORE" ]; then
942 # Frequently the llvm submodule directory is broken by the build
944 llvm_lock="${CFG_SRC_DIR}/.git/modules/src/llvm/index.lock"
945 if [ -e "$llvm_lock" ]; then
946 step_msg "removing $llvm_lock"
951 step_msg "looking for target specific programs"
956 if [ "$CFG_OSTYPE" = "pc-windows-gnu" ] || [ "$CFG_OSTYPE" = "pc-windows-msvc" ]
961 # --enable-local-rebuild implies --enable-local-rust too
962 if [ -n "$CFG_ENABLE_LOCAL_REBUILD" ]
964 if [ -z "$CFG_ENABLE_LOCAL_RUST" ]
966 CFG_ENABLE_LOCAL_RUST=1
967 putvar CFG_ENABLE_LOCAL_RUST
971 if [ -n "$CFG_ENABLE_LOCAL_RUST" ]
973 system_rustc=$(which rustc)
974 if [ -f ${CFG_LOCAL_RUST_ROOT}/bin/rustc${BIN_SUF} ]
976 : # everything already configured
977 elif [ -n "$system_rustc" ]
979 # we assume that rustc is in a /bin directory
980 CFG_LOCAL_RUST_ROOT=${system_rustc%/bin/rustc}
982 err "no local rust to use"
985 CMD="${CFG_LOCAL_RUST_ROOT}/bin/rustc${BIN_SUF}"
986 LRV=`LD_LIBRARY_PATH=${CFG_LOCAL_RUST_ROOT}/lib $CMD --version`
989 step_msg "failure while running $CMD --version"
992 step_msg "using rustc at: ${CFG_LOCAL_RUST_ROOT} with version: $LRV"
993 putvar CFG_LOCAL_RUST_ROOT
996 # Force bitrig to build with clang; gcc doesn't like us there
997 if [ $CFG_OSTYPE = unknown-bitrig ]
999 step_msg "on Bitrig, forcing use of clang"
1003 # default gcc version under OpenBSD maybe too old, try using egcc, which is a
1004 # gcc version from ports
1005 if [ $CFG_OSTYPE = unknown-openbsd ]
1007 if [ $("$CFG_GCC" --version 2>&1 | grep -c ' 4\.[0-6]') -ne 0 ]; then
1008 step_msg "older GCC found, try with egcc instead"
1010 # probe again but using egcc
1013 # and use egcc/eg++ for CC/CXX too if it was found
1014 # (but user setting has priority)
1015 if [ -n "$CFG_GCC" ]; then
1022 # OS X 10.9, gcc is actually clang. This can cause some confusion in the build
1023 # system, so if we find that gcc is clang, we should just use clang directly.
1024 if [ $CFG_OSTYPE = apple-darwin -a -z "$CFG_ENABLE_CLANG" ]
1026 CFG_OSX_GCC_VERSION=$("$CFG_GCC" --version 2>&1 | grep "Apple LLVM version")
1029 step_msg "on OS X >=10.9, forcing use of clang"
1032 if [ $("$CFG_GCC" --version 2>&1 | grep -c ' 4\.[0-6]') -ne 0 ]; then
1033 step_msg "older GCC found, using clang instead"
1036 # on OS X, with xcode 5 and newer, certain developers may have
1037 # cc, gcc and g++ point to a mixture of clang and gcc
1038 # if so, this will create very strange build errors
1039 # this last stanza is to detect some such problems and save the future rust
1040 # contributor some time solving that issue.
1041 # this detection could be generalized to other OSes aside from OS X
1042 # but the issue seems most likely to happen on OS X
1045 $1 --version 2> /dev/null | grep -q $2
1047 # check that gcc, cc and g++ all point to the same compiler.
1048 # note that for xcode 5, g++ points to clang, not clang++
1049 if !((chk_cc gcc clang && chk_cc g++ clang) ||
1050 (chk_cc gcc gcc &&( chk_cc g++ g++ || chk g++ gcc))); then
1051 err "the gcc and g++ in your path point to different compilers.
1052 Check which versions are in your path with gcc --version and g++ --version.
1053 To resolve this problem, either fix your PATH or run configure with --enable-clang"
1060 # If the clang isn't already enabled, check for GCC, and if it is missing, turn
1061 # on clang as a backup.
1062 if [ -z "$CFG_ENABLE_CLANG" ]
1064 CFG_GCC_VERSION=$("$CFG_GCC" --version 2>&1)
1067 step_msg "GCC not installed, will try using Clang"
1072 # Okay, at this point, we have made up our minds about whether we are
1073 # going to force CFG_ENABLE_CLANG or not; save the setting if so.
1074 if [ -n "$CFG_ENABLE_CLANG" ]
1076 putvar CFG_ENABLE_CLANG
1079 if [ -z "$CFG_DISABLE_LIBCPP" -a -n "$CFG_ENABLE_CLANG" ]
1081 CFG_USING_LIBCPP="1"
1083 CFG_USING_LIBCPP="0"
1086 # Same with jemalloc. save the setting here.
1087 if [ -n "$CFG_DISABLE_JEMALLOC" ]
1089 putvar CFG_DISABLE_JEMALLOC
1092 if [ -n "$CFG_LLVM_ROOT" -a -z "$CFG_DISABLE_LLVM_VERSION_CHECK" -a -e "$CFG_LLVM_ROOT/bin/llvm-config" ]
1094 step_msg "using custom LLVM at $CFG_LLVM_ROOT"
1096 LLVM_CONFIG="$CFG_LLVM_ROOT/bin/llvm-config"
1097 LLVM_VERSION=$($LLVM_CONFIG --version)
1099 case $LLVM_VERSION in
1101 msg "found ok version of LLVM: $LLVM_VERSION"
1104 err "bad LLVM version: $LLVM_VERSION, need >=3.7"
1108 if "$CFG_LLVM_ROOT/bin/llvm-mc" -help | grep -- "-relocation-model"; then
1109 msg "found older llvm-mc"
1110 CFG_LLVM_MC_HAS_RELOCATION_MODEL=1
1111 putvar CFG_LLVM_MC_HAS_RELOCATION_MODEL
1115 # Even when the user overrides the choice of CC, still try to detect
1116 # clang to disable some clang-specific warnings. We here draw a
1117 # distinction between:
1119 # CFG_ENABLE_CLANG : passed --enable-clang, or host "requires" clang,
1120 # CFG_USING_CLANG : compiler (clang / gcc / $CC) looks like clang.
1122 # This distinction is important because there are some safeguards we
1123 # would prefer to skip when merely CFG_USING_CLANG is set; but when
1124 # CFG_ENABLE_CLANG is set, that indicates that we are opting into
1125 # running such safeguards.
1129 msg "skipping compiler inference steps; using provided CC=$CC"
1132 CFG_OSX_CC_VERSION=$("$CFG_CC" --version 2>&1 | grep "clang")
1135 step_msg "note, user-provided CC looks like clang; CC=$CC."
1137 putvar CFG_USING_CLANG
1140 if [ -n "$CFG_ENABLE_CLANG" ]
1142 if [ -z "$CFG_CLANG" ]
1144 err "clang requested but not found"
1148 putvar CFG_USING_CLANG
1154 if [ -n "$CFG_ENABLE_CLANG" ]
1166 if [ -n "$CFG_ENABLE_CCACHE" ]
1168 if [ -z "$CFG_CCACHE" ]
1170 err "ccache requested but not found"
1173 CFG_CC="ccache $CFG_CC"
1176 if [ -z "$CC" -a -z "$CFG_ENABLE_CLANG" -a -z "$CFG_GCC" ]
1178 err "either clang or gcc is required"
1181 # All safeguards based on $CFG_ENABLE_CLANG should occur before this
1182 # point in the script; after this point, script logic should inspect
1183 # $CFG_USING_CLANG rather than $CFG_ENABLE_CLANG.
1185 # Set CFG_{CC,CXX,CPP,CFLAGS,CXXFLAGS,LDFLAGS}
1193 # stdc++ name in use
1194 # used to manage non-standard name (on OpenBSD for example)
1195 program_transform_name=$($CFG_CC -v 2>&1 | sed -n "s/.*--program-transform-name='\([^']*\)'.*/\1/p")
1196 CFG_STDCPP_NAME=$(echo "stdc++" | sed "${program_transform_name}")
1197 putvar CFG_STDCPP_NAME
1199 # a little post-processing of various config values
1200 CFG_PREFIX=${CFG_PREFIX%/}
1201 CFG_MANDIR=${CFG_MANDIR%/}
1202 CFG_DOCDIR=${CFG_DOCDIR%/}
1203 CFG_HOST="$(echo $CFG_HOST | tr ',' ' ')"
1204 CFG_TARGET="$(echo $CFG_TARGET | tr ',' ' ')"
1205 CFG_SUPPORTED_TARGET=""
1206 for target_file in ${CFG_SRC_DIR}mk/cfg/*.mk; do
1207 CFG_SUPPORTED_TARGET="${CFG_SUPPORTED_TARGET} $(basename "$target_file" .mk)"
1210 # copy build-triples to host-triples so that builds are a subset of hosts
1212 for i in $CFG_BUILD $CFG_HOST;
1214 echo "$V_TEMP" | grep -qF $i || V_TEMP="$V_TEMP${V_TEMP:+ }$i"
1218 # copy host-triples to target-triples so that hosts are a subset of targets
1220 for i in $CFG_HOST $CFG_TARGET;
1222 echo "$V_TEMP" | grep -qF $i || V_TEMP="$V_TEMP${V_TEMP:+ }$i"
1226 # check target-specific tool-chains
1227 for i in $CFG_TARGET
1230 for j in $CFG_SUPPORTED_TARGET
1238 if [ $L_CHECK = false ]
1240 err "unsupported target triples \"$i\" found"
1246 armv7-linux-androideabi)
1247 cmd_prefix="arm-linux-androideabi"
1254 upper_snake_target=$(echo "$i" | tr '[:lower:]' '[:upper:]' | tr '\-' '\_')
1255 eval ndk=\$"CFG_${upper_snake_target}_NDK"
1258 ndk=$CFG_ANDROID_CROSS_PATH
1259 eval "CFG_${upper_snake_target}_NDK"=$CFG_ANDROID_CROSS_PATH
1260 warn "generic/default Android NDK option is deprecated (use --$i-ndk option instead)"
1263 # Perform a basic sanity check of the NDK
1264 for android_ndk_tool in "$ndk/bin/$cmd_prefix-gcc" "$ndk/bin/$cmd_prefix-g++" "$ndk/bin/$cmd_prefix-ar"
1266 if [ ! -f $android_ndk_tool ]
1268 err "NDK tool $android_ndk_tool not found (bad or missing --$i-ndk option?)"
1273 if [ -z "$CFG_NACL_CROSS_PATH" ]
1275 err "I need the NaCl SDK path! (use --nacl-cross-path)"
1279 if [ $CFG_OSTYPE != apple-darwin ]
1281 err "The iOS target is only supported on Mac OS X"
1286 # There are three builds of cmake on windows: MSVC, MinGW and Cygwin
1287 # The Cygwin build does not have generators for Visual Studio, so
1288 # detect that here and error.
1289 if ! "$CFG_CMAKE" --help | sed -n '/^Generators/,$p' | grep 'Visual Studio' > /dev/null
1293 cmake does not support Visual Studio generators.
1295 This is likely due to it being an msys/cygwin build of cmake, \
1296 rather than the required windows version, built using MinGW \
1299 If you are building under msys2 try installing the mingw-w64-x86_64-cmake \
1300 package instead of cmake:
1302 $ pacman -R cmake && pacman -S mingw-w64-x86_64-cmake
1306 # Use the REG program to figure out where VS is installed
1307 # We need to figure out where cl.exe and link.exe are, so we do some
1308 # munging and some probing here. We also look for the default
1309 # INCLUDE and LIB variables for MSVC so we can set those in the
1310 # build system as well.
1311 install=$(cmd //c reg QUERY \
1312 'HKLM\SOFTWARE\Wow6432Node\Microsoft\VisualStudio\14.0' \
1314 if [ -z "$install" ]; then
1315 install=$(cmd //c reg QUERY \
1316 'HKLM\SOFTWARE\Wow6432Node\Microsoft\VisualStudio\12.0' \
1319 need_ok "couldn't find visual studio install root"
1320 CFG_MSVC_ROOT=$(echo "$install" | grep InstallDir | sed 's/.*REG_SZ[ ]*//')
1321 CFG_MSVC_ROOT=$(dirname "$CFG_MSVC_ROOT")
1322 CFG_MSVC_ROOT=$(dirname "$CFG_MSVC_ROOT")
1323 putvar CFG_MSVC_ROOT
1335 err "can only target x86 targets for MSVC"
1338 bindir="${CFG_MSVC_ROOT}/VC/bin"
1339 if [ -n "$msvc_part" ]; then
1340 bindir="$bindir/$msvc_part"
1342 eval CFG_MSVC_BINDIR_$bits="\"$bindir\""
1343 eval CFG_MSVC_CL_$bits="\"$bindir/cl.exe\""
1344 eval CFG_MSVC_LIB_$bits="\"$bindir/lib.exe\""
1345 eval CFG_MSVC_LINK_$bits="\"$bindir/link.exe\""
1347 vcvarsall="${CFG_MSVC_ROOT}/VC/vcvarsall.bat"
1348 include_path=$(cmd //V:ON //c "$vcvarsall" $msvc_part \& echo !INCLUDE!)
1349 need_ok "failed to learn about MSVC's INCLUDE"
1350 lib_path=$(cmd //V:ON //c "$vcvarsall" $msvc_part \& echo !LIB!)
1351 need_ok "failed to learn about MSVC's LIB"
1353 eval CFG_MSVC_INCLUDE_PATH_${bits}="\"$include_path\""
1354 eval CFG_MSVC_LIB_PATH_${bits}="\"$lib_path\""
1356 putvar CFG_MSVC_BINDIR_${bits}
1357 putvar CFG_MSVC_CL_${bits}
1358 putvar CFG_MSVC_LIB_${bits}
1359 putvar CFG_MSVC_LINK_${bits}
1360 putvar CFG_MSVC_INCLUDE_PATH_${bits}
1361 putvar CFG_MSVC_LIB_PATH_${bits}
1369 if [ "$CFG_OSTYPE" = "pc-windows-gnu" ] || [ "$CFG_OSTYPE" = "pc-windows-msvc" ]
1371 # There are some MSYS python builds which will auto-translate
1372 # windows-style paths to MSYS-style paths in Python itself.
1373 # Unfortunately this breaks LLVM's build system as somewhere along
1374 # the line LLVM prints a path into a file from Python and then CMake
1375 # later tries to interpret that path. If Python prints a MSYS path
1376 # and CMake tries to use it as a Windows path, you're gonna have a
1379 # Consequently here we try to detect when that happens and print an
1381 if $CFG_PYTHON -c 'import sys; print sys.argv[1]' `pwd` | grep '^/' > /dev/null
1385 python is silently translating windows paths to MSYS paths \
1386 and the build will fail if this python is used.
1388 Either an official python install must be used or an \
1389 alternative python package in MinGW must be used.
1391 If you are building under msys2 try installing the mingw-w64-x86_64-python2 \
1392 package instead of python2:
1394 $ pacman -S mingw-w64-x86_64-python2
1399 if [ -n "$CFG_PERF" ]
1401 HAVE_PERF_LOGFD=`$CFG_PERF stat --log-fd 2>&1 | grep 'unknown option'`
1402 if [ -z "$HAVE_PERF_LOGFD" ];
1404 CFG_PERF_WITH_LOGFD=1
1405 putvar CFG_PERF_WITH_LOGFD
1409 if [ -n "$CFG_DISABLE_RUSTBUILD" ]; then
1411 step_msg "making directories"
1414 doc doc/std doc/extra \
1427 make_dir $t/rustllvm
1430 for t in $CFG_TARGET
1435 make_dir $t/rt/stage$s
1436 make_dir $t/rt/jemalloc
1437 make_dir $t/rt/compiler-rt
1440 arch/i386 arch/x86_64 arch/arm arch/aarch64 arch/mips arch/powerpc
1442 make_dir $t/rt/stage$s/$i
1449 for t in $CFG_TARGET
1451 # host bin dir stage0
1452 make_dir $h/stage0/bin
1454 # host lib dir stage0
1455 make_dir $h/stage0/lib
1457 # host test dir stage0
1458 make_dir $h/stage0/test
1460 # target bin dir stage0
1461 make_dir $h/stage0/lib/rustlib/$t/bin
1463 # target lib dir stage0
1464 make_dir $h/stage0/lib/rustlib/$t/lib
1469 make_dir $h/stage$i/bin
1472 make_dir $h/stage$i/$CFG_LIBDIR_RELATIVE
1475 make_dir $h/stage$i/test
1478 make_dir $h/stage$i/$CFG_LIBDIR_RELATIVE/rustlib/$t/bin
1481 make_dir $h/stage$i/$CFG_LIBDIR_RELATIVE/rustlib/$t/lib
1485 make_dir $h/test/run-pass
1486 make_dir $h/test/run-pass-valgrind
1487 make_dir $h/test/run-pass-fulldeps
1488 make_dir $h/test/run-fail
1489 make_dir $h/test/run-fail-fulldeps
1490 make_dir $h/test/compile-fail
1491 make_dir $h/test/parse-fail
1492 make_dir $h/test/compile-fail-fulldeps
1493 make_dir $h/test/bench
1494 make_dir $h/test/perf
1495 make_dir $h/test/pretty
1496 make_dir $h/test/debuginfo-gdb
1497 make_dir $h/test/debuginfo-lldb
1498 make_dir $h/test/codegen
1499 make_dir $h/test/codegen-units
1500 make_dir $h/test/rustdoc
1505 # Configure submodules
1506 step_msg "configuring submodules"
1508 # Have to be in the top of src directory for this
1509 if [ -z "$CFG_DISABLE_MANAGE_SUBMODULES" ] && [ -n "$CFG_DISABLE_RUSTBUILD" ]
1513 msg "git: submodule sync"
1514 "${CFG_GIT}" submodule sync
1516 msg "git: submodule init"
1517 "${CFG_GIT}" submodule init
1519 # Disable submodules that we're not using
1520 if [ -n "${CFG_LLVM_ROOT}" ]; then
1521 msg "git: submodule deinit src/llvm"
1522 "${CFG_GIT}" submodule deinit src/llvm
1524 if [ -n "${CFG_JEMALLOC_ROOT}" ]; then
1525 msg "git: submodule deinit src/jemalloc"
1526 "${CFG_GIT}" submodule deinit src/jemalloc
1529 msg "git: submodule update"
1530 "${CFG_GIT}" submodule update
1531 need_ok "git failed"
1533 msg "git: submodule foreach sync"
1534 "${CFG_GIT}" submodule foreach --recursive 'if test -e .gitmodules; then git submodule sync; fi'
1535 need_ok "git failed"
1537 msg "git: submodule foreach update"
1538 "${CFG_GIT}" submodule update --recursive
1539 need_ok "git failed"
1541 # NB: this is just for the sake of getting the submodule SHA1 values
1542 # and status written into the build log.
1543 msg "git: submodule status"
1544 "${CFG_GIT}" submodule status --recursive
1546 msg "git: submodule clobber"
1547 "${CFG_GIT}" submodule foreach --recursive git clean -dxf
1548 need_ok "git failed"
1549 "${CFG_GIT}" submodule foreach --recursive git checkout .
1550 need_ok "git failed"
1555 # Do a sanity check that the submodule source exists. Because GitHub
1556 # automatically publishes broken tarballs that can't be disabled, and
1557 # people download them and try to use them.
1558 if [ ! -e "${CFG_SRC_DIR}/src/liblibc" ]; then
1559 err "some submodules are missing. Is this a broken tarball?
1561 If you downloaded this tarball from the GitHub release pages at
1562 https://github.com/rust-lang/rust/releases,
1563 then please delete it and instead download the source from
1564 https://www.rust-lang.org/downloads.html"
1568 # Configure llvm, only if necessary
1569 step_msg "looking at LLVM"
1570 CFG_LLVM_SRC_DIR=${CFG_SRC_DIR}src/llvm/
1581 if [ -z "$CFG_DISABLE_RUSTBUILD" ]
1583 msg "not configuring LLVM, rustbuild in use"
1585 elif [ -z "$CFG_LLVM_ROOT" ]
1587 LLVM_BUILD_DIR=${CFG_BUILD_DIR}$t/llvm
1588 LLVM_INST_DIR=$LLVM_BUILD_DIR
1589 # For some weird reason the MSVC output dir is different than Unix
1590 if [ ${is_msvc} -ne 0 ]; then
1591 if [ -n "$CFG_DISABLE_OPTIMIZE_LLVM" ]
1593 # Just use LLVM straight from its build directory to
1594 # avoid 'make install' time
1595 LLVM_INST_DIR=$LLVM_BUILD_DIR/Debug
1597 LLVM_INST_DIR=$LLVM_BUILD_DIR/Release
1601 msg "not reconfiguring LLVM, external LLVM root"
1602 # The user is using their own LLVM
1604 LLVM_INST_DIR=$CFG_LLVM_ROOT
1606 # Check that LLVm FileCheck is available. Needed for the tests
1607 if [ -z "$CFG_DISABLE_CODEGEN_TESTS" ]; then
1608 need_cmd $LLVM_INST_DIR/bin/FileCheck
1612 if [ ${do_reconfigure} -ne 0 ]
1614 # because git is hilarious, it might have put the module index
1615 # in a couple places.
1616 index1="${CFG_SRC_DIR}.git/modules/src/llvm/index"
1617 index2="${CFG_SRC_DIR}src/llvm/.git/index"
1618 for index in ${index1} ${index2}
1620 config_status="${LLVM_BUILD_DIR}/config.status"
1621 if test -e ${index} -a \
1622 -e ${config_status} -a \
1623 ${config_status} -nt ${index}
1625 msg "not reconfiguring LLVM, config.status is fresh"
1631 # We need the generator later on for compiler-rt even if LLVM's not built
1632 if [ -n "$CFG_NINJA" ]
1635 elif [ ${is_msvc} -ne 0 ]
1637 case "$CFG_MSVC_ROOT" in
1639 generator="Visual Studio 14 2015"
1642 generator="Visual Studio 12 2013"
1645 err "can't determine generator for LLVM cmake"
1650 generator="$generator Win64"
1655 err "can only build LLVM for x86 platforms"
1659 generator="Unix Makefiles"
1661 CFG_CMAKE_GENERATOR=$generator
1662 putvar CFG_CMAKE_GENERATOR
1664 msg "configuring LLVM for $t"
1675 LLVM_CXX_32="ccache"
1677 LLVM_CXX_32_ARG1="clang++"
1678 LLVM_CC_32_ARG1="clang"
1679 LLVM_CFLAGS_32="-Qunused-arguments"
1680 LLVM_CXXFLAGS_32="-Qunused-arguments"
1682 LLVM_CXX_64="ccache"
1684 LLVM_CXX_64_ARG1="clang++"
1685 LLVM_CC_64_ARG1="clang"
1686 LLVM_CFLAGS_64="-Qunused-arguments"
1687 LLVM_CXXFLAGS_64="-Qunused-arguments"
1690 LLVM_CXX_32="clang++"
1692 LLVM_CFLAGS_32="-Qunused-arguments"
1693 LLVM_CXXFLAGS_32="-Qunused-arguments"
1695 LLVM_CXX_64="clang++"
1697 LLVM_CFLAGS_64="-Qunused-arguments"
1698 LLVM_CXXFLAGS_64="-Qunused-arguments"
1701 LLVM_CXX_32="ccache"
1703 LLVM_CXX_32_ARG1="g++"
1704 LLVM_CC_32_ARG1="gcc"
1706 LLVM_CXX_64="ccache"
1708 LLVM_CXX_64_ARG1="g++"
1709 LLVM_CC_64_ARG1="gcc"
1712 if [ -z "$CFG_ENABLE_SCCACHE" ]; then
1719 LLVM_CXX_32="sccache"
1720 LLVM_CC_32="sccache"
1721 LLVM_CXX_32_ARG1="g++"
1722 LLVM_CC_32_ARG1="gcc"
1724 LLVM_CXX_64="sccache"
1725 LLVM_CC_64="sccache"
1726 LLVM_CXX_64_ARG1="g++"
1727 LLVM_CC_64_ARG1="gcc"
1732 msg "inferring LLVM_CXX/CC from CXX/CC = $CXX/$CC"
1733 if [ -n "$CFG_ENABLE_CCACHE" ]
1735 if [ -z "$CFG_CCACHE" ]
1737 err "ccache requested but not found"
1740 LLVM_CXX_32="ccache"
1742 LLVM_CXX_32_ARG1="$CXX"
1743 LLVM_CC_32_ARG1="$CC"
1745 LLVM_CXX_64="ccache"
1747 LLVM_CXX_64_ARG1="$CXX"
1748 LLVM_CC_64_ARG1="$CC"
1760 case "$CFG_CPUTYPE" in
1762 LLVM_CFLAGS_32="$LLVM_CFLAGS_32 -m32"
1763 LLVM_CXXFLAGS_32="$LLVM_CXXFLAGS_32 -m32"
1764 LLVM_LDFLAGS_32="$LLVM_LDFLAGS_32 -m32"
1768 if echo $t | grep -q x86_64
1770 LLVM_CXX=$LLVM_CXX_64
1772 LLVM_CXX_ARG1=$LLVM_CXX_64_ARG1
1773 LLVM_CC_ARG1=$LLVM_CC_64_ARG1
1774 LLVM_CFLAGS=$LLVM_CFLAGS_64
1775 LLVM_CXXFLAGS=$LLVM_CXXFLAGS_64
1776 LLVM_LDFLAGS=$LLVM_LDFLAGS_64
1778 LLVM_CXX=$LLVM_CXX_32
1780 LLVM_CXX_ARG1=$LLVM_CXX_32_ARG1
1781 LLVM_CC_ARG1=$LLVM_CC_32_ARG1
1782 LLVM_CFLAGS=$LLVM_CFLAGS_32
1783 LLVM_CXXFLAGS=$LLVM_CXXFLAGS_32
1784 LLVM_LDFLAGS=$LLVM_LDFLAGS_32
1787 if [ "$CFG_USING_LIBCPP" != "0" ]; then
1788 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_ENABLE_LIBCXX=ON"
1791 # Turn off things we don't need
1792 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_INCLUDE_TESTS=OFF"
1793 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_INCLUDE_EXAMPLES=OFF"
1794 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_INCLUDE_DOCS=OFF"
1795 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_ENABLE_ZLIB=OFF"
1796 CMAKE_ARGS="$CMAKE_ARGS -DWITH_POLY=OFF"
1797 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_ENABLE_TERMINFO=OFF"
1798 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_ENABLE_LIBEDIT=OFF"
1800 arch="$(echo "$t" | cut -d - -f 1)"
1802 if [ "$arch" = i686 ]; then
1803 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_BUILD_32_BITS=ON"
1806 if [ "$t" != "$CFG_BUILD" ]; then
1807 # see http://llvm.org/docs/HowToCrossCompileLLVM.html
1808 CMAKE_ARGS="$CMAKE_ARGS -DCMAKE_CROSSCOMPILING=True"
1809 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_TARGET_ARCH=$arch"
1810 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_TABLEGEN=$CFG_BUILD_DIR/$CFG_BUILD/llvm/bin/llvm-tblgen"
1811 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_DEFAULT_TARGET_TRIPLE=$t"
1814 # MSVC handles compiler business itself
1815 if [ ${is_msvc} -eq 0 ]; then
1816 CMAKE_ARGS="$CMAKE_ARGS -DCMAKE_C_COMPILER=$LLVM_CC"
1817 CMAKE_ARGS="$CMAKE_ARGS -DCMAKE_CXX_COMPILER=$LLVM_CXX"
1818 CMAKE_ARGS="$CMAKE_ARGS '-DCMAKE_C_FLAGS=$LLVM_CFLAGS'"
1819 CMAKE_ARGS="$CMAKE_ARGS '-DCMAKE_CXX_FLAGS=$LLVM_CXXFLAGS'"
1820 if [ -n "$LLVM_CC_ARG1" ]; then
1821 CMAKE_ARGS="$CMAKE_ARGS -DCMAKE_C_COMPILER_ARG1=$LLVM_CC_ARG1"
1823 if [ -n "$LLVM_CXX_ARG1" ]; then
1824 CMAKE_ARGS="$CMAKE_ARGS -DCMAKE_CXX_COMPILER_ARG1=$LLVM_CXX_ARG1"
1826 # FIXME: What about LDFLAGS?
1829 if [ -n "$CFG_DISABLE_OPTIMIZE_LLVM" ]; then
1830 CMAKE_ARGS="$CMAKE_ARGS -DCMAKE_BUILD_TYPE=Debug"
1831 elif [ -n "$CFG_ENABLE_LLVM_RELEASE_DEBUGINFO" ]; then
1832 CMAKE_ARGS="$CMAKE_ARGS -DCMAKE_BUILD_TYPE=RelWithDebInfo"
1834 CMAKE_ARGS="$CMAKE_ARGS -DCMAKE_BUILD_TYPE=Release"
1836 if [ -z "$CFG_ENABLE_LLVM_ASSERTIONS" ]
1838 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_ENABLE_ASSERTIONS=OFF"
1840 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_ENABLE_ASSERTIONS=ON"
1843 CMAKE_ARGS="$CMAKE_ARGS -DLLVM_TARGETS_TO_BUILD='X86;ARM;AArch64;Mips;PowerPC;SystemZ;JSBackend;MSP430;Sparc'"
1844 CMAKE_ARGS="$CMAKE_ARGS -G '$CFG_CMAKE_GENERATOR'"
1845 CMAKE_ARGS="$CMAKE_ARGS $CFG_LLVM_SRC_DIR"
1847 if [ ${do_reconfigure} -ne 0 ]
1849 msg "configuring LLVM for $t with cmake"
1851 msg "configuring LLVM with:"
1854 (cd $LLVM_BUILD_DIR && eval "\"$CFG_CMAKE\"" $CMAKE_ARGS)
1855 need_ok "LLVM cmake configure failed"
1858 # Construct variables for LLVM build and install directories for
1859 # each target. These will be named
1860 # CFG_LLVM_BUILD_DIR_${target_triple} but all the hyphens in
1861 # target_triple will be converted to underscore, because bash
1862 # variables can't contain hyphens. The makefile will then have to
1864 CFG_LLVM_BUILD_DIR=$(echo CFG_LLVM_BUILD_DIR_${t} | tr - _)
1865 CFG_LLVM_INST_DIR=$(echo CFG_LLVM_INST_DIR_${t} | tr - _)
1866 eval ${CFG_LLVM_BUILD_DIR}="'$LLVM_BUILD_DIR'"
1867 eval ${CFG_LLVM_INST_DIR}="'$LLVM_INST_DIR'"
1871 step_msg "writing configuration"
1874 putvar CFG_SRC_DIR_RELATIVE
1875 putvar CFG_BUILD_DIR
1878 putvar CFG_CONFIGURE_ARGS
1882 putvar CFG_LIBDIR_RELATIVE
1883 putvar CFG_DISABLE_MANAGE_SUBMODULES
1884 putvar CFG_AARCH64_LINUX_ANDROID_NDK
1885 putvar CFG_ARM_LINUX_ANDROIDEABI_NDK
1886 putvar CFG_ARMV7_LINUX_ANDROIDEABI_NDK
1887 putvar CFG_I686_LINUX_ANDROID_NDK
1888 putvar CFG_NACL_CROSS_PATH
1891 putvar CFG_USING_LIBCPP
1893 # Avoid spurious warnings from clang by feeding it original source on
1894 # ccache-miss rather than preprocessed input.
1895 if [ -n "$CFG_ENABLE_CCACHE" ] && [ -n "$CFG_USING_CLANG" ]
1898 putvar CFG_CCACHE_CPP2
1901 if [ -n "$CFG_ENABLE_CCACHE" ]
1903 CFG_CCACHE_BASEDIR=${CFG_SRC_DIR}
1904 putvar CFG_CCACHE_BASEDIR
1908 putvar CFG_LLVM_SRC_DIR
1912 CFG_LLVM_BUILD_DIR=$(echo CFG_LLVM_BUILD_DIR_${t} | tr - _)
1913 CFG_LLVM_INST_DIR=$(echo CFG_LLVM_INST_DIR_${t} | tr - _)
1914 putvar $CFG_LLVM_BUILD_DIR
1915 putvar $CFG_LLVM_INST_DIR
1918 if [ -z "$CFG_DISABLE_RUSTBUILD" ]
1920 INPUT_MAKEFILE=src/bootstrap/mk/Makefile.in
1922 INPUT_MAKEFILE=Makefile.in
1926 copy_if_changed ${CFG_SRC_DIR}${INPUT_MAKEFILE} ./Makefile
1927 move_if_changed config.tmp config.mk
1931 if [ -z "$CFG_ENABLE_DEBUG" ]; then
1932 step_msg "configured in release mode. for development consider --enable-debug"
1937 if [ "$CFG_SRC_DIR" = `pwd` ]; then
1940 X_PY=${CFG_SRC_DIR_RELATIVE}x.py
1943 if [ -z "$CFG_DISABLE_RUSTBUILD" ]; then
1944 msg "NOTE you have now configured rust to use a rewritten build system"
1945 msg " called rustbuild, and as a result this may have bugs that "
1946 msg " you did not see before. If you experience any issues you can"
1947 msg " go back to the old build system with --disable-rustbuild and"
1948 msg " please feel free to report any bugs!"
1950 msg "run \`python ${X_PY} --help\`"
1952 warn "the makefile-based build system is deprecated in favor of rustbuild"
1954 msg "It is recommended you avoid passing --disable-rustbuild to get your"
1955 msg "build working as the makefiles will be deleted on 2017-02-02. If you"
1956 msg "encounter bugs with rustbuild please file issues against rust-lang/rust"
1958 msg "run \`make help\`"