scripts/crosstool-NG.sh.in
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sun Jan 17 23:06:02 2010 +0100 (2010-01-17)
changeset 1740 c57458bb354d
parent 1726 f581da7fe34e
child 1753 fcc55af9aee5
child 1755 30d91bfc1f2a
permissions -rw-r--r--
configure: do not require hg when configuring in an hg clone

When configuring in an hg clone, we need hg to compute the version string.
It can happen that users do not have Mercurial (eg. if they got a snapshot
rather that they did a full clone). In this case, we can still run, of
course, so simply fill the version string with a sufficiently explicit
value, that does not require hg. The date is a good candidate.
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@965
    25
. .config
yann@1156
    26
# Yes! We can do full logging from now on!
yann@1
    27
yann@1064
    28
# Overide the locale early, in case we ever translate crosstool-NG messages
yann@1064
    29
[ -z "${CT_NO_OVERIDE_LC_MESSAGES}" ] && export LC_ALL=C
yann@1064
    30
yann@1416
    31
# Some sanity checks in the environment and needed tools
yann@1416
    32
CT_DoLog INFO "Performing some trivial sanity checks"
yann@1416
    33
CT_TestAndAbort "Don't set LD_LIBRARY_PATH. It screws up the build." -n "${LD_LIBRARY_PATH}"
yann@1416
    34
CT_TestAndAbort "Don't set CFLAGS. It screws up the build." -n "${CFLAGS}"
yann@1416
    35
CT_TestAndAbort "Don't set CXXFLAGS. It screws up the build." -n "${CXXFLAGS}"
yann@1416
    36
CT_Test "GREP_OPTIONS screws up the build. Resetting." -n "${GREP_OPTIONS}"
yann@1416
    37
export GREP_OPTIONS=
yann@1416
    38
yann@1416
    39
# Some sanity checks on paths content
yann@1416
    40
for d in            \
yann@1416
    41
    LOCAL_TARBALLS  \
yann@1416
    42
    WORK            \
yann@1416
    43
    PREFIX          \
yann@1416
    44
    INSTALL         \
yann@1416
    45
    ; do
yann@1416
    46
        eval dir="\${CT_${d}_DIR}"
yann@1416
    47
        case "${dir}" in
yann@1416
    48
            *" "*)
yann@1416
    49
                CT_Abort "'CT_${d}_DIR'='${dir}' contains a space in it.\nDon't use spaces in paths, it breaks things."
yann@1416
    50
                ;;
yann@1416
    51
        esac
yann@1416
    52
done
yann@1416
    53
yann@1156
    54
# Where will we work?
yann@1156
    55
CT_WORK_DIR="${CT_WORK_DIR:-${CT_TOP_DIR}/targets}"
yann@1270
    56
CT_DoExecLog ALL mkdir -p "${CT_WORK_DIR}"
yann@1270
    57
yann@1270
    58
# Check build file system case-sensitiveness
yann@1278
    59
CT_DoExecLog DEBUG touch "${CT_WORK_DIR}/foo"
yann@1270
    60
CT_TestAndAbort "Your file system in '${CT_WORK_DIR}' is *not* case-sensitive!" -f "${CT_WORK_DIR}/FOO"
yann@1278
    61
CT_DoExecLog DEBUG rm -f "${CT_WORK_DIR}/foo"
yann@1156
    62
yann@1421
    63
# What's our shell?
yann@1421
    64
# Will be plain /bin/sh on most systems, except if we have /bin/ash and we
yann@1421
    65
# _explictly_ required using it
yann@1444
    66
case "${CT_CONFIG_SHELL}" in
yann@1444
    67
    sh)     CT_SHELL="/bin/sh";;
yann@1444
    68
    ash)    CT_SHELL="/bin/ash";;
yann@1445
    69
    bash)   CT_SHELL="${BASH}";;
yann@1446
    70
    custom) CT_SHELL="${CT_CONFIG_SHELL_CUSTOM_PATH}";;
yann@1444
    71
esac
yann@1444
    72
yann@1444
    73
# Check the user is using an existing SHELL to be used by ./configure and Makefiles
yann@1444
    74
CT_TestOrAbort "The CONFIG_SHELL '${CT_CONFIG_SHELL}' (${CT_SHELL}) is not valid" -f "${CT_SHELL}" -a -x "${CT_SHELL}"
yann@1421
    75
yann@1156
    76
# Create the bin-overide early
yann@1219
    77
# Contains symlinks to the tools found by ./configure
yann@1156
    78
# Note: CT_DoLog and CT_DoExecLog do not use any of those tool, so
yann@1156
    79
# they can be safely used
richard@1726
    80
CT_TOOLS_OVERIDE_DIR="${CT_WORK_DIR}/tools"
richard@1726
    81
CT_DoLog DEBUG "Creating bin-overide for tools in '${CT_TOOLS_OVERIDE_DIR}'"
richard@1726
    82
CT_DoExecLog DEBUG mkdir -p "${CT_TOOLS_OVERIDE_DIR}/bin"
yann@1156
    83
cat "${CT_LIB_DIR}/paths.mk" |while read trash line; do
yann@1156
    84
    tool="${line%%=*}"
yann@1156
    85
    path="${line#*=}"
