scripts/crosstool-NG.sh.in
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sun Jul 17 17:56:22 2011 +0200 (2011-07-17)
changeset 2889 f3b2199620f1
parent 2801 21f4f28e60ec
child 2924 0eab838768b1
permissions -rw-r--r--
cc/gcc: pass the install prefix to the core passes

Currently, the discrimination on the core compilers prefixes depends on
the type of core compiler to build.

This is not correct, and the caller of the core backend should specify
the prefix.

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
yann@1156
     1
#!@@CT_bash@@
yann@1
     2
# Copyright 2007 Yann E. MORIN
yann@1
     3
# Licensed under the GPL v2. See COPYING in the root of this package.
yann@1
     4
yann@1
     5
# This is the main entry point to crosstool
yann@1
     6
# This will:
yann@1
     7
#   - download, extract and patch the toolchain components
yann@1
     8
#   - build and install each components in turn
yann@1
     9
#   - and eventually test the resulting toolchain
yann@1
    10
yann@1
    11
# What this file does is prepare the environment, based upon the user-choosen
yann@1
    12
# options. It also checks the existing environment for un-friendly variables,
yann@96
    13
# and builds the tools.
yann@1
    14
yann@1
    15
# Parse the common functions
yann@501
    16
# Note: some initialisation and sanitizing is done while parsing this file,
yann@501
    17
# most notably:
yann@501
    18
#  - set trap handler on errors,
yann@501
    19
#  - don't hash commands lookups,
yann@501
    20
#  - initialise logging.
yann@182
    21
. "${CT_LIB_DIR}/scripts/functions"
yann@1
    22
yann@1
    23
# Parse the configuration file
yann@96
    24
# It has some info about the logging facility, so include it early
yann@2468
    25
. .config.2
yann@1156
    26
# Yes! We can do full logging from now on!
yann@1
    27
antony@2564
    28
# Override the locale early, in case we ever translate crosstool-NG messages
yann@2171
    29
if [ -z "${CT_NO_OVERIDE_LC_MESSAGES}" ]; then
yann@2171
    30
    export LC_ALL=C
yann@2171
    31
    export LANG=C
yann@2171
    32
fi
yann@1064
    33
js@2044
    34
# remove . from PATH since it can cause gcc build failures
js@2044
    35
CT_SanitizePath
js@2044
    36
yann@1416
    37
# Some sanity checks in the environment and needed tools
yann@1416
    38
CT_DoLog INFO "Performing some trivial sanity checks"
yann@1416
    39
CT_TestAndAbort "Don't set LD_LIBRARY_PATH. It screws up the build." -n "${LD_LIBRARY_PATH}"
yann@1416
    40
CT_TestAndAbort "Don't set CFLAGS. It screws up the build." -n "${CFLAGS}"
yann@1416
    41
CT_TestAndAbort "Don't set CXXFLAGS. It screws up the build." -n "${CXXFLAGS}"
yann@1416
    42
CT_Test "GREP_OPTIONS screws up the build. Resetting." -n "${GREP_OPTIONS}"
yann@1416
    43
export GREP_OPTIONS=
yann@2801
    44
# Workaround against openSUSE 12.1 that breaks ./configure for cross-compilation:
yann@2801
    45
export CONFIG_SITE=
yann@1416
    46
yann@1416
    47
# Some sanity checks on paths content
yann@1416
    48
for d in            \
yann@1416
    49
    LOCAL_TARBALLS  \
yann@1416
    50
    WORK            \
yann@1416
    51
    PREFIX          \
yann@1416
    52
    INSTALL         \
yann@1416
    53
    ; do
yann@1416
    54
        eval dir="\${CT_${d}_DIR}"
yann@1416
    55
        case "${dir}" in
yann@1416
    56
            *" "*)
yann@1416
    57
                CT_Abort "'CT_${d}_DIR'='${dir}' contains a space in it.\nDon't use spaces in paths, it breaks things."
yann@1416
    58
                ;;
yann@1416
    59
        esac
yann@1416
    60
done
yann@1416
    61
yann@1156
    62
# Where will we work?
yann@1156
    63
CT_WORK_DIR="${CT_WORK_DIR:-${CT_TOP_DIR}/targets}"
yann@1270
    64
CT_DoExecLog ALL mkdir -p "${CT_WORK_DIR}"
yann@1270
    65
yann@1270
    66
# Check build file system case-sensitiveness
yann@1278
    67
CT_DoExecLog DEBUG touch "${CT_WORK_DIR}/foo"
yann@1270
    68
CT_TestAndAbort "Your file system in '${CT_WORK_DIR}' is *not* case-sensitive!" -f "${CT_WORK_DIR}/FOO"
yann@1278
    69
CT_DoExecLog DEBUG rm -f "${CT_WORK_DIR}/foo"
yann@1156
    70
yann@1444
    71
# Check the user is using an existing SHELL to be used by ./configure and Makefiles
yann@2705
    72
CT_TestOrAbort "The CONFIG_SHELL '${CT_CONFIG_SHELL}' is not valid" -f "${CT_CONFIG_SHELL}" -a -x "${CT_CONFIG_SHELL}"
yann@1421
    73
antony@2564
    74
# Create the bin-override early
yann@1219
    75
# Contains symlinks to the tools found by ./configure
yann@1156
    76
# Note: CT_DoLog and CT_DoExecLog do not use any of those tool, so
yann@1156
    77
# they can be safely used
richard@1726
    78
CT_TOOLS_OVERIDE_DIR="${CT_WORK_DIR}/tools"
antony@2564
    79
CT_DoLog DEBUG "Creating bin-override for tools in '${CT_TOOLS_OVERIDE_DIR}'"
richard@1726
    80
CT_DoExecLog DEBUG mkdir -p "${CT_TOOLS_OVERIDE_DIR}/bin"
yann@2838
    81
cat "${CT_LIB_DIR}/paths.sh" |while read trash line; do
yann@1156
    82
    tool="${line%%=*}"
yann@1156
    83
    path="${line#*=}"
yann@1517
    84
    CT_DoLog DEBUG "Creating script-override for '${tool}' -> '${path}'"
yann@2838
    85
    # Note: we need to supress the " in the path because
yann@2838
    86
    # there can be arguments in there (thanks autostuff...)
yann@2838
    87
    printf "#${BANG}${CT_CONFIG_SHELL}\nexec ${path//\"/} \"\${@}\"\n" >"${CT_TOOLS_OVERIDE_DIR}/bin/${tool}"
richard@1726
    88
    CT_DoExecLog ALL chmod 700 "${CT_TOOLS_OVERIDE_DIR}/bin/${tool}"
yann@1156
    89
done
richard@1726
    90
export PATH="${CT_TOOLS_OVERIDE_DIR}/bin:${PATH}"
yann@1156
    91
yann@1064
    92
# Start date. Can't be done until we know the locale
yann@1416
    93
# Also requires the bin-override tools
yann@1064
    94
CT_STAR_DATE=$(CT_DoDate +%s%N)
yann@1064
    95
CT_STAR_DATE_HUMAN=$(CT_DoDate +%Y%m%d.%H%M%S)
yann@1064
    96
yann@1156
    97
# Log real begining of build, now
yann@379
    98
CT_DoLog INFO "Build started ${CT_STAR_DATE_HUMAN}"
yann@379
    99
yann@2468
   100
# We really need to extract from ,config and not .config.2, as we
yann@2468
   101
# do want the kconfig's values, not our mangled config with arrays.
yann@894
   102
CT_DoStep DEBUG "Dumping user-supplied crosstool-NG configuration"
yann@1247
   103
CT_DoExecLog DEBUG grep -E '^(# |)CT_' .config
yann@96
   104
CT_EndStep
yann@63
   105
yann@290
   106
CT_DoLog DEBUG "Unsetting and unexporting MAKEFLAGS"
yann@290
   107
unset MAKEFLAGS
yann@290
   108
export MAKEFLAGS
yann@290
   109
yann@1
   110
CT_DoLog INFO "Building environment variables"
yann@1
   111
yann@965
   112
# Include sub-scripts instead of calling them: that way, we do not have to
yann@965
   113
# export any variable, nor re-parse the configuration and functions files.
yann@1225
   114
. "${CT_LIB_DIR}/scripts/build/internals.sh"
yann@903
   115
. "${CT_LIB_DIR}/scripts/build/arch/${CT_ARCH}.sh"
richard@1727
   116
. "${CT_LIB_DIR}/scripts/build/companion_tools.sh"
yann@965
   117
. "${CT_LIB_DIR}/scripts/build/kernel/${CT_KERNEL}.sh"
yann@1318
   118
. "${CT_LIB_DIR}/scripts/build/companion_libs/gmp.sh"
yann@1318
   119
. "${CT_LIB_DIR}/scripts/build/companion_libs/mpfr.sh"
yann@1324
   120
. "${CT_LIB_DIR}/scripts/build/companion_libs/ppl.sh"
yann@1380
   121
. "${CT_LIB_DIR}/scripts/build/companion_libs/cloog.sh"
yann@1384
   122
. "${CT_LIB_DIR}/scripts/build/companion_libs/mpc.sh"
yann@1811
   123
. "${CT_LIB_DIR}/scripts/build/companion_libs/libelf.sh"
yann@1345
   124
. "${CT_LIB_DIR}/scripts/build/binutils/binutils.sh"
yann@1345
   125
. "${CT_LIB_DIR}/scripts/build/binutils/elf2flt.sh"
yann@1854
   126
. "${CT_LIB_DIR}/scripts/build/binutils/sstrip.sh"
yann@965
   127
. "${CT_LIB_DIR}/scripts/build/libc/${CT_LIBC}.sh"
yann@965
   128
. "${CT_LIB_DIR}/scripts/build/cc/${CT_CC}.sh"
yann@965
   129
. "${CT_LIB_DIR}/scripts/build/debug.sh"
mgl@1965
   130
. "${CT_LIB_DIR}/scripts/build/test_suite.sh"
yann@380
   131
yann@335
   132
# Target tuple: CT_TARGET needs a little love:
yann@335
   133
CT_DoBuildTargetTuple
yann@1
   134
yann@96
   135
# Kludge: If any of the configured options needs CT_TARGET,
yann@96
   136
# then rescan the options file now:
yann@2468
   137
. .config.2
yann@96
   138
yann@1663
   139
# Sanity check some directories
yann@1663
   140
CT_TestAndAbort "'CT_PREFIX_DIR' is not set: where should I install?" -z "${CT_PREFIX_DIR}"
yann@1663
   141
yann@397
   142
# Second kludge: merge user-supplied target CFLAGS with architecture-provided
yann@531
   143
# target CFLAGS. Do the same for LDFLAGS in case it happens in the future.
yann@531
   144
# Put user-supplied flags at the end, so that they take precedence.
yann@397
   145
CT_TARGET_CFLAGS="${CT_ARCH_TARGET_CFLAGS} ${CT_TARGET_CFLAGS}"
yann@531
   146
CT_TARGET_LDFLAGS="${CT_ARCH_TARGET_LDFLAGS} ${CT_TARGET_LDFLAGS}"
yann@2467
   147
CT_CC_CORE_EXTRA_CONFIG_ARRAY=( ${CT_ARCH_CC_CORE_EXTRA_CONFIG} "${CT_CC_CORE_EXTRA_CONFIG_ARRAY[@]}" )
yann@2467
   148
CT_CC_EXTRA_CONFIG_ARRAY=( ${CT_ARCH_CC_EXTRA_CONFIG} "${CT_CC_EXTRA_CONFIG_ARRAY[@]}" )
yann@397
   149
benoit@2503
   150
# Compute the package version string
benoit@2503
   151
CT_PKGVERSION="crosstool-NG ${CT_VERSION}${CT_TOOLCHAIN_PKGVERSION:+ - ${CT_TOOLCHAIN_PKGVERSION}}"
benoit@2503
   152
yann@1416
   153
# Compute the working directories names
yann@610
   154
CT_TARBALLS_DIR="${CT_WORK_DIR}/tarballs"
yann@610
   155
CT_SRC_DIR="${CT_WORK_DIR}/src"
yann@610
   156
CT_BUILD_DIR="${CT_WORK_DIR}/${CT_TARGET}/build"
yann@2308
   157
CT_BUILDTOOLS_PREFIX_DIR="${CT_WORK_DIR}/${CT_TARGET}/buildtools"
yann@1272
   158
CT_STATE_DIR="${CT_WORK_DIR}/${CT_TARGET}/state"
yann@1272
   159
CT_CONFIG_DIR="${CT_BUILD_DIR}/configs"
yann@2381
   160
CT_COMPLIBS_DIR="${CT_BUILD_DIR}/static"
yann@1272
   161
mgl@1965
   162
# Compute test suite install directory
mgl@1965
   163
CT_TEST_SUITE_DIR=${CT_INSTALL_DIR}/test-suite
mgl@1965
   164
yann@121
   165
# Note: we'll always install the core compiler in its own directory, so as to
yann@331
   166
# not mix the two builds: core and final.
yann@136
   167
CT_CC_CORE_STATIC_PREFIX_DIR="${CT_BUILD_DIR}/${CT_CC}-core-static"
yann@136
   168
CT_CC_CORE_SHARED_PREFIX_DIR="${CT_BUILD_DIR}/${CT_CC}-core-shared"
yann@85
   169
yann@143
   170
# We must ensure that we can restart if asked for!
yann@143
   171
if [ -n "${CT_RESTART}" -a ! -d "${CT_STATE_DIR}"  ]; then
yann@143
   172
    CT_DoLog ERROR "You asked to restart a non-restartable build"
yann@143
   173
    CT_DoLog ERROR "This happened because you didn't set CT_DEBUG_CT_SAVE_STEPS"
yann@153
   174
    CT_DoLog ERROR "in the config options for the previous build, or the state"
yann@425
   175
    CT_DoLog ERROR "directory for the previous build was deleted."
yann@143
   176
    CT_Abort "I will stop here to avoid any carnage"
yann@143
   177
fi
yann@143
   178
yann@403
   179
# If the local tarball directory does not exist, say so, and don't try to save there!
yann@1662
   180
if [    "${CT_SAVE_TARBALLS}" = "y"     \
yann@1662
   181
     -a ! -d "${CT_LOCAL_TARBALLS_DIR}" ]; then
yann@1662
   182
    CT_DoLog WARN "Directory '${CT_LOCAL_TARBALLS_DIR}' does not exist."
yann@1662
   183
    CT_DoLog WARN "Will not save downloaded tarballs to local storage."
yann@523
   184
    CT_SAVE_TARBALLS=
yann@403
   185
fi
yann@403
   186
yann@85
   187
# Check now if we can write to the destination directory:
yann@85
   188
if [ -d "${CT_INSTALL_DIR}" ]; then
yann@523
   189
    CT_TestAndAbort "Destination directory '${CT_INSTALL_DIR}' is not removable" ! -w $(dirname "${CT_INSTALL_DIR}")
yann@85
   190
fi
yann@85
   191
yann@96
   192
# Good, now grab a bit of informations on the system we're being run on,
yann@96
   193
# just in case something goes awok, and it's not our fault:
yann@523
   194
CT_SYS_USER=$(id -un)
yann@523
   195
CT_SYS_HOSTNAME=$(hostname -f 2>/dev/null || true)
yann@96
   196
# Hmmm. Some non-DHCP-enabled machines do not have an FQDN... Fall back to node name.
yann@523
   197
CT_SYS_HOSTNAME="${CT_SYS_HOSTNAME:-$(uname -n)}"
yann@523
   198
CT_SYS_KERNEL=$(uname -s)
yann@523
   199
CT_SYS_REVISION=$(uname -r)
titus@1954
   200
CT_SYS_OS=$(uname -s)
yann@523
   201
CT_SYS_MACHINE=$(uname -m)
yann@523
   202
CT_SYS_PROCESSOR=$(uname -p)
yann@523
   203
CT_SYS_GCC=$(gcc -dumpversion)
yann@523
   204
CT_SYS_TARGET=$(CT_DoConfigGuess)
yann@96
   205
CT_TOOLCHAIN_ID="crosstool-${CT_VERSION} build ${CT_STAR_DATE_HUMAN} by ${CT_SYS_USER}@${CT_SYS_HOSTNAME}"
yann@96
   206
yann@96
   207
CT_DoLog EXTRA "Preparing working directories"
yann@96
   208
yann@121
   209
# Ah! The build directory shall be eradicated, even if we restart!
yann@2543
   210
# Ditto for the build tools install dir
yann@2543
   211
CT_DoForceRmdir "${CT_BUILD_DIR}" "${CT_BUILDTOOLS_PREFIX_DIR}"
yann@121
   212
yann@121
   213
# Don't eradicate directories if we need to restart
yann@121
   214
if [ -z "${CT_RESTART}" ]; then
yann@121
   215
    # Get rid of pre-existing installed toolchain and previous build directories.
yann@121
   216
    if [ "${CT_FORCE_DOWNLOAD}" = "y" -a -d "${CT_TARBALLS_DIR}" ]; then
yann@1138
   217
        CT_DoForceRmdir "${CT_TARBALLS_DIR}"
yann@121
   218
    fi
yann@121
   219
    if [ "${CT_FORCE_EXTRACT}" = "y" -a -d "${CT_SRC_DIR}" ]; then
yann@1138
   220
        CT_DoForceRmdir "${CT_SRC_DIR}"
yann@121
   221
    fi
yann@2284
   222
    if [ -d "${CT_INSTALL_DIR}" -a "${CT_RM_RF_PREFIX_DIR}" = "y" ]; then
yann@1138
   223
        CT_DoForceRmdir "${CT_INSTALL_DIR}"
yann@121
   224
    fi
yann@121
   225
    # In case we start anew, get rid of the previously saved state directory
yann@121
   226
    if [ -d "${CT_STATE_DIR}" ]; then
yann@1138
   227
        CT_DoForceRmdir "${CT_STATE_DIR}"
yann@121
   228
    fi
yann@96
   229
fi
yann@85
   230
yann@121
   231
# Create the directories we'll use, even if restarting: it does no harm to
yann@121
   232
# create already existent directories, and CT_BUILD_DIR needs to be created
yann@121
   233
# anyway
yann@1135
   234
CT_DoExecLog ALL mkdir -p "${CT_TARBALLS_DIR}"
yann@1135
   235
CT_DoExecLog ALL mkdir -p "${CT_SRC_DIR}"
yann@1135
   236
CT_DoExecLog ALL mkdir -p "${CT_BUILD_DIR}"
yann@2308
   237
CT_DoExecLog ALL mkdir -p "${CT_BUILDTOOLS_PREFIX_DIR}/bin"
yann@1272
   238
CT_DoExecLog ALL mkdir -p "${CT_CONFIG_DIR}"
yann@1135
   239
CT_DoExecLog ALL mkdir -p "${CT_INSTALL_DIR}"
yann@1135
   240
CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}"
yann@1894
   241
CT_DoExecLog ALL mkdir -p "${CT_COMPLIBS_DIR}"
yann@1425
   242
if [ -z "${CT_CANADIAN}" ]; then
yann@1425
   243
    CT_DoExecLog ALL mkdir -p "${CT_CC_CORE_STATIC_PREFIX_DIR}"
yann@1425
   244
    CT_DoExecLog ALL mkdir -p "${CT_CC_CORE_SHARED_PREFIX_DIR}"
yann@1425
   245
fi
yann@1272
   246
yann@1272
   247
# Only create the state dir if asked for a restartable build
yann@1272
   248
[ -n "${CT_DEBUG_CT_SAVE_STEPS}" ] && CT_DoExecLog ALL mkdir -p "${CT_STATE_DIR}"
yann@121
   249
yann@1270
   250
# Check install file system case-sensitiveness
yann@1278
   251
CT_DoExecLog DEBUG touch "${CT_PREFIX_DIR}/foo"
yann@1270
   252
CT_TestAndAbort "Your file system in '${CT_PREFIX_DIR}' is *not* case-sensitive!" -f "${CT_PREFIX_DIR}/FOO"
yann@1278
   253
CT_DoExecLog DEBUG rm -f "${CT_PREFIX_DIR}/foo"
yann@1270
   254
yann@121
   255
# Kludge: CT_INSTALL_DIR and CT_PREFIX_DIR might have grown read-only if
yann@2339
   256
# the previous build was successful.
yann@1135
   257
CT_DoExecLog ALL chmod -R u+w "${CT_INSTALL_DIR}" "${CT_PREFIX_DIR}"
yann@85
   258
yann@397
   259
# Setting up the rest of the environment only if not restarting
yann@121
   260
if [ -z "${CT_RESTART}" ]; then
yann@2279
   261
    case "${CT_SYSROOT_NAME}" in
yann@2279
   262
        "")     CT_SYSROOT_NAME="sysroot";;
yann@2279
   263
        .)      CT_Abort "Sysroot name is set to '.' which is forbidden";;
yann@2279
   264
        *' '*)  CT_Abort "Sysroot name contains forbidden space(s): '${CT_SYSROOT_NAME}'";;
yann@2279
   265
        */*)    CT_Abort "Sysroot name contains forbidden slash(es): '${CT_SYSROOT_NAME}'";;
yann@2279
   266
    esac
yann@2279
   267
yann@2279
   268
    # Arrange paths depending on wether we use sysroot or not.
yann@121
   269
    if [ "${CT_USE_SYSROOT}" = "y" ]; then
yann@2653
   270
        CT_SYSROOT_REL_DIR="${CT_SYSROOT_DIR_PREFIX:+${CT_SYSROOT_DIR_PREFIX}/}${CT_SYSROOT_NAME}"
yann@2286
   271
        CT_SYSROOT_DIR="${CT_PREFIX_DIR}/${CT_TARGET}/${CT_SYSROOT_REL_DIR}"
yann@1219
   272
        CT_DEBUGROOT_DIR="${CT_PREFIX_DIR}/${CT_TARGET}/${CT_SYSROOT_DIR_PREFIX}/debug-root"
yann@121
   273
        CT_HEADERS_DIR="${CT_SYSROOT_DIR}/usr/include"
yann@2286
   274
        CT_SanitiseVarDir CT_SYSROOT_REL_DIR CT_SYSROOT_DIR CT_DEBUGROOT_DIR CT_HEADERS_DIR 
yann@121
   275
        BINUTILS_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   276
        CC_CORE_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   277
        CC_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   278
        LIBC_SYSROOT_ARG=""
yann@121
   279
        # glibc's prefix must be exactly /usr, else --with-sysroot'd gcc will get
yann@121
   280
        # confused when $sysroot/usr/include is not present.
yann@121
   281
        # Note: --prefix=/usr is magic!
yann@121
   282
        # See http://www.gnu.org/software/libc/FAQ.html#s-2.2
yann@121
   283
    else
yann@121
   284
        # plain old way. All libraries in prefix/target/lib
yann@121
   285
        CT_SYSROOT_DIR="${CT_PREFIX_DIR}/${CT_TARGET}"
yann@1419
   286
        CT_DEBUGROOT_DIR="${CT_SYSROOT_DIR}"
yann@121
   287
        CT_HEADERS_DIR="${CT_SYSROOT_DIR}/include"
yann@2280
   288
        CT_SanitiseVarDir CT_SYSROOT_DIR CT_DEBUGROOT_DIR CT_HEADERS_DIR 
yann@121
   289
        # hack!  Always use --with-sysroot for binutils.
yann@121
   290
        # binutils 2.14 and later obey it, older binutils ignore it.
yann@121
   291
        # Lets you build a working 32->64 bit cross gcc
yann@121
   292
        BINUTILS_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   293
        # Use --with-headers, else final gcc will define disable_glibc while
yann@121
   294
        # building libgcc, and you'll have no profiling
yann@121
   295
        CC_CORE_SYSROOT_ARG="--without-headers"
yann@121
   296
        CC_SYSROOT_ARG="--with-headers=${CT_HEADERS_DIR}"
yann@121
   297
        LIBC_SYSROOT_ARG="prefix="
yann@121
   298
    fi
yann@1219
   299
    CT_DoExecLog ALL mkdir -p "${CT_SYSROOT_DIR}"
yann@1219
   300
    CT_DoExecLog ALL mkdir -p "${CT_DEBUGROOT_DIR}"
yann@121
   301
yann@121
   302
    # Prepare the 'lib' directories in sysroot, else the ../lib64 hack used by
yann@1180
   303
    # 32 -> 64 bit crosscompilers won't work, and build of final gcc will fail
yann@1180
   304
    # with: "ld: cannot open crti.o: No such file or directory"
yann@1180
   305
    # Also prepare the lib directory in the install dir, else some 64 bit archs
yann@1180
   306
    # won't build
yann@1180
   307
    CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}/lib"
yann@1135
   308
    CT_DoExecLog ALL mkdir -p "${CT_SYSROOT_DIR}/lib"
yann@1135
   309
    CT_DoExecLog ALL mkdir -p "${CT_SYSROOT_DIR}/usr/lib"
zhenqiang@2796
   310
    CT_DoExecLog ALL mkdir -p "${CT_HEADERS_DIR}"
yann@121
   311
yann@1420
   312
    if [ "${CT_USE_SYSROOT}" = "y" ]; then
yann@2279
   313
        # Prevent gcc from installing its libraries outside of the sysroot
yann@2653
   314
        CT_Pushd "${CT_PREFIX_DIR}/${CT_TARGET}"
yann@2653
   315
        CT_DoExecLog ALL ln -sf "${CT_SYSROOT_REL_DIR}/lib" "lib"
yann@2653
   316
        CT_Popd
yann@1420
   317
    fi
yann@740
   318
anthony@2138
   319
    # Since we're *not* multilib on the target side, we want all the
anthony@2138
   320
    # libraries to end up in "lib".  We create "lib64" (for 64-bit
anthony@2138
   321
    # build or host architectures) and "lib32" (for 32-bit emulation
anthony@2138
   322
    # on 64-bit) as symlinks to "lib".
anthony@2138
   323
    #
anthony@2138
   324
    # Not all of these symlinks are necessary, but better safe than
anthony@2138
   325
    # sorry. They are summarily removed by build/internals.sh:do_finish.
anthony@2138
   326
    for d in                            \
anthony@2138
   327
        "${CT_PREFIX_DIR}"              \
anthony@2138
   328
        "${CT_SYSROOT_DIR}"             \
anthony@2138
   329
        "${CT_SYSROOT_DIR}/usr"         \
anthony@2138
   330
        "${CT_PREFIX_DIR}/${CT_TARGET}" \
anthony@2138
   331
    ; do
anthony@2138
   332
        CT_DoExecLog ALL ln -sf "lib" "${d}/lib32"
anthony@2138
   333
        CT_DoExecLog ALL ln -sf "lib" "${d}/lib64"
anthony@2138
   334
    done
yann@740
   335
yann@1041
   336
    # Determine build system if not set by the user
titus@1958
   337
    if [ -z "${CT_BUILD}" ]; then
titus@1958
   338
        CT_BUILD=$(CT_DoConfigGuess)
titus@1958
   339
    fi
yann@121
   340
yann@1083
   341
    # Prepare mangling patterns to later modify BUILD and HOST (see below)
yann@1041
   342
    case "${CT_TOOLCHAIN_TYPE}" in
yann@1041
   343
        cross)
yann@1426
   344
            # A cross-compiler runs on the same machine it is built on
yann@1041
   345
            CT_HOST="${CT_BUILD}"
yann@1041
   346
            build_mangle="build_"
yann@1041
   347
            host_mangle="build_"
yann@1426
   348
            target_mangle=""
yann@1425
   349
            install_build_tools_for="BUILD HOST"
yann@1041
   350
            ;;
yann@1426
   351
        canadian)
yann@1426
   352
            build_mangle="build_"
yann@1426
   353
            host_mangle="host_"
yann@1426
   354
            target_mangle=""
yann@1426
   355
            install_build_tools_for="BUILD HOST TARGET"
yann@1426
   356
            ;;
yann@1041
   357
        *)  CT_Abort "No code for '${CT_TOOLCHAIN_TYPE}' toolchain type!"
yann@1041
   358
            ;;
yann@1041
   359
    esac
yann@1033
   360
yann@1041
   361
    # Save the real tuples to generate shell-wrappers to the real tools
yann@1041
   362
    CT_REAL_BUILD="${CT_BUILD}"
yann@1041
   363
    CT_REAL_HOST="${CT_HOST}"
yann@1426
   364
    CT_REAL_TARGET="${CT_TARGET}"
yann@1041
   365
yann@1082
   366
    # Canonicalise CT_BUILD and CT_HOST
yann@1082
   367
    # Not only will it give us full-qualified tuples, but it will also ensure
yann@1082
   368
    # that they are valid tuples (in case of typo with user-provided tuples)
yann@1082
   369
    # That's way better than trying to rewrite config.sub ourselves...
yann@1426
   370
    # CT_TARGET is already made canonical in CT_DoBuildTargetTuple
yann@1089
   371
    CT_BUILD=$(CT_DoConfigSub "${CT_BUILD}")
yann@1089
   372
    CT_HOST=$(CT_DoConfigSub "${CT_HOST}")
yann@1041
   373
yann@1041
   374
    # Modify BUILD and HOST so that gcc always generate a cross-compiler
yann@1041
   375
    # even if any of the build, host or target machines are the same.
yann@1041
   376
    # NOTE: we'll have to mangle the (BUILD|HOST)->TARGET x-compiler to
yann@1041
   377
    #       support canadain build, later...
yann@1041
   378
    CT_BUILD="${CT_BUILD/-/-${build_mangle}}"
yann@1041
   379
    CT_HOST="${CT_HOST/-/-${host_mangle}}"
yann@1426
   380
    CT_TARGET="${CT_TARGET/-/-${target_mangle}}"
yann@1041
   381
yann@1041
   382
    # Now we have mangled our BUILD and HOST tuples, we must fake the new
yann@1041
   383
    # cross-tools for those mangled tuples.
yann@174
   384
    CT_DoLog DEBUG "Making build system tools available"
yann@1425
   385
    for m in ${install_build_tools_for}; do
yann@1041
   386
        r="CT_REAL_${m}"
yann@1041
   387
        v="CT_${m}"
yann@1041
   388
        p="CT_${m}_PREFIX"
yann@1041
   389
        s="CT_${m}_SUFFIX"
yann@1041
   390
        if [ -n "${!p}" ]; then
yann@1041
   391
            t="${!p}"
yann@1041
   392
        else
yann@1041
   393
            t="${!r}-"
yann@1041
   394
        fi
yann@1041
   395
yann@1129
   396
        for tool in ar as dlltool gcc g++ gcj gnatbind gnatmake ld nm objcopy objdump ranlib strip windres; do
yann@1041
   397
            # First try with prefix + suffix
yann@1041
   398
            # Then try with prefix only
yann@1041
   399
            # Then try with suffix only, but only for BUILD, and HOST iff REAL_BUILD == REAL_HOST
yann@1041
   400
            # Finally try with neither prefix nor suffix, but only for BUILD, and HOST iff REAL_BUILD == REAL_HOST
yann@1041
   401
            # This is needed, because some tools have a prefix and
yann@1041
   402
            # a suffix (eg. gcc), while others may have only one,
yann@1041
   403
            # or even none (eg. binutils)
yann@1041
   404
            where=$(CT_Which "${t}${tool}${!s}")
yann@1041
   405
            [ -z "${where}" ] && where=$(CT_Which "${t}${tool}")
yann@1041
   406
            if [    -z "${where}"                         \
yann@1041
   407
                 -a \(    "${m}" = "BUILD"                \
yann@1041
   408
                       -o "${CT_REAL_BUILD}" = "${!r}" \) ]; then
yann@1041
   409
                where=$(CT_Which "${tool}${!s}")
yann@1041
   410
            fi
yann@1041
   411
            if [ -z "${where}"                            \
yann@1041
   412
                 -a \(    "${m}" = "BUILD"                \
yann@1041
   413
                       -o "${CT_REAL_BUILD}" = "${!r}" \) ]; then
yann@1041
   414
                where=$(CT_Which "${tool}")
yann@1041
   415
            fi
yann@1041
   416
yann@1041
   417
            # Not all tools are available for all platforms, but some are really,
yann@1041
   418
            # bally needed
yann@1041
   419
            if [ -n "${where}" ]; then
yann@1041
   420
                CT_DoLog DEBUG "  '${!v}-${tool}' -> '${where}'"
titus@2795
   421
                printf "#${BANG}${CT_CONFIG_SHELL}\nexec '${where}' \"\${@}\"\n" >"${CT_BUILDTOOLS_PREFIX_DIR}/bin/${!v}-${tool}"
yann@2308
   422
                CT_DoExecLog ALL chmod 700 "${CT_BUILDTOOLS_PREFIX_DIR}/bin/${!v}-${tool}"
yann@1041
   423
            else
yann@1041
   424
                case "${tool}" in
yann@1176
   425
                    # We'll at least need some of them...
linux@1927
   426
                    ar|as|gcc|ld|nm|objcopy|objdump|ranlib)
yann@1041
   427
                        CT_Abort "Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : either needed!"
yann@1041
   428
                        ;;
yann@1176
   429
                    # Some are conditionnally required
yann@1176
   430
                    # Add them in alphabetical (C locale) ordering
linux@1927
   431
                    g++)
linux@1927
   432
                        # g++ (needed for companion lib), only needed for HOST
linux@1927
   433
                        CT_TestAndAbort "Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : either needed!" "${m}" = "HOST"
linux@1927
   434
                        ;;
yann@1176
   435
                    gcj)
yann@1176
   436
                        CT_TestAndAbort "Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : either needed!" "${CT_CC_LANG_JAVA}" = "y"
yann@1176
   437
                        ;;
linux@2060
   438
                    strip)
linux@2060
   439
                        CT_TestAndAbort "Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : either needed!" "${CT_STRIP_ALL_TOOLCHAIN_EXECUTABLES}" = "y"
linux@2060
   440
                        ;;
yann@1176
   441
                    # If any other is missing, only warn at low level
yann@1041
   442
                    *)
yann@1041
   443
                        # It does not deserve a WARN level.
yann@1041
   444
                        CT_DoLog DEBUG "  Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : not required."
yann@1041
   445
                        ;;
yann@1041
   446
                esac
yann@1041
   447
            fi
yann@1041
   448
        done
yann@121
   449
    done
yann@121
   450
yann@2305
   451
    # Some makeinfo versions are a pain in [put your most sensible body part here].
yann@2305
   452
    # Go ahead with those, by creating a wrapper that keeps partial files, and that
yann@2305
   453
    # never fails:
yann@2305
   454
    CT_DoLog DEBUG "  'makeinfo' -> '$(CT_Which makeinfo)'"
titus@2795
   455
    printf "#${BANG}${CT_CONFIG_SHELL}\n$(CT_Which makeinfo) --force \"\${@}\"\ntrue\n" >"${CT_BUILDTOOLS_PREFIX_DIR}/bin/makeinfo"
yann@2308
   456
    CT_DoExecLog ALL chmod 700 "${CT_BUILDTOOLS_PREFIX_DIR}/bin/makeinfo"
yann@2305
   457
yann@1041
   458
    # Carefully add paths in the order we want them:
yann@1041
   459
    #  - first try in ${CT_PREFIX_DIR}/bin
yann@1041
   460
    #  - then try in ${CT_CC_CORE_SHARED_PREFIX_DIR}/bin
yann@1041
   461
    #  - then try in ${CT_CC_CORE_STATIC_PREFIX_DIR}/bin
yann@1041
   462
    #  - fall back to searching user's PATH
yann@1041
   463
    # Of course, neither cross-native nor canadian can run on BUILD,
yann@1041
   464
    # so don't add those PATHs in this case...
yann@1041
   465
    case "${CT_TOOLCHAIN_TYPE}" in
yann@2308
   466
        cross)  export PATH="${CT_BUILDTOOLS_PREFIX_DIR}/bin:${CT_PREFIX_DIR}/bin:${CT_CC_CORE_SHARED_PREFIX_DIR}/bin:${CT_CC_CORE_STATIC_PREFIX_DIR}/bin:${PATH}";;
yann@2308
   467
        canadian) export PATH="${CT_BUILDTOOLS_PREFIX_DIR}/bin:${PATH}";;
yann@1041
   468
        *)  ;;
yann@1041
   469
    esac
yann@1041
   470
yann@2717
   471
    # Now we know our host and where to find the host tools, we can check
yann@2717
   472
    # if static link was requested, but only if it was requested
yann@2717
   473
    if [ "${CT_WANTS_STATIC_LINK}" = "y" ]; then
yann@2717
   474
        tmp="${CT_BUILD_DIR}/.static-test"
yann@2717
   475
        if ! "${CT_HOST}-gcc" -xc - -static -o "${tmp}" >/dev/null 2>&1 <<-_EOF_
yann@2717
   476
				int main() { return 0; }
yann@2717
   477
			_EOF_
yann@2717
   478
        then
yann@2717
   479
            CT_Abort "Static linking impossible on the host system '${CT_HOST}'"
yann@2717
   480
        fi
yann@2717
   481
        rm -f "${tmp}"
yann@2717
   482
    fi
yann@2717
   483
yann@121
   484
    # Help gcc
yann@121
   485
    CT_CFLAGS_FOR_HOST=
michael@2701
   486
    [ "${CT_USE_PIPES}" = "y" ] && CT_CFLAGS_FOR_HOST+=" -pipe"
michael@2727
   487
    CT_CFLAGS_FOR_HOST+=" ${CT_EXTRA_FLAGS_FOR_HOST}"
yann@121
   488
yann@1033
   489
    # Set the shell to be used by ./configure scripts and by Makefiles (those
yann@1033
   490
    # that support it!).
yann@2705
   491
    export CONFIG_SHELL="${CT_CONFIG_SHELL}"    # for ./configure
yann@2705
   492
    export SHELL="${CT_CONFIG_SHELL}"           # for Makefiles
yann@805
   493
yann@121
   494
    # And help make go faster
yann@2275
   495
    JOBSFLAGS=
yann@2716
   496
    # Override the configured jobs with what's been given on the command line
yann@2716
   497
    [ -n "${CT_JOBS}" ] && CT_PARALLEL_JOBS="${CT_JOBS}"
michael@2695
   498
    # Use the number of processors+1 when automatically setting the number of
michael@2695
   499
    # parallel jobs.  Fall back to 1 if the host doesn't use GLIBC.
michael@2695
   500
    AUTO_JOBS=$((`getconf _NPROCESSORS_ONLN 2> /dev/null || echo 0` + 1))
yann@2716
   501
    [ ${CT_PARALLEL_JOBS} -eq 0 ] && JOBSFLAGS="${JOBSFLAGS} -j${AUTO_JOBS}"
michael@2695
   502
    [ ${CT_PARALLEL_JOBS} -gt 0 ] && JOBSFLAGS="${JOBSFLAGS} -j${CT_PARALLEL_JOBS}"
yann@2275
   503
    [ ${CT_LOAD} -ne 0 ] && JOBSFLAGS="${JOBSFLAGS} -l${CT_LOAD}"
yann@121
   504
yann@2468
   505
    # We need to save the real .config with kconfig's value,
yann@2468
   506
    # not our mangled .config.2 with arrays.
yann@894
   507
    CT_DoLog EXTRA "Installing user-supplied crosstool-NG configuration"
yann@1423
   508
    CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}/bin"
yann@1098
   509
    CT_DoExecLog DEBUG install -m 0755 "${CT_LIB_DIR}/scripts/toolchain-config.in" "${CT_PREFIX_DIR}/bin/${CT_TARGET}-ct-ng.config"
tvb377@1814
   510
    CT_DoExecLog DEBUG sed -i -e 's,@@grep@@,"'"${grep}"'",;' "${CT_PREFIX_DIR}/bin/${CT_TARGET}-ct-ng.config"
yann@909
   511
    bzip2 -c -9 .config >>"${CT_PREFIX_DIR}/bin/${CT_TARGET}-ct-ng.config"
yann@894
   512
yann@121
   513
    CT_DoStep EXTRA "Dumping internal crosstool-NG configuration"
yann@121
   514
    CT_DoLog EXTRA "Building a toolchain for:"
yann@1041
   515
    CT_DoLog EXTRA "  build  = ${CT_REAL_BUILD}"
yann@1041
   516
    CT_DoLog EXTRA "  host   = ${CT_REAL_HOST}"
yann@121
   517
    CT_DoLog EXTRA "  target = ${CT_TARGET}"
yann@1247
   518
    set |grep -E '^CT_.+=' |sort |CT_DoLog DEBUG
yann@1806
   519
    CT_DoLog DEBUG "Other environment:"
yann@1806
   520
    printenv |grep -v -E '^CT_.+=' |CT_DoLog DEBUG
yann@121
   521
    CT_EndStep
yann@63
   522
fi
yann@63
   523
yann@121
   524
if [ -z "${CT_RESTART}" ]; then
yann@2595
   525
    CT_DoStep INFO "Retrieving needed toolchain components' tarballs"
yann@2595
   526
    do_companion_tools_get
yann@2595
   527
    do_kernel_get
yann@2595
   528
    do_gmp_get
yann@2595
   529
    do_mpfr_get
yann@2595
   530
    do_ppl_get
yann@2595
   531
    do_cloog_get
yann@2595
   532
    do_mpc_get
yann@2595
   533
    do_libelf_get
yann@2595
   534
    do_binutils_get
yann@2595
   535
    do_elf2flt_get
yann@2595
   536
    do_sstrip_get
yann@2595
   537
    do_cc_get
yann@2595
   538
    do_libc_get
yann@2595
   539
    do_debug_get
yann@2595
   540
    do_test_suite_get
yann@2595
   541
    CT_EndStep
yann@63
   542
yann@121
   543
    if [ "${CT_ONLY_DOWNLOAD}" != "y" ]; then
yann@121
   544
        if [ "${CT_FORCE_EXTRACT}" = "y" ]; then
yann@1138
   545
            CT_DoForceRmdir "${CT_SRC_DIR}"
yann@1135
   546
            CT_DoExecLog ALL mkdir -p "${CT_SRC_DIR}"
yann@121
   547
        fi
richard@1727
   548
richard@1727
   549
        if [ "${CT_COMP_TOOLS}" = "y" ]; then
richard@1727
   550
          CT_DoStep INFO "Extracting, patching and installing companion tools"
richard@1727
   551
          do_companion_tools_extract
richard@1727
   552
          do_companion_tools
richard@1727
   553
          CT_EndStep
richard@1727
   554
        fi
richard@1727
   555
yann@121
   556
        CT_DoStep INFO "Extracting and patching toolchain components"
yann@121
   557
        do_kernel_extract
yann@466
   558
        do_gmp_extract
yann@466
   559
        do_mpfr_extract
yann@1324
   560
        do_ppl_extract
yann@1380
   561
        do_cloog_extract
yann@1384
   562
        do_mpc_extract
yann@1811
   563
        do_libelf_extract
yann@121
   564
        do_binutils_extract
yann@1755
   565
        do_elf2flt_extract
yann@1854
   566
        do_sstrip_extract
yann@331
   567
        do_cc_extract
yann@121
   568
        do_libc_extract
yann@121
   569
        do_debug_extract
mgl@1965
   570
        do_test_suite_extract
yann@121
   571
        CT_EndStep
yann@121
   572
    fi
yann@121
   573
fi
yann@85
   574
yann@121
   575
# Now for the job by itself. Go have a coffee!
yann@121
   576
if [ "${CT_ONLY_DOWNLOAD}" != "y" -a "${CT_ONLY_EXTRACT}" != "y" ]; then
yann@121
   577
    # Because of CT_RESTART, this becomes quite complex
yann@143
   578
    do_stop=0
yann@143
   579
    prev_step=
yann@121
   580
    [ -n "${CT_RESTART}" ] && do_it=0 || do_it=1
yann@466
   581
    # Aha! CT_STEPS comes from steps.mk!
yann@461
   582
    for step in ${CT_STEPS}; do
yann@121
   583
        if [ ${do_it} -eq 0 ]; then
yann@121
   584
            if [ "${CT_RESTART}" = "${step}" ]; then
yann@121
   585
                CT_DoLoadState "${step}"
yann@121
   586
                do_it=1
yann@143
   587
                do_stop=0
yann@121
   588
            fi
yann@121
   589
        else
yann@121
   590
            CT_DoSaveState ${step}
yann@143
   591
            if [ ${do_stop} -eq 1 ]; then
yann@523
   592
                CT_DoLog ERROR "Stopping just after step '${prev_step}', as requested."
yann@143
   593
                exit 0
yann@143
   594
            fi
yann@85
   595
        fi
yann@121
   596
        if [ ${do_it} -eq 1 ]; then
yann@2707
   597
            ( do_${step} )
yann@135
   598
            if [ "${CT_STOP}" = "${step}" ]; then
yann@143
   599
                do_stop=1
yann@135
   600
            fi
yann@725
   601
            if [ "${CT_DEBUG_PAUSE_STEPS}" = "y" ]; then
yann@523
   602
                CT_DoPause "Step '${step}' finished"
yann@121
   603
            fi
yann@121
   604
        fi
yann@143
   605
        prev_step="${step}"
yann@121
   606
    done
yann@63
   607
fi
yann@1
   608
yann@96
   609
CT_DoEnd INFO
yann@96
   610
yann@1135
   611
# From now-on, it can become impossible to log any time, because
yann@1135
   612
# either we're compressing the log file, or it can become RO any
yann@1135
   613
# moment... Consign all ouptut to oblivion...
yann@1135
   614
CT_DoLog INFO "Finishing installation (may take a few seconds)..."
yann@1135
   615
exec >/dev/null 2>&1
yann@2550
   616
rm -f ${CT_PREFIX_DIR}/build.log.bz2
yann@2339
   617
if [ "${CT_LOG_TO_FILE}" = "y" ]; then
yann@2339
   618
    cp "${tmp_log_file}" "${CT_PREFIX_DIR}/build.log"
yann@2339
   619
    if [ "${CT_LOG_FILE_COMPRESS}" = y ]; then
yann@2339
   620
        bzip2 -9 "${CT_PREFIX_DIR}/build.log"
yann@2339
   621
    fi
yann@2339
   622
fi
yann@1135
   623
[ "${CT_INSTALL_DIR_RO}" = "y"  ] && chmod -R a-w "${CT_INSTALL_DIR}"
yann@1966
   624
[ "${CT_TEST_SUITE}" = "y" ] && chmod -R u+w "${CT_TEST_SUITE_DIR}"
yann@1
   625
yann@1
   626
trap - EXIT