scripts/crosstool-NG.sh
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Tue Jan 20 20:37:43 2009 +0000 (2009-01-20)
changeset 1149 df32ef8825f9
parent 1143 eee9e8de51e3
permissions -rwxr-xr-x
On 20090115.0012+0100, "Andy Johnson" <ajohnson@aecno.com> wrote:
... I added a step after
"debug" called "finish", and moved the code in crosstool.sh
after the loop that processes the steps from crosstool.sh
into a do_finish function in functions. Thus, it is now
possible to restart after the "debug" step to re-do the
final few things (clean and compress).

/trunk/scripts/crosstool-NG.sh | 38 0 38 0 --------------------------------------
/trunk/scripts/functions | 42 42 0 0 ++++++++++++++++++++++++++++++++++++++++++
/trunk/steps.mk | 3 2 1 0 ++-
3 files changed, 44 insertions(+), 39 deletions(-)
yann@1
     1
#!/bin/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@965
    25
. .config
yann@1
    26
yann@1064
    27
# Overide the locale early, in case we ever translate crosstool-NG messages
yann@1064
    28
[ -z "${CT_NO_OVERIDE_LC_MESSAGES}" ] && export LC_ALL=C
yann@1064
    29
yann@1064
    30
# Start date. Can't be done until we know the locale
yann@1064
    31
CT_STAR_DATE=$(CT_DoDate +%s%N)
yann@1064
    32
CT_STAR_DATE_HUMAN=$(CT_DoDate +%Y%m%d.%H%M%S)
yann@1064
    33
yann@379
    34
# Yes! We can do full logging from now on!
yann@379
    35
CT_DoLog INFO "Build started ${CT_STAR_DATE_HUMAN}"
yann@379
    36
yann@96
    37
# renice oursleves
yann@762
    38
CT_DoExecLog DEBUG renice ${CT_NICE} $$
yann@1
    39
yann@894
    40
CT_DoStep DEBUG "Dumping user-supplied crosstool-NG configuration"
yann@965
    41
CT_DoExecLog DEBUG egrep '^(# |)CT_' .config
yann@96
    42
CT_EndStep
yann@63
    43
yann@1
    44
# Some sanity checks in the environment and needed tools
yann@1
    45
CT_DoLog INFO "Checking environment sanity"
yann@1
    46
yann@290
    47
CT_DoLog DEBUG "Unsetting and unexporting MAKEFLAGS"
yann@290
    48
unset MAKEFLAGS
yann@290
    49
export MAKEFLAGS
yann@290
    50
yann@1
    51
# Other environment sanity checks
yann@1
    52
CT_TestAndAbort "Don't set LD_LIBRARY_PATH. It screws up the build." -n "${LD_LIBRARY_PATH}"
yann@1
    53
CT_TestAndAbort "Don't set CFLAGS. It screws up the build." -n "${CFLAGS}"
yann@1
    54
CT_TestAndAbort "Don't set CXXFLAGS. It screws up the build." -n "${CXXFLAGS}"
yann@1
    55
CT_Test "GREP_OPTIONS screws up the build. Resetting." -n "${GREP_OPTIONS}"
yann@965
    56
export GREP_OPTIONS=
yann@1
    57
yann@1
    58
CT_DoLog INFO "Building environment variables"
yann@1
    59
yann@965
    60
# Include sub-scripts instead of calling them: that way, we do not have to
yann@965
    61
# export any variable, nor re-parse the configuration and functions files.
yann@903
    62
. "${CT_LIB_DIR}/scripts/build/arch/${CT_ARCH}.sh"
yann@965
    63
. "${CT_LIB_DIR}/scripts/build/kernel/${CT_KERNEL}.sh"
yann@965
    64
. "${CT_LIB_DIR}/scripts/build/gmp.sh"
yann@965
    65
. "${CT_LIB_DIR}/scripts/build/mpfr.sh"
yann@965
    66
. "${CT_LIB_DIR}/scripts/build/binutils.sh"
yann@965
    67
. "${CT_LIB_DIR}/scripts/build/libc/${CT_LIBC}.sh"
yann@965
    68
. "${CT_LIB_DIR}/scripts/build/cc/${CT_CC}.sh"
yann@965
    69
. "${CT_LIB_DIR}/scripts/build/tools.sh"
yann@965
    70
. "${CT_LIB_DIR}/scripts/build/debug.sh"
yann@380
    71
yann@335
    72
# Target tuple: CT_TARGET needs a little love:
yann@335
    73
CT_DoBuildTargetTuple
yann@1
    74
yann@96
    75
# Kludge: If any of the configured options needs CT_TARGET,
yann@96
    76
# then rescan the options file now:
yann@1093
    77
. .config
yann@96
    78
yann@397
    79
# Second kludge: merge user-supplied target CFLAGS with architecture-provided
yann@531
    80
# target CFLAGS. Do the same for LDFLAGS in case it happens in the future.
yann@531
    81
# Put user-supplied flags at the end, so that they take precedence.
yann@397
    82
CT_TARGET_CFLAGS="${CT_ARCH_TARGET_CFLAGS} ${CT_TARGET_CFLAGS}"
yann@531
    83
CT_TARGET_LDFLAGS="${CT_ARCH_TARGET_LDFLAGS} ${CT_TARGET_LDFLAGS}"
yann@767
    84
CT_CC_CORE_EXTRA_CONFIG="${CT_ARCH_CC_CORE_EXTRA_CONFIG} ${CT_CC_CORE_EXTRA_CONFIG}"
yann@767
    85
CT_CC_EXTRA_CONFIG="${CT_ARCH_CC_EXTRA_CONFIG} ${CT_CC_EXTRA_CONFIG}"
yann@397
    86
yann@85
    87
# Where will we work?
yann@610
    88
: "${CT_WORK_DIR:=${CT_TOP_DIR}/targets}"
yann@610
    89
CT_TARBALLS_DIR="${CT_WORK_DIR}/tarballs"
yann@610
    90
CT_SRC_DIR="${CT_WORK_DIR}/src"
yann@610
    91
CT_BUILD_DIR="${CT_WORK_DIR}/${CT_TARGET}/build"
yann@96
    92
CT_DEBUG_INSTALL_DIR="${CT_INSTALL_DIR}/${CT_TARGET}/debug-root"
yann@121
    93
# Note: we'll always install the core compiler in its own directory, so as to
yann@331
    94
# not mix the two builds: core and final.
yann@136
    95
CT_CC_CORE_STATIC_PREFIX_DIR="${CT_BUILD_DIR}/${CT_CC}-core-static"
yann@136
    96
CT_CC_CORE_SHARED_PREFIX_DIR="${CT_BUILD_DIR}/${CT_CC}-core-shared"
yann@610
    97
CT_STATE_DIR="${CT_WORK_DIR}/${CT_TARGET}/state"
yann@85
    98
yann@143
    99
# We must ensure that we can restart if asked for!
yann@143
   100
if [ -n "${CT_RESTART}" -a ! -d "${CT_STATE_DIR}"  ]; then
yann@143
   101
    CT_DoLog ERROR "You asked to restart a non-restartable build"
yann@143
   102
    CT_DoLog ERROR "This happened because you didn't set CT_DEBUG_CT_SAVE_STEPS"
yann@153
   103
    CT_DoLog ERROR "in the config options for the previous build, or the state"
yann@425
   104
    CT_DoLog ERROR "directory for the previous build was deleted."
yann@143
   105
    CT_Abort "I will stop here to avoid any carnage"
yann@143
   106
fi
yann@143
   107
yann@403
   108
# If the local tarball directory does not exist, say so, and don't try to save there!
yann@403
   109
if [ ! -d "${CT_LOCAL_TARBALLS_DIR}" ]; then
yann@523
   110
    CT_DoLog WARN "Directory '${CT_LOCAL_TARBALLS_DIR}' does not exist. Will not save downloaded tarballs to local storage."
yann@523
   111
    CT_SAVE_TARBALLS=
yann@403
   112
fi
yann@403
   113
yann@1
   114
# Some more sanity checks now that we have all paths set up
yann@403
   115
case "${CT_LOCAL_TARBALLS_DIR},${CT_TARBALLS_DIR},${CT_SRC_DIR},${CT_BUILD_DIR},${CT_PREFIX_DIR},${CT_INSTALL_DIR}" in
yann@1
   116
    *" "*) CT_Abort "Don't use spaces in paths, it breaks things.";;
yann@1
   117
esac
yann@1
   118
yann@85
   119
# Check now if we can write to the destination directory:
yann@85
   120
if [ -d "${CT_INSTALL_DIR}" ]; then
yann@523
   121
    CT_TestAndAbort "Destination directory '${CT_INSTALL_DIR}' is not removable" ! -w $(dirname "${CT_INSTALL_DIR}")
yann@85
   122
fi
yann@85
   123
yann@96
   124
# Good, now grab a bit of informations on the system we're being run on,
yann@96
   125
# just in case something goes awok, and it's not our fault:
yann@523
   126
CT_SYS_USER=$(id -un)
yann@523
   127
CT_SYS_HOSTNAME=$(hostname -f 2>/dev/null || true)
yann@96
   128
# Hmmm. Some non-DHCP-enabled machines do not have an FQDN... Fall back to node name.
yann@523
   129
CT_SYS_HOSTNAME="${CT_SYS_HOSTNAME:-$(uname -n)}"
yann@523
   130
CT_SYS_KERNEL=$(uname -s)
yann@523
   131
CT_SYS_REVISION=$(uname -r)
yann@96
   132
# MacOS X lacks '-o' :
yann@523
   133
CT_SYS_OS=$(uname -o || echo "Unknown (maybe MacOS-X)")
yann@523
   134
CT_SYS_MACHINE=$(uname -m)
yann@523
   135
CT_SYS_PROCESSOR=$(uname -p)
yann@523
   136
CT_SYS_GCC=$(gcc -dumpversion)
yann@523
   137
CT_SYS_TARGET=$(CT_DoConfigGuess)
yann@96
   138
CT_TOOLCHAIN_ID="crosstool-${CT_VERSION} build ${CT_STAR_DATE_HUMAN} by ${CT_SYS_USER}@${CT_SYS_HOSTNAME}"
yann@96
   139
yann@96
   140
CT_DoLog EXTRA "Preparing working directories"
yann@96
   141
yann@121
   142
# Ah! The build directory shall be eradicated, even if we restart!
yann@85
   143
if [ -d "${CT_BUILD_DIR}" ]; then
yann@1138
   144
    CT_DoForceRmdir "${CT_BUILD_DIR}"
yann@85
   145
fi
yann@121
   146
yann@121
   147
# Don't eradicate directories if we need to restart
yann@121
   148
if [ -z "${CT_RESTART}" ]; then
yann@121
   149
    # Get rid of pre-existing installed toolchain and previous build directories.
yann@121
   150
    # We need to do that _before_ we can safely log, because the log file will
yann@121
   151
    # most probably be in the toolchain directory.
yann@121
   152
    if [ "${CT_FORCE_DOWNLOAD}" = "y" -a -d "${CT_TARBALLS_DIR}" ]; then
yann@1138
   153
        CT_DoForceRmdir "${CT_TARBALLS_DIR}"
yann@121
   154
    fi
yann@121
   155
    if [ "${CT_FORCE_EXTRACT}" = "y" -a -d "${CT_SRC_DIR}" ]; then
yann@1138
   156
        CT_DoForceRmdir "${CT_SRC_DIR}"
yann@121
   157
    fi
yann@121
   158
    if [ -d "${CT_INSTALL_DIR}" ]; then
yann@1138
   159
        CT_DoForceRmdir "${CT_INSTALL_DIR}"
yann@121
   160
    fi
yann@121
   161
    if [ -d "${CT_DEBUG_INSTALL_DIR}" ]; then
yann@1138
   162
        CT_DoForceRmdir "${CT_DEBUG_INSTALL_DIR}"
yann@121
   163
    fi
yann@121
   164
    # In case we start anew, get rid of the previously saved state directory
yann@121
   165
    if [ -d "${CT_STATE_DIR}" ]; then
yann@1138
   166
        CT_DoForceRmdir "${CT_STATE_DIR}"
yann@121
   167
    fi
yann@96
   168
fi
yann@85
   169
yann@121
   170
# Create the directories we'll use, even if restarting: it does no harm to
yann@121
   171
# create already existent directories, and CT_BUILD_DIR needs to be created
yann@121
   172
# anyway
yann@1135
   173
CT_DoExecLog ALL mkdir -p "${CT_TARBALLS_DIR}"
yann@1135
   174
CT_DoExecLog ALL mkdir -p "${CT_SRC_DIR}"
yann@1135
   175
CT_DoExecLog ALL mkdir -p "${CT_BUILD_DIR}"
yann@1135
   176
CT_DoExecLog ALL mkdir -p "${CT_INSTALL_DIR}"
yann@1135
   177
CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}"
yann@1135
   178
CT_DoExecLog ALL mkdir -p "${CT_DEBUG_INSTALL_DIR}"
yann@1135
   179
CT_DoExecLog ALL mkdir -p "${CT_CC_CORE_STATIC_PREFIX_DIR}"
yann@1135
   180
CT_DoExecLog ALL mkdir -p "${CT_CC_CORE_SHARED_PREFIX_DIR}"
yann@1135
   181
CT_DoExecLog ALL mkdir -p "${CT_STATE_DIR}"
yann@121
   182
yann@121
   183
# Kludge: CT_INSTALL_DIR and CT_PREFIX_DIR might have grown read-only if
yann@425
   184
# the previous build was successful. To be able to move the logfile there,
yann@121
   185
# switch them back to read/write
yann@1135
   186
CT_DoExecLog ALL chmod -R u+w "${CT_INSTALL_DIR}" "${CT_PREFIX_DIR}"
yann@85
   187
yann@63
   188
# Redirect log to the actual log file now we can
yann@63
   189
# It's quite understandable that the log file will be installed in the install
yann@63
   190
# directory, so we must first ensure it exists and is writeable (above) before
yann@63
   191
# we can log there
yann@112
   192
exec >/dev/null
yann@174
   193
case "${CT_LOG_TO_FILE}" in
yann@174
   194
    y)  CT_LOG_FILE="${CT_PREFIX_DIR}/build.log"
yann@174
   195
        cat "${tmp_log_file}" >>"${CT_LOG_FILE}"
yann@174
   196
        rm -f "${tmp_log_file}"
yann@174
   197
        exec >>"${CT_LOG_FILE}"
yann@174
   198
        ;;
yann@174
   199
    *)  rm -f "${tmp_log_file}"
yann@174
   200
        ;;
yann@63
   201
esac
yann@63
   202
yann@397
   203
# Setting up the rest of the environment only if not restarting
yann@121
   204
if [ -z "${CT_RESTART}" ]; then
yann@1041
   205
    # What's our shell?
yann@1041
   206
    # Will be plain /bin/sh on most systems, except if we have /bin/ash and we
yann@1041
   207
    # _explictly_ required using it
yann@1041
   208
    CT_SHELL="/bin/sh"
yann@1041
   209
    [ "${CT_CONFIG_SHELL_ASH}" = "y" -a -x "/bin/ash" ] && CT_SHELL="/bin/ash"
yann@63
   210
yann@121
   211
    # Arrange paths depending on wether we use sys-root or not.
yann@121
   212
    if [ "${CT_USE_SYSROOT}" = "y" ]; then
yann@121
   213
        CT_SYSROOT_DIR="${CT_PREFIX_DIR}/${CT_TARGET}/sys-root"
yann@121
   214
        CT_HEADERS_DIR="${CT_SYSROOT_DIR}/usr/include"
yann@121
   215
        BINUTILS_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   216
        CC_CORE_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   217
        CC_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   218
        LIBC_SYSROOT_ARG=""
yann@121
   219
        # glibc's prefix must be exactly /usr, else --with-sysroot'd gcc will get
yann@121
   220
        # confused when $sysroot/usr/include is not present.
yann@121
   221
        # Note: --prefix=/usr is magic!
yann@121
   222
        # See http://www.gnu.org/software/libc/FAQ.html#s-2.2
yann@121
   223
    else
yann@121
   224
        # plain old way. All libraries in prefix/target/lib
yann@121
   225
        CT_SYSROOT_DIR="${CT_PREFIX_DIR}/${CT_TARGET}"
yann@121
   226
        CT_HEADERS_DIR="${CT_SYSROOT_DIR}/include"
yann@121
   227
        # hack!  Always use --with-sysroot for binutils.
yann@121
   228
        # binutils 2.14 and later obey it, older binutils ignore it.
yann@121
   229
        # Lets you build a working 32->64 bit cross gcc
yann@121
   230
        BINUTILS_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   231
        # Use --with-headers, else final gcc will define disable_glibc while
yann@121
   232
        # building libgcc, and you'll have no profiling
yann@121
   233
        CC_CORE_SYSROOT_ARG="--without-headers"
yann@121
   234
        CC_SYSROOT_ARG="--with-headers=${CT_HEADERS_DIR}"
yann@121
   235
        LIBC_SYSROOT_ARG="prefix="
yann@121
   236
    fi
yann@121
   237
yann@121
   238
    # Prepare the 'lib' directories in sysroot, else the ../lib64 hack used by
yann@121
   239
    # 32 -> 64 bit crosscompilers won't work, and build of final gcc will fail with
yann@121
   240
    #  "ld: cannot open crti.o: No such file or directory"
yann@1135
   241
    CT_DoExecLog ALL mkdir -p "${CT_SYSROOT_DIR}/lib"
yann@1135
   242
    CT_DoExecLog ALL mkdir -p "${CT_SYSROOT_DIR}/usr/lib"
yann@121
   243
yann@740
   244
    # Prevent gcc from installing its libraries outside of the sys-root
yann@1135
   245
    CT_DoExecLog ALL ln -sf "sys-root/lib" "${CT_PREFIX_DIR}/${CT_TARGET}/lib"
yann@740
   246
yann@740
   247
    # Now, in case we're 64 bits, just have lib64/ be a symlink to lib/
yann@740
   248
    # so as to have all libraries in the same directory (we can do that
yann@740
   249
    # because we are *not* multilib).
yann@1038
   250
    if [ "${CT_ARCH_64}" = "y" ]; then
yann@1135
   251
        CT_DoExecLog ALL ln -sf "lib" "${CT_SYSROOT_DIR}/lib64"
yann@1135
   252
        CT_DoExecLog ALL ln -sf "lib" "${CT_SYSROOT_DIR}/usr/lib64"
yann@1135
   253
        CT_DoExecLog ALL ln -sf "sys-root/lib" "${CT_PREFIX_DIR}/${CT_TARGET}/lib64"
yann@1038
   254
    fi
yann@740
   255
yann@1041
   256
    # Determine build system if not set by the user
yann@1041
   257
    CT_Test "You did not specify the build system. That's OK, I can guess..." -z "${CT_BUILD}"
yann@1041
   258
    case "${CT_BUILD}" in
yann@1082
   259
        "") CT_BUILD=$("${CT_BUILD_PREFIX}gcc${CT_BUILD_SUFFIX}" -dumpmachine);;
yann@121
   260
    esac
yann@121
   261
yann@1083
   262
    # Prepare mangling patterns to later modify BUILD and HOST (see below)
yann@1041
   263
    case "${CT_TOOLCHAIN_TYPE}" in
yann@1041
   264
        cross)
yann@1041
   265
            CT_HOST="${CT_BUILD}"
yann@1041
   266
            build_mangle="build_"
yann@1041
   267
            host_mangle="build_"
yann@1041
   268
            ;;
yann@1041
   269
        *)  CT_Abort "No code for '${CT_TOOLCHAIN_TYPE}' toolchain type!"
yann@1041
   270
            ;;
yann@1041
   271
    esac
yann@1033
   272
yann@1041
   273
    # Save the real tuples to generate shell-wrappers to the real tools
yann@1041
   274
    CT_REAL_BUILD="${CT_BUILD}"
yann@1041
   275
    CT_REAL_HOST="${CT_HOST}"
yann@1041
   276
yann@1082
   277
    # Canonicalise CT_BUILD and CT_HOST
yann@1082
   278
    # Not only will it give us full-qualified tuples, but it will also ensure
yann@1082
   279
    # that they are valid tuples (in case of typo with user-provided tuples)
yann@1082
   280
    # That's way better than trying to rewrite config.sub ourselves...
yann@1089
   281
    CT_BUILD=$(CT_DoConfigSub "${CT_BUILD}")
yann@1089
   282
    CT_HOST=$(CT_DoConfigSub "${CT_HOST}")
yann@1041
   283
yann@1041
   284
    # Modify BUILD and HOST so that gcc always generate a cross-compiler
yann@1041
   285
    # even if any of the build, host or target machines are the same.
yann@1041
   286
    # NOTE: we'll have to mangle the (BUILD|HOST)->TARGET x-compiler to
yann@1041
   287
    #       support canadain build, later...
yann@1041
   288
    CT_BUILD="${CT_BUILD/-/-${build_mangle}}"
yann@1041
   289
    CT_HOST="${CT_HOST/-/-${host_mangle}}"
yann@1041
   290
yann@1041
   291
    # Now we have mangled our BUILD and HOST tuples, we must fake the new
yann@1041
   292
    # cross-tools for those mangled tuples.
yann@174
   293
    CT_DoLog DEBUG "Making build system tools available"
yann@1135
   294
    CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}/bin"
yann@1041
   295
    for m in BUILD HOST; do
yann@1041
   296
        r="CT_REAL_${m}"
yann@1041
   297
        v="CT_${m}"
yann@1041
   298
        p="CT_${m}_PREFIX"
yann@1041
   299
        s="CT_${m}_SUFFIX"
yann@1041
   300
        if [ -n "${!p}" ]; then
yann@1041
   301
            t="${!p}"
yann@1041
   302
        else
yann@1041
   303
            t="${!r}-"
yann@1041
   304
        fi
yann@1041
   305
yann@1129
   306
        for tool in ar as dlltool gcc g++ gcj gnatbind gnatmake ld nm objcopy objdump ranlib strip windres; do
yann@1041
   307
            # First try with prefix + suffix
yann@1041
   308
            # Then try with prefix only
yann@1041
   309
            # Then try with suffix only, but only for BUILD, and HOST iff REAL_BUILD == REAL_HOST
yann@1041
   310
            # Finally try with neither prefix nor suffix, but only for BUILD, and HOST iff REAL_BUILD == REAL_HOST
yann@1041
   311
            # This is needed, because some tools have a prefix and
yann@1041
   312
            # a suffix (eg. gcc), while others may have only one,
yann@1041
   313
            # or even none (eg. binutils)
yann@1041
   314
            where=$(CT_Which "${t}${tool}${!s}")
yann@1041
   315
            [ -z "${where}" ] && where=$(CT_Which "${t}${tool}")
yann@1041
   316
            if [    -z "${where}"                         \
yann@1041
   317
                 -a \(    "${m}" = "BUILD"                \
yann@1041
   318
                       -o "${CT_REAL_BUILD}" = "${!r}" \) ]; then
yann@1041
   319
                where=$(CT_Which "${tool}${!s}")
yann@1041
   320
            fi
yann@1041
   321
            if [ -z "${where}"                            \
yann@1041
   322
                 -a \(    "${m}" = "BUILD"                \
yann@1041
   323
                       -o "${CT_REAL_BUILD}" = "${!r}" \) ]; then
yann@1041
   324
                where=$(CT_Which "${tool}")
yann@1041
   325
            fi
yann@1041
   326
yann@1041
   327
            # Not all tools are available for all platforms, but some are really,
yann@1041
   328
            # bally needed
yann@1041
   329
            if [ -n "${where}" ]; then
yann@1041
   330
                CT_DoLog DEBUG "  '${!v}-${tool}' -> '${where}'"
yann@1041
   331
                printf "#${BANG}${CT_SHELL}\nexec '${where}' \"\${@}\"\n" >"${CT_PREFIX_DIR}/bin/${!v}-${tool}"
yann@1135
   332
                CT_DoExecLog ALL chmod 700 "${CT_PREFIX_DIR}/bin/${!v}-${tool}"
yann@1041
   333
            else
yann@1041
   334
                # We'll at least need some of them...
yann@1041
   335
                case "${tool}" in
yann@1041
   336
                    ar|as|gcc|ld|nm|objcopy|objdump|ranlib)
yann@1041
   337
                        CT_Abort "Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : either needed!"
yann@1041
   338
                        ;;
yann@1041
   339
                    *)
yann@1041
   340
                        # It does not deserve a WARN level.
yann@1041
   341
                        CT_DoLog DEBUG "  Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : not required."
yann@1041
   342
                        ;;
yann@1041
   343
                esac
yann@1041
   344
            fi
yann@1041
   345
        done
yann@121
   346
    done
yann@121
   347
yann@1041
   348
    # Carefully add paths in the order we want them:
yann@1041
   349
    #  - first try in ${CT_PREFIX_DIR}/bin
yann@1041
   350
    #  - then try in ${CT_CC_CORE_SHARED_PREFIX_DIR}/bin
yann@1041
   351
    #  - then try in ${CT_CC_CORE_STATIC_PREFIX_DIR}/bin
yann@1041
   352
    #  - fall back to searching user's PATH
yann@1041
   353
    # Of course, neither cross-native nor canadian can run on BUILD,
yann@1041
   354
    # so don't add those PATHs in this case...
yann@1041
   355
    case "${CT_TOOLCHAIN_TYPE}" in
yann@1041
   356
        cross)  export PATH="${CT_PREFIX_DIR}/bin:${CT_CC_CORE_SHARED_PREFIX_DIR}/bin:${CT_CC_CORE_STATIC_PREFIX_DIR}/bin:${PATH}";;
yann@1041
   357
        *)  ;;
yann@1041
   358
    esac
yann@1041
   359
yann@564
   360
    # Some makeinfo versions are a pain in [put your most sensible body part here].
yann@564
   361
    # Go ahead with those, by creating a wrapper that keeps partial files, and that
yann@564
   362
    # never fails:
yann@1135
   363
    CT_DoLog DEBUG "  'makeinfo' -> '$(CT_Which makeinfo)'"
yann@1083
   364
    printf "#${BANG}/bin/sh\n$(CT_Which makeinfo) --force \"\${@}\"\ntrue\n" >"${CT_PREFIX_DIR}/bin/makeinfo"
yann@1135
   365
    CT_DoExecLog ALL chmod 700 "${CT_PREFIX_DIR}/bin/makeinfo"
yann@564
   366
yann@121
   367
    # Help gcc
yann@121
   368
    CT_CFLAGS_FOR_HOST=
yann@121
   369
    [ "${CT_USE_PIPES}" = "y" ] && CT_CFLAGS_FOR_HOST="${CT_CFLAGS_FOR_HOST} -pipe"
yann@121
   370
yann@333
   371
    # Override the configured jobs with what's been given on the command line
yann@333
   372
    [ -n "${CT_JOBS}" ] && CT_PARALLEL_JOBS="${CT_JOBS}"
yann@333
   373
yann@1033
   374
    # Set the shell to be used by ./configure scripts and by Makefiles (those
yann@1033
   375
    # that support it!).
yann@1033
   376
    export CONFIG_SHELL="${CT_SHELL}"
yann@805
   377
yann@121
   378
    # And help make go faster
yann@121
   379
    PARALLELMFLAGS=
yann@121
   380
    [ ${CT_PARALLEL_JOBS} -ne 0 ] && PARALLELMFLAGS="${PARALLELMFLAGS} -j${CT_PARALLEL_JOBS}"
yann@121
   381
    [ ${CT_LOAD} -ne 0 ] && PARALLELMFLAGS="${PARALLELMFLAGS} -l${CT_LOAD}"
yann@568
   382
    export PARALLELMFLAGS
yann@121
   383
yann@894
   384
    CT_DoLog EXTRA "Installing user-supplied crosstool-NG configuration"
yann@1098
   385
    CT_DoExecLog DEBUG install -m 0755 "${CT_LIB_DIR}/scripts/toolchain-config.in" "${CT_PREFIX_DIR}/bin/${CT_TARGET}-ct-ng.config"
yann@909
   386
    bzip2 -c -9 .config >>"${CT_PREFIX_DIR}/bin/${CT_TARGET}-ct-ng.config"
yann@894
   387
yann@121
   388
    CT_DoStep EXTRA "Dumping internal crosstool-NG configuration"
yann@121
   389
    CT_DoLog EXTRA "Building a toolchain for:"
yann@1041
   390
    CT_DoLog EXTRA "  build  = ${CT_REAL_BUILD}"
yann@1041
   391
    CT_DoLog EXTRA "  host   = ${CT_REAL_HOST}"
yann@121
   392
    CT_DoLog EXTRA "  target = ${CT_TARGET}"
yann@121
   393
    set |egrep '^CT_.+=' |sort |CT_DoLog DEBUG
yann@121
   394
    CT_EndStep
yann@63
   395
fi
yann@63
   396
yann@121
   397
if [ -z "${CT_RESTART}" ]; then
yann@121
   398
    CT_DoStep INFO "Retrieving needed toolchain components' tarballs"
yann@121
   399
    do_kernel_get
yann@466
   400
    do_gmp_get
yann@466
   401
    do_mpfr_get
yann@121
   402
    do_binutils_get
yann@331
   403
    do_cc_get
yann@121
   404
    do_libc_get
yann@148
   405
    do_tools_get
yann@121
   406
    do_debug_get
yann@63
   407
    CT_EndStep
yann@63
   408
yann@121
   409
    if [ "${CT_ONLY_DOWNLOAD}" != "y" ]; then
yann@121
   410
        if [ "${CT_FORCE_EXTRACT}" = "y" ]; then
yann@1138
   411
            CT_DoForceRmdir "${CT_SRC_DIR}"
yann@1135
   412
            CT_DoExecLog ALL mkdir -p "${CT_SRC_DIR}"
yann@121
   413
        fi
yann@121
   414
        CT_DoStep INFO "Extracting and patching toolchain components"
yann@121
   415
        do_kernel_extract
yann@466
   416
        do_gmp_extract
yann@466
   417
        do_mpfr_extract
yann@121
   418
        do_binutils_extract
yann@331
   419
        do_cc_extract
yann@121
   420
        do_libc_extract
yann@148
   421
        do_tools_extract
yann@121
   422
        do_debug_extract
yann@121
   423
        CT_EndStep
yann@121
   424
    fi
yann@121
   425
fi
yann@85
   426
yann@121
   427
# Now for the job by itself. Go have a coffee!
yann@121
   428
if [ "${CT_ONLY_DOWNLOAD}" != "y" -a "${CT_ONLY_EXTRACT}" != "y" ]; then
yann@121
   429
    # Because of CT_RESTART, this becomes quite complex
yann@143
   430
    do_stop=0
yann@143
   431
    prev_step=
yann@121
   432
    [ -n "${CT_RESTART}" ] && do_it=0 || do_it=1
yann@466
   433
    # Aha! CT_STEPS comes from steps.mk!
yann@461
   434
    for step in ${CT_STEPS}; do
yann@121
   435
        if [ ${do_it} -eq 0 ]; then
yann@121
   436
            if [ "${CT_RESTART}" = "${step}" ]; then
yann@121
   437
                CT_DoLoadState "${step}"
yann@121
   438
                do_it=1
yann@143
   439
                do_stop=0
yann@121
   440
            fi
yann@121
   441
        else
yann@121
   442
            CT_DoSaveState ${step}
yann@143
   443
            if [ ${do_stop} -eq 1 ]; then
yann@523
   444
                CT_DoLog ERROR "Stopping just after step '${prev_step}', as requested."
yann@143
   445
                exit 0
yann@143
   446
            fi
yann@85
   447
        fi
yann@121
   448
        if [ ${do_it} -eq 1 ]; then
yann@121
   449
            do_${step}
yann@135
   450
            if [ "${CT_STOP}" = "${step}" ]; then
yann@143
   451
                do_stop=1
yann@135
   452
            fi
yann@725
   453
            if [ "${CT_DEBUG_PAUSE_STEPS}" = "y" ]; then
yann@523
   454
                CT_DoPause "Step '${step}' finished"
yann@121
   455
            fi
yann@121
   456
        fi
yann@143
   457
        prev_step="${step}"
yann@121
   458
    done
yann@63
   459
fi
yann@1
   460
yann@96
   461
CT_DoEnd INFO
yann@96
   462
yann@1135
   463
# From now-on, it can become impossible to log any time, because
yann@1135
   464
# either we're compressing the log file, or it can become RO any
yann@1135
   465
# moment... Consign all ouptut to oblivion...
yann@1135
   466
CT_DoLog INFO "Finishing installation (may take a few seconds)..."
yann@1135
   467
exec >/dev/null 2>&1
yann@174
   468
yann@1135
   469
[ "${CT_LOG_FILE_COMPRESS}" = y ] && bzip2 -9 "${CT_LOG_FILE}"
yann@1135
   470
[ "${CT_INSTALL_DIR_RO}" = "y"  ] && chmod -R a-w "${CT_INSTALL_DIR}"
yann@1
   471
yann@1
   472
trap - EXIT