yann@1517
    86
    CT_DoLog DEBUG "Creating script-override for '${tool}' -> '${path}'"
richard@1726
    87
    printf "#${BANG}${CT_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@96
   100
# renice oursleves
yann@762
   101
CT_DoExecLog DEBUG renice ${CT_NICE} $$
yann@1
   102
yann@894
   103
CT_DoStep DEBUG "Dumping user-supplied crosstool-NG configuration"
yann@1247
   104
CT_DoExecLog DEBUG grep -E '^(# |)CT_' .config
yann@96
   105
CT_EndStep
yann@63
   106
yann@290
   107
CT_DoLog DEBUG "Unsetting and unexporting MAKEFLAGS"
yann@290
   108
unset MAKEFLAGS
yann@290
   109
export MAKEFLAGS
yann@290
   110
yann@1
   111
CT_DoLog INFO "Building environment variables"
yann@1
   112
yann@965
   113
# Include sub-scripts instead of calling them: that way, we do not have to
yann@965
   114
# export any variable, nor re-parse the configuration and functions files.
yann@1225
   115
. "${CT_LIB_DIR}/scripts/build/internals.sh"
yann@903
   116
. "${CT_LIB_DIR}/scripts/build/arch/${CT_ARCH}.sh"
richard@1727
   117
. "${CT_LIB_DIR}/scripts/build/companion_tools.sh"
yann@965
   118
. "${CT_LIB_DIR}/scripts/build/kernel/${CT_KERNEL}.sh"
yann@1318
   119
. "${CT_LIB_DIR}/scripts/build/companion_libs/gmp.sh"
yann@1318
   120
. "${CT_LIB_DIR}/scripts/build/companion_libs/mpfr.sh"
yann@1324
   121
. "${CT_LIB_DIR}/scripts/build/companion_libs/ppl.sh"
yann@1380
   122
. "${CT_LIB_DIR}/scripts/build/companion_libs/cloog.sh"
yann@1384
   123
. "${CT_LIB_DIR}/scripts/build/companion_libs/mpc.sh"
yann@1345
   124
. "${CT_LIB_DIR}/scripts/build/binutils/binutils.sh"
yann@1345
   125
. "${CT_LIB_DIR}/scripts/build/binutils/elf2flt.sh"
yann@965
   126
. "${CT_LIB_DIR}/scripts/build/libc/${CT_LIBC}.sh"
yann@965
   127
. "${CT_LIB_DIR}/scripts/build/cc/${CT_CC}.sh"
yann@965
   128
. "${CT_LIB_DIR}/scripts/build/tools.sh"
yann@965
   129
. "${CT_LIB_DIR}/scripts/build/debug.sh"
yann@380
   130
yann@335
   131
# Target tuple: CT_TARGET needs a little love:
yann@335
   132
CT_DoBuildTargetTuple
yann@1
   133
yann@96
   134
# Kludge: If any of the configured options needs CT_TARGET,
yann@96
   135
# then rescan the options file now:
yann@1093
   136
. .config
yann@96
   137
yann@1663
   138
# Sanity check some directories
yann@1663
   139
CT_TestAndAbort "'CT_PREFIX_DIR' is not set: where should I install?" -z "${CT_PREFIX_DIR}"
yann@1663
   140
yann@397
   141
# Second kludge: merge user-supplied target CFLAGS with architecture-provided
yann@531
   142
# target CFLAGS. Do the same for LDFLAGS in case it happens in the future.
yann@531
   143
# Put user-supplied flags at the end, so that they take precedence.
yann@397
   144
CT_TARGET_CFLAGS="${CT_ARCH_TARGET_CFLAGS} ${CT_TARGET_CFLAGS}"
yann@531
   145
CT_TARGET_LDFLAGS="${CT_ARCH_TARGET_LDFLAGS} ${CT_TARGET_LDFLAGS}"
yann@767
   146
CT_CC_CORE_EXTRA_CONFIG="${CT_ARCH_CC_CORE_EXTRA_CONFIG} ${CT_CC_CORE_EXTRA_CONFIG}"
yann@767
   147
CT_CC_EXTRA_CONFIG="${CT_ARCH_CC_EXTRA_CONFIG} ${CT_CC_EXTRA_CONFIG}"
yann@397
   148
yann@1416
   149
# Compute the working directories names
yann@610
   150
CT_TARBALLS_DIR="${CT_WORK_DIR}/tarballs"
yann@610
   151
CT_SRC_DIR="${CT_WORK_DIR}/src"
yann@610
   152
CT_BUILD_DIR="${CT_WORK_DIR}/${CT_TARGET}/build"
yann@1272
   153
CT_STATE_DIR="${CT_WORK_DIR}/${CT_TARGET}/state"
yann@1272
   154
CT_CONFIG_DIR="${CT_BUILD_DIR}/configs"
yann@1272
   155
yann@121
   156
# Note: we'll always install the core compiler in its own directory, so as to
yann@331
   157
# not mix the two builds: core and final.
yann@136
   158
CT_CC_CORE_STATIC_PREFIX_DIR="${CT_BUILD_DIR}/${CT_CC}-core-static"
yann@136
   159
CT_CC_CORE_SHARED_PREFIX_DIR="${CT_BUILD_DIR}/${CT_CC}-core-shared"
yann@85
   160
yann@1392
   161
# Set LD_LIBRARY_PATH to point to prefix/lib so we can find our own
yann@1392
   162
# libraries; add as first path, so we get hit first by the dynamic linker
yann@1392
   163
CT_SetLibPath "${CT_PREFIX_DIR}/lib" first
yann@1392
   164
yann@143
   165
# We must ensure that we can restart if asked for!
yann@143
   166
if [ -n "${CT_RESTART}" -a ! -d "${CT_STATE_DIR}"  ]; then
yann@143
   167
    CT_DoLog ERROR "You asked to restart a non-restartable build"
yann@143
   168
    CT_DoLog ERROR "This happened because you didn't set CT_DEBUG_CT_SAVE_STEPS"
yann@153
   169
    CT_DoLog ERROR "in the config options for the previous build, or the state"
yann@425
   170
    CT_DoLog ERROR "directory for the previous build was deleted."
yann@143
   171
    CT_Abort "I will stop here to avoid any carnage"
yann@143
   172
fi
yann@143
   173
yann@403
   174
# If the local tarball directory does not exist, say so, and don't try to save there!
yann@1662
   175
if [    "${CT_SAVE_TARBALLS}" = "y"     \
yann@1662
   176
     -a ! -d "${CT_LOCAL_TARBALLS_DIR}" ]; then
yann@1662
   177
    CT_DoLog WARN "Directory '${CT_LOCAL_TARBALLS_DIR}' does not exist."
yann@1662
   178
    CT_DoLog WARN "Will not save downloaded tarballs to local storage."
yann@523
   179
    CT_SAVE_TARBALLS=
yann@403
   180
fi
yann@403
   181
yann@85
   182
# Check now if we can write to the destination directory:
yann@85
   183
if [ -d "${CT_INSTALL_DIR}" ]; then
yann@523
   184
    CT_TestAndAbort "Destination directory '${CT_INSTALL_DIR}' is not removable" ! -w $(dirname "${CT_INSTALL_DIR}")
yann@85
   185
fi
yann@85
   186
yann@96
   187
# Good, now grab a bit of informations on the system we're being run on,
yann@96
   188
# just in case something goes awok, and it's not our fault:
yann@523
   189
CT_SYS_USER=$(id -un)
yann@523
   190
CT_SYS_HOSTNAME=$(hostname -f 2>/dev/null || true)
yann@96
   191
# Hmmm. Some non-DHCP-enabled machines do not have an FQDN... Fall back to node name.
yann@523
   192
CT_SYS_HOSTNAME="${CT_SYS_HOSTNAME:-$(uname -n)}"
yann@523
   193
CT_SYS_KERNEL=$(uname -s)
yann@523
   194
CT_SYS_REVISION=$(uname -r)
yann@96
   195
# MacOS X lacks '-o' :
yann@523
   196
CT_SYS_OS=$(uname -o || echo "Unknown (maybe MacOS-X)")
yann@523
   197
CT_SYS_MACHINE=$(uname -m)
yann@523
   198
CT_SYS_PROCESSOR=$(uname -p)
yann@523
   199
CT_SYS_GCC=$(gcc -dumpversion)
yann@523
   200
CT_SYS_TARGET=$(CT_DoConfigGuess)
yann@96
   201
CT_TOOLCHAIN_ID="crosstool-${CT_VERSION} build ${CT_STAR_DATE_HUMAN} by ${CT_SYS_USER}@${CT_SYS_HOSTNAME}"
yann@96
   202
yann@96
   203
CT_DoLog EXTRA "Preparing working directories"
yann@96
   204
yann@121
   205
# Ah! The build directory shall be eradicated, even if we restart!
yann@85
   206
if [ -d "${CT_BUILD_DIR}" ]; then
yann@1138
   207
    CT_DoForceRmdir "${CT_BUILD_DIR}"
yann@85
   208
fi
yann@121
   209
yann@121
   210
# Don't eradicate directories if we need to restart
yann@121
   211
if [ -z "${CT_RESTART}" ]; then
yann@121
   212
    # Get rid of pre-existing installed toolchain and previous build directories.
yann@121
   213
    # We need to do that _before_ we can safely log, because the log file will
yann@121
   214
    # most probably be in the toolchain directory.
yann@121
   215
    if [ "${CT_FORCE_DOWNLOAD}" = "y" -a -d "${CT_TARBALLS_DIR}" ]; then
yann@1138
   216
        CT_DoForceRmdir "${CT_TARBALLS_DIR}"
yann@121
   217
    fi
yann@121
   218
    if [ "${CT_FORCE_EXTRACT}" = "y" -a -d "${CT_SRC_DIR}" ]; then
yann@1138
   219
        CT_DoForceRmdir "${CT_SRC_DIR}"
yann@121
   220
    fi
yann@121
   221
    if [ -d "${CT_INSTALL_DIR}" ]; then
yann@1138
   222
        CT_DoForceRmdir "${CT_INSTALL_DIR}"
yann@121
   223
    fi
yann@121
   224
    # In case we start anew, get rid of the previously saved state directory
yann@121
   225
    if [ -d "${CT_STATE_DIR}" ]; then
yann@1138
   226
        CT_DoForceRmdir "${CT_STATE_DIR}"
yann@121
   227
    fi
yann@96
   228
fi
yann@85
   229
yann@121
   230
# Create the directories we'll use, even if restarting: it does no harm to
yann@121
   231
# create already existent directories, and CT_BUILD_DIR needs to be created
yann@121
   232
# anyway
yann@1135
   233
CT_DoExecLog ALL mkdir -p "${CT_TARBALLS_DIR}"
yann@1135
   234
CT_DoExecLog ALL mkdir -p "${CT_SRC_DIR}"
yann@1135
   235
CT_DoExecLog ALL mkdir -p "${CT_BUILD_DIR}"
yann@1272
   236
CT_DoExecLog ALL mkdir -p "${CT_CONFIG_DIR}"
yann@1135
   237
CT_DoExecLog ALL mkdir -p "${CT_INSTALL_DIR}"
yann@1135
   238
CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}"
yann@1425
   239
if [ -z "${CT_CANADIAN}" ]; then
yann@1425
   240
    CT_DoExecLog ALL mkdir -p "${CT_CC_CORE_STATIC_PREFIX_DIR}"
yann@1425
   241
    CT_DoExecLog ALL mkdir -p "${CT_CC_CORE_SHARED_PREFIX_DIR}"
yann@1425
   242
fi
yann@1272
   243
yann@1272
   244
# Only create the state dir if asked for a restartable build
yann@1272
   245
[ -n "${CT_DEBUG_CT_SAVE_STEPS}" ] && CT_DoExecLog ALL mkdir -p "${CT_STATE_DIR}"
yann@121
   246
yann@1270
   247
# Check install file system case-sensitiveness
yann@1278
   248
CT_DoExecLog DEBUG touch "${CT_PREFIX_DIR}/foo"
yann@1270
   249
CT_TestAndAbort "Your file system in '${CT_PREFIX_DIR}' is *not* case-sensitive!" -f "${CT_PREFIX_DIR}/FOO"
yann@1278
   250
CT_DoExecLog DEBUG rm -f "${CT_PREFIX_DIR}/foo"
yann@1270
   251
yann@121
   252
# Kludge: CT_INSTALL_DIR and CT_PREFIX_DIR might have grown read-only if
yann@425
   253
# the previous build was successful. To be able to move the logfile there,
yann@121
   254
# switch them back to read/write
yann@1135
   255
CT_DoExecLog ALL chmod -R u+w "${CT_INSTALL_DIR}" "${CT_PREFIX_DIR}"
yann@85
   256
yann@63
   257
# Redirect log to the actual log file now we can
yann@63
   258
# It's quite understandable that the log file will be installed in the install
yann@63
   259
# directory, so we must first ensure it exists and is writeable (above) before
yann@63
   260
# we can log there
yann@112
   261
exec >/dev/null
yann@174
   262
case "${CT_LOG_TO_FILE}" in
yann@174
   263
    y)  CT_LOG_FILE="${CT_PREFIX_DIR}/build.log"
yann@174
   264
        cat "${tmp_log_file}" >>"${CT_LOG_FILE}"
yann@174
   265
        rm -f "${tmp_log_file}"
yann@174
   266
        exec >>"${CT_LOG_FILE}"
yann@174
   267
        ;;
yann@174
   268
    *)  rm -f "${tmp_log_file}"
yann@174
   269
        ;;
yann@63
   270
esac
yann@63
   271
yann@397
   272
# Setting up the rest of the environment only if not restarting
yann@121
   273
if [ -z "${CT_RESTART}" ]; then
yann@121
   274
    # Arrange paths depending on wether we use sys-root or not.
yann@121
   275
    if [ "${CT_USE_SYSROOT}" = "y" ]; then
yann@1219
   276
        CT_SYSROOT_DIR="${CT_PREFIX_DIR}/${CT_TARGET}/${CT_SYSROOT_DIR_PREFIX}/sys-root"
yann@1219
   277
        CT_DEBUGROOT_DIR="${CT_PREFIX_DIR}/${CT_TARGET}/${CT_SYSROOT_DIR_PREFIX}/debug-root"
yann@121
   278
        CT_HEADERS_DIR="${CT_SYSROOT_DIR}/usr/include"
yann@121
   279
        BINUTILS_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   280
        CC_CORE_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   281
        CC_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   282
        LIBC_SYSROOT_ARG=""
yann@121
   283
        # glibc's prefix must be exactly /usr, else --with-sysroot'd gcc will get
yann@121
   284
        # confused when $sysroot/usr/include is not present.
yann@121
   285
        # Note: --prefix=/usr is magic!
yann@121
   286
        # See http://www.gnu.org/software/libc/FAQ.html#s-2.2
yann@121
   287
    else
yann@121
   288
        # plain old way. All libraries in prefix/target/lib
yann@121
   289
        CT_SYSROOT_DIR="${CT_PREFIX_DIR}/${CT_TARGET}"
yann@1419
   290
        CT_DEBUGROOT_DIR="${CT_SYSROOT_DIR}"
yann@121
   291
        CT_HEADERS_DIR="${CT_SYSROOT_DIR}/include"
yann@121
   292
        # hack!  Always use --with-sysroot for binutils.
yann@121
   293
        # binutils 2.14 and later obey it, older binutils ignore it.
yann@121
   294
        # Lets you build a working 32->64 bit cross gcc
yann@121
   295
        BINUTILS_SYSROOT_ARG="--with-sysroot=${CT_SYSROOT_DIR}"
yann@121
   296
        # Use --with-headers, else final gcc will define disable_glibc while
yann@121
   297
        # building libgcc, and you'll have no profiling
yann@121
   298
        CC_CORE_SYSROOT_ARG="--without-headers"
yann@121
   299
        CC_SYSROOT_ARG="--with-headers=${CT_HEADERS_DIR}"
yann@121
   300
        LIBC_SYSROOT_ARG="prefix="
yann@121
   301
    fi
yann@1219
   302
    CT_DoExecLog ALL mkdir -p "${CT_SYSROOT_DIR}"
yann@1219
   303
    CT_DoExecLog ALL mkdir -p "${CT_DEBUGROOT_DIR}"
yann@121
   304
yann@121
   305
    # Prepare the 'lib' directories in sysroot, else the ../lib64 hack used by
yann@1180
   306
    # 32 -> 64 bit crosscompilers won't work, and build of final gcc will fail
yann@1180
   307
    # with: "ld: cannot open crti.o: No such file or directory"
yann@1180
   308
    # Also prepare the lib directory in the install dir, else some 64 bit archs
yann@1180
   309
    # won't build
yann@1180
   310
    CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}/lib"
yann@1135
   311
    CT_DoExecLog ALL mkdir -p "${CT_SYSROOT_DIR}/lib"
yann@1135
   312
    CT_DoExecLog ALL mkdir -p "${CT_SYSROOT_DIR}/usr/lib"
yann@121
   313
yann@1420
   314
    if [ "${CT_USE_SYSROOT}" = "y" ]; then
yann@1420
   315
      # Prevent gcc from installing its libraries outside of the sys-root
yann@1420
   316
      CT_DoExecLog ALL ln -sf "./${CT_SYSROOT_DIR_PREFIX}/sys-root/lib" "${CT_PREFIX_DIR}/${CT_TARGET}/lib"
yann@1420
   317
    fi
yann@740
   318
yann@740
   319
    # Now, in case we're 64 bits, just have lib64/ be a symlink to lib/
yann@740
   320
    # so as to have all libraries in the same directory (we can do that
yann@740
   321
    # because we are *not* multilib).
yann@1038
   322
    if [ "${CT_ARCH_64}" = "y" ]; then
yann@1180
   323
        CT_DoExecLog ALL ln -sf "lib" "${CT_PREFIX_DIR}/lib64"
yann@1135
   324
        CT_DoExecLog ALL ln -sf "lib" "${CT_SYSROOT_DIR}/lib64"
yann@1135
   325
        CT_DoExecLog ALL ln -sf "lib" "${CT_SYSROOT_DIR}/usr/lib64"
yann@1219
   326
        CT_DoExecLog ALL ln -sf "lib" "${CT_PREFIX_DIR}/${CT_TARGET}/lib64"
yann@1038
   327
    fi
yann@740
   328
yann@1041
   329
    # Determine build system if not set by the user
yann@1041
   330
    CT_Test "You did not specify the build system. That's OK, I can guess..." -z "${CT_BUILD}"
yann@1041
   331
    case "${CT_BUILD}" in
yann@1082
   332
        "") CT_BUILD=$("${CT_BUILD_PREFIX}gcc${CT_BUILD_SUFFIX}" -dumpmachine);;
yann@121
   333
    esac
yann@121
   334
yann@1083
   335
    # Prepare mangling patterns to later modify BUILD and HOST (see below)
yann@1041
   336
    case "${CT_TOOLCHAIN_TYPE}" in
yann@1041
   337
        cross)
yann@1426
   338
            # A cross-compiler runs on the same machine it is built on
yann@1041
   339
            CT_HOST="${CT_BUILD}"
yann@1041
   340
            build_mangle="build_"
yann@1041
   341
            host_mangle="build_"
yann@1426
   342
            target_mangle=""
yann@1425
   343
            install_build_tools_for="BUILD HOST"
yann@1041
   344
            ;;
yann@1426
   345
        canadian)
yann@1426
   346
            build_mangle="build_"
yann@1426
   347
            host_mangle="host_"
yann@1426
   348
            target_mangle=""
yann@1426
   349
            install_build_tools_for="BUILD HOST TARGET"
yann@1426
   350
            ;;
yann@1041
   351
        *)  CT_Abort "No code for '${CT_TOOLCHAIN_TYPE}' toolchain type!"
yann@1041
   352
            ;;
yann@1041
   353
    esac
yann@1033
   354
yann@1041
   355
    # Save the real tuples to generate shell-wrappers to the real tools
yann@1041
   356
    CT_REAL_BUILD="${CT_BUILD}"
yann@1041
   357
    CT_REAL_HOST="${CT_HOST}"
yann@1426
   358
    CT_REAL_TARGET="${CT_TARGET}"
yann@1041
   359
yann@1082
   360
    # Canonicalise CT_BUILD and CT_HOST
yann@1082
   361
    # Not only will it give us full-qualified tuples, but it will also ensure
yann@1082
   362
    # that they are valid tuples (in case of typo with user-provided tuples)
yann@1082
   363
    # That's way better than trying to rewrite config.sub ourselves...
yann@1426
   364
    # CT_TARGET is already made canonical in CT_DoBuildTargetTuple
yann@1089
   365
    CT_BUILD=$(CT_DoConfigSub "${CT_BUILD}")
yann@1089
   366
    CT_HOST=$(CT_DoConfigSub "${CT_HOST}")
yann@1041
   367
yann@1041
   368
    # Modify BUILD and HOST so that gcc always generate a cross-compiler
yann@1041
   369
    # even if any of the build, host or target machines are the same.
yann@1041
   370
    # NOTE: we'll have to mangle the (BUILD|HOST)->TARGET x-compiler to
yann@1041
   371
    #       support canadain build, later...
yann@1041
   372
    CT_BUILD="${CT_BUILD/-/-${build_mangle}}"
yann@1041
   373
    CT_HOST="${CT_HOST/-/-${host_mangle}}"
yann@1426
   374
    CT_TARGET="${CT_TARGET/-/-${target_mangle}}"
yann@1041
   375
yann@1041
   376
    # Now we have mangled our BUILD and HOST tuples, we must fake the new
yann@1041
   377
    # cross-tools for those mangled tuples.
yann@174
   378
    CT_DoLog DEBUG "Making build system tools available"
yann@1423
   379
    CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}/buildtools"
yann@1425
   380
    for m in ${install_build_tools_for}; do
yann@1041
   381
        r="CT_REAL_${m}"
yann@1041
   382
        v="CT_${m}"
yann@1041
   383
        p="CT_${m}_PREFIX"
yann@1041
   384
        s="CT_${m}_SUFFIX"
yann@1041
   385
        if [ -n "${!p}" ]; then
yann@1041
   386
            t="${!p}"
yann@1041
   387
        else
yann@1041
   388
            t="${!r}-"
yann@1041
   389
        fi
yann@1041
   390
yann@1129
   391
        for tool in ar as dlltool gcc g++ gcj gnatbind gnatmake ld nm objcopy objdump ranlib strip windres; do
yann@1041
   392
            # First try with prefix + suffix
yann@1041
   393
            # Then try with prefix only
yann@1041
   394
            # Then try with suffix only, but only for BUILD, and HOST iff REAL_BUILD == REAL_HOST
yann@1041
   395
            # Finally try with neither prefix nor suffix, but only for BUILD, and HOST iff REAL_BUILD == REAL_HOST
yann@1041
   396
            # This is needed, because some tools have a prefix and
yann@1041
   397
            # a suffix (eg. gcc), while others may have only one,
yann@1041
   398
            # or even none (eg. binutils)
yann@1041
   399
            where=$(CT_Which "${t}${tool}${!s}")
yann@1041
   400
            [ -z "${where}" ] && where=$(CT_Which "${t}${tool}")
yann@1041
   401
            if [    -z "${where}"                         \
yann@1041
   402
                 -a \(    "${m}" = "BUILD"                \
yann@1041
   403
                       -o "${CT_REAL_BUILD}" = "${!r}" \) ]; then
yann@1041
   404
                where=$(CT_Which "${tool}${!s}")
yann@1041
   405
            fi
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}")
yann@1041
   410
            fi
yann@1041
   411
yann@1041
   412
            # Not all tools are available for all platforms, but some are really,
yann@1041
   413
            # bally needed
yann@1041
   414
            if [ -n "${where}" ]; then
yann@1041
   415
                CT_DoLog DEBUG "  '${!v}-${tool}' -> '${where}'"
yann@1423
   416
                printf "#${BANG}${CT_SHELL}\nexec '${where}' \"\${@}\"\n" >"${CT_PREFIX_DIR}/buildtools/${!v}-${tool}"
yann@1423
   417
                CT_DoExecLog ALL chmod 700 "${CT_PREFIX_DIR}/buildtools/${!v}-${tool}"
yann@1041
   418
            else
yann@1041
   419
                case "${tool}" in
yann@1176
   420
                    # We'll at least need some of them...
bartvdrmeulen@1433
   421
                    ar|as|gcc|g++|ld|nm|objcopy|objdump|ranlib)
yann@1041
   422
                        CT_Abort "Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : either needed!"
yann@1041
   423
                        ;;
yann@1176
   424
                    # Some are conditionnally required
yann@1176
   425
                    # Add them in alphabetical (C locale) ordering
yann@1176
   426
                    gcj)
yann@1176
   427
                        CT_TestAndAbort "Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : either needed!" "${CT_CC_LANG_JAVA}" = "y"
yann@1176
   428
                        ;;
yann@1176
   429
                    # If any other is missing, only warn at low level
yann@1041
   430
                    *)
yann@1041
   431
                        # It does not deserve a WARN level.
yann@1041
   432
                        CT_DoLog DEBUG "  Missing: '${t}${tool}${!s}' or '${t}${tool}' or '${tool}' : not required."
yann@1041
   433
                        ;;
yann@1041
   434
                esac
yann@1041
   435
            fi
yann@1041
   436
        done
yann@121
   437
    done
yann@121
   438
yann@1041
   439
    # Carefully add paths in the order we want them:
yann@1041
   440
    #  - first try in ${CT_PREFIX_DIR}/bin
yann@1041
   441
    #  - then try in ${CT_CC_CORE_SHARED_PREFIX_DIR}/bin
yann@1041
   442
    #  - then try in ${CT_CC_CORE_STATIC_PREFIX_DIR}/bin
yann@1041
   443
    #  - fall back to searching user's PATH
yann@1041
   444
    # Of course, neither cross-native nor canadian can run on BUILD,
yann@1041
   445
    # so don't add those PATHs in this case...
yann@1041
   446
    case "${CT_TOOLCHAIN_TYPE}" in
yann@1423
   447
        cross)  export PATH="${CT_PREFIX_DIR}/buildtools:${CT_PREFIX_DIR}/bin:${CT_CC_CORE_SHARED_PREFIX_DIR}/bin:${CT_CC_CORE_STATIC_PREFIX_DIR}/bin:${PATH}";;
yann@1425
   448
        canadian) export PATH="${CT_PREFIX_DIR}/buildtools:${PATH}";;
yann@1041
   449
        *)  ;;
yann@1041
   450
    esac
yann@1041
   451
yann@564
   452
    # Some makeinfo versions are a pain in [put your most sensible body part here].
yann@564
   453
    # Go ahead with those, by creating a wrapper that keeps partial files, and that
yann@564
   454
    # never fails:
yann@1135
   455
    CT_DoLog DEBUG "  'makeinfo' -> '$(CT_Which makeinfo)'"
yann@1423
   456
    printf "#${BANG}${CT_SHELL}\n$(CT_Which makeinfo) --force \"\${@}\"\ntrue\n" >"${CT_PREFIX_DIR}/buildtools/makeinfo"
yann@1423
   457
    CT_DoExecLog ALL chmod 700 "${CT_PREFIX_DIR}/buildtools/makeinfo"
yann@564
   458
yann@121
   459
    # Help gcc
yann@121
   460
    CT_CFLAGS_FOR_HOST=
yann@121
   461
    [ "${CT_USE_PIPES}" = "y" ] && CT_CFLAGS_FOR_HOST="${CT_CFLAGS_FOR_HOST} -pipe"
yann@121
   462
yann@333
   463
    # Override the configured jobs with what's been given on the command line
yann@333
   464
    [ -n "${CT_JOBS}" ] && CT_PARALLEL_JOBS="${CT_JOBS}"
yann@333
   465
yann@1033
   466
    # Set the shell to be used by ./configure scripts and by Makefiles (those
yann@1033
   467
    # that support it!).
yann@1444
   468
    export CONFIG_SHELL="${CT_SHELL}"   # for ./configure
yann@1444
   469
    export SHELL="${CT_SHELL}"          # for Makefiles
yann@805
   470
yann@121
   471
    # And help make go faster
yann@121
   472
    PARALLELMFLAGS=
yann@121
   473
    [ ${CT_PARALLEL_JOBS} -ne 0 ] && PARALLELMFLAGS="${PARALLELMFLAGS} -j${CT_PARALLEL_JOBS}"
yann@121
   474
    [ ${CT_LOAD} -ne 0 ] && PARALLELMFLAGS="${PARALLELMFLAGS} -l${CT_LOAD}"
yann@568
   475
    export PARALLELMFLAGS
yann@121
   476
yann@894
   477
    CT_DoLog EXTRA "Installing user-supplied crosstool-NG configuration"
yann@1423
   478
    CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}/bin"
yann@1098
   479
    CT_DoExecLog DEBUG install -m 0755 "${CT_LIB_DIR}/scripts/toolchain-config.in" "${CT_PREFIX_DIR}/bin/${CT_TARGET}-ct-ng.config"
yann@1189
   480
    CT_DoExecLog DEBUG sed -r -i -e 's,@@grep@@,"'"${grep}"'",;' "${CT_PREFIX_DIR}/bin/${CT_TARGET}-ct-ng.config"
yann@909
   481
    bzip2 -c -9 .config >>"${CT_PREFIX_DIR}/bin/${CT_TARGET}-ct-ng.config"
yann@894
   482
yann@121
   483
    CT_DoStep EXTRA "Dumping internal crosstool-NG configuration"
yann@121
   484
    CT_DoLog EXTRA "Building a toolchain for:"
yann@1041
   485
    CT_DoLog EXTRA "  build  = ${CT_REAL_BUILD}"
yann@1041
   486
    CT_DoLog EXTRA "  host   = ${CT_REAL_HOST}"
yann@121
   487
    CT_DoLog EXTRA "  target = ${CT_TARGET}"
yann@1247
   488
    set |grep -E '^CT_.+=' |sort |CT_DoLog DEBUG
yann@121
   489
    CT_EndStep
yann@63
   490
fi
yann@63
   491
yann@121
   492
if [ -z "${CT_RESTART}" ]; then
yann@1689
   493
    if [ "${CT_FORBID_DOWNLOAD}" = "y" ]; then
yann@1689
   494
        CT_DoLog INFO "Downloading forbidden by configuration, skipping downloads"
yann@1689
   495
    else
yann@1689
   496
        CT_DoStep INFO "Retrieving needed toolchain components' tarballs"
richard@1727
   497
        do_companion_tools_get
yann@1689
   498
        do_kernel_get
yann@1689
   499
        do_gmp_get
yann@1689
   500
        do_mpfr_get
yann@1689
   501
        do_ppl_get
yann@1689
   502
        do_cloog_get
yann@1689
   503
        do_mpc_get
yann@1689
   504
        do_binutils_get
yann@1689
   505
        do_cc_get
yann@1689
   506
        do_libc_get
yann@1689
   507
        do_tools_get
yann@1689
   508
        do_debug_get
yann@1689
   509
        CT_EndStep
yann@1689
   510
    fi
yann@63
   511
yann@121
   512
    if [ "${CT_ONLY_DOWNLOAD}" != "y" ]; then
yann@121
   513
        if [ "${CT_FORCE_EXTRACT}" = "y" ]; then
yann@1138
   514
            CT_DoForceRmdir "${CT_SRC_DIR}"
yann@1135
   515
            CT_DoExecLog ALL mkdir -p "${CT_SRC_DIR}"
yann@121
   516
        fi
richard@1727
   517
richard@1727
   518
        if [ "${CT_COMP_TOOLS}" = "y" ]; then
richard@1727
   519
          CT_DoStep INFO "Extracting, patching and installing companion tools"
richard@1727
   520
          do_companion_tools_extract
richard@1727
   521
          do_companion_tools
richard@1727
   522
          CT_EndStep
richard@1727
   523
        fi
richard@1727
   524
yann@121
   525
        CT_DoStep INFO "Extracting and patching toolchain components"
yann@121
   526
        do_kernel_extract
yann@466
   527
        do_gmp_extract
yann@466
   528
        do_mpfr_extract
yann@1324
   529
        do_ppl_extract
yann@1380
   530
        do_cloog_extract
yann@1384
   531
        do_mpc_extract
yann@121
   532
        do_binutils_extract
yann@331
   533
        do_cc_extract
yann@121
   534
        do_libc_extract
yann@148
   535
        do_tools_extract
yann@121
   536
        do_debug_extract
yann@121
   537
        CT_EndStep
yann@121
   538
    fi
yann@121
   539
fi
yann@85
   540
yann@121
   541
# Now for the job by itself. Go have a coffee!
yann@121
   542
if [ "${CT_ONLY_DOWNLOAD}" != "y" -a "${CT_ONLY_EXTRACT}" != "y" ]; then
yann@121
   543
    # Because of CT_RESTART, this becomes quite complex
yann@143
   544
    do_stop=0
yann@143
   545
    prev_step=
yann@121
   546
    [ -n "${CT_RESTART}" ] && do_it=0 || do_it=1
yann@466
   547
    # Aha! CT_STEPS comes from steps.mk!
yann@461
   548
    for step in ${CT_STEPS}; do
yann@121
   549
        if [ ${do_it} -eq 0 ]; then
yann@121
   550
            if [ "${CT_RESTART}" = "${step}" ]; then
yann@121
   551
                CT_DoLoadState "${step}"
yann@121
   552
                do_it=1
yann@143
   553
                do_stop=0
yann@121
   554
            fi
yann@121
   555
        else
yann@121
   556
            CT_DoSaveState ${step}
yann@143
   557
            if [ ${do_stop} -eq 1 ]; then
yann@523
   558
                CT_DoLog ERROR "Stopping just after step '${prev_step}', as requested."
yann@143
   559
                exit 0
yann@143
   560
            fi
yann@85
   561
        fi
yann@121
   562
        if [ ${do_it} -eq 1 ]; then
yann@121
   563
            do_${step}
yann@135
   564
            if [ "${CT_STOP}" = "${step}" ]; then
yann@143
   565
                do_stop=1
yann@135
   566
            fi
yann@725
   567
            if [ "${CT_DEBUG_PAUSE_STEPS}" = "y" ]; then
yann@523
   568
                CT_DoPause "Step '${step}' finished"
yann@121
   569
            fi
yann@121
   570
        fi
yann@143
   571
        prev_step="${step}"
yann@121
   572
    done
yann@63
   573
fi
yann@1
   574
yann@96
   575
CT_DoEnd INFO
yann@96
   576
yann@1135
   577
# From now-on, it can become impossible to log any time, because
yann@1135
   578
# either we're compressing the log file, or it can become RO any
yann@1135
   579
# moment... Consign all ouptut to oblivion...
yann@1135
   580
CT_DoLog INFO "Finishing installation (may take a few seconds)..."
yann@1135
   581
exec >/dev/null 2>&1
yann@174
   582
yann@1135
   583
[ "${CT_LOG_FILE_COMPRESS}" = y ] && bzip2 -9 "${CT_LOG_FILE}"
yann@1135
   584
[ "${CT_INSTALL_DIR_RO}" = "y"  ] && chmod -R a-w "${CT_INSTALL_DIR}"
yann@1
   585
yann@1
   586
trap - EXIT