scripts/build/cc/gcc.sh
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Wed Jul 28 23:55:10 2010 +0200 (2010-07-28)
changeset 2043 efb1058baa31
parent 2042 d1f70bef45ba
child 2045 fdaa6c7f6dea
permissions -rw-r--r--
cc/gcc: add option to enable/disable libmudflap

For some scenarii, libmudflap is not very usefull
or can break the build. Make in an optioon that
defaults to 'N' to be on the safe side.

For the core gcc-s, there is absolutely no need
to build libmidflap.

Idea from: Bernhard Pfund <bernhard@chapter7.ch>
yann@850
     1
# This file adds the function to build the gcc C compiler
yann@850
     2
# Copyright 2007 Yann E. MORIN
yann@850
     3
# Licensed under the GPL v2. See COPYING in the root of this package
yann@850
     4
yann@850
     5
# Download gcc
yann@850
     6
do_cc_get() {
yann@850
     7
    # Ah! gcc folks are kind of 'different': they store the tarballs in
yann@850
     8
    # subdirectories of the same name! That's because gcc is such /crap/ that
yann@850
     9
    # it is such /big/ that it needs being splitted for distribution! Sad. :-(
yann@850
    10
    # Arrgghh! Some of those versions does not follow this convention:
yann@850
    11
    # gcc-3.3.3 lives in releases/gcc-3.3.3, while gcc-2.95.* isn't in a
yann@850
    12
    # subdirectory! You bastard!
yann@1389
    13
    CT_GetFile "gcc-${CT_CC_VERSION}"                                                       \
yann@1389
    14
               {ftp,http}://ftp.gnu.org/gnu/gcc{,{,/releases}/gcc-${CT_CC_VERSION}}         \
yann@1389
    15
               ftp://ftp.irisa.fr/pub/mirrors/gcc.gnu.org/gcc/releases/gcc-${CT_CC_VERSION} \
yann@1389
    16
               ftp://ftp.uvsq.fr/pub/gcc/snapshots/${CT_CC_VERSION}
yann@1268
    17
yann@1129
    18
    # Starting with GCC 4.3, ecj is used for Java, and will only be
yann@1129
    19
    # built if the configure script finds ecj.jar at the top of the
yann@1129
    20
    # GCC source tree, which will not be there unless we get it and
yann@1129
    21
    # put it there ourselves
yann@1129
    22
    if [ "${CT_CC_LANG_JAVA_USE_ECJ}" = "y" ]; then
yann@1129
    23
        CT_GetFile ecj-latest .jar ftp://gcc.gnu.org/pub/java   \
yann@1129
    24
                                   ftp://sourceware.org/pub/java
yann@1129
    25
    fi
yann@850
    26
}
yann@850
    27
yann@850
    28
# Extract gcc
yann@850
    29
do_cc_extract() {
yann@1389
    30
    CT_Extract "gcc-${CT_CC_VERSION}"
yann@1901
    31
    CT_Patch "gcc" "${CT_CC_VERSION}"
yann@1268
    32
yann@1129
    33
    # Copy ecj-latest.jar to ecj.jar at the top of the GCC source tree
yann@1389
    34
    if [ "${CT_CC_LANG_JAVA_USE_ECJ}" = "y"                     \
yann@1389
    35
         -a ! -f "${CT_SRC_DIR}/gcc-${CT_CC_VERSION}/ecj.jar"   \
yann@1259
    36
       ]; then
yann@1389
    37
        CT_DoExecLog ALL cp -v "${CT_TARBALLS_DIR}/ecj-latest.jar" "${CT_SRC_DIR}/gcc-${CT_CC_VERSION}/ecj.jar"
yann@1129
    38
    fi
yann@850
    39
}
yann@850
    40
yann@850
    41
#------------------------------------------------------------------------------
yann@850
    42
# Core gcc pass 1
yann@850
    43
do_cc_core_pass_1() {
yann@850
    44
    # If we're building for bare metal, build the static core gcc,
yann@850
    45
    # with libgcc.
linux@1925
    46
    # In case we're not bare metal and building a canadian compiler, do nothing
yann@850
    47
    # In case we're not bare metal, and we're NPTL, build the static core gcc.
yann@850
    48
    # In any other case, do nothing.
linux@1925
    49
    case "${CT_BARE_METAL},${CT_CANADIAN},${CT_THREADS}" in
yann@1983
    50
        y,*,*)  do_cc_core mode=static;;
linux@1925
    51
        ,y,*)   ;;
yann@1980
    52
        ,,nptl) do_cc_core mode=static;;
yann@850
    53
        *)      ;;
yann@850
    54
    esac
yann@850
    55
}
yann@850
    56
yann@850
    57
# Core gcc pass 2
yann@850
    58
do_cc_core_pass_2() {
yann@850
    59
    # In case we're building for bare metal, do nothing, we already have
yann@850
    60
    # our compiler.
linux@1925
    61
    # In case we're not bare metal and building a canadian compiler, do nothing
yann@892
    62
    # In case we're NPTL, build the shared core gcc and the target libgcc.
yann@892
    63
    # In any other case, build the static core gcc and, if using gcc-4.3+,
yann@892
    64
    # also build the target libgcc.
linux@1925
    65
    case "${CT_BARE_METAL},${CT_CANADIAN},${CT_THREADS}" in
yann@1983
    66
        y,*,*)  do_cc_core mode=baremetal build_libgcc=yes build_libstdcxx=yes;;
yann@1983
    67
        ,y,*)   ;;
linux@1925
    68
        ,,nptl)
yann@892
    69
            do_cc_core mode=shared build_libgcc=yes
yann@892
    70
            ;;
bartvdrmeulen@2017
    71
        ,,win32) do_cc_core mode=static build_libgcc=yes
bartvdrmeulen@2017
    72
            ;;
yann@892
    73
        *)  if [ "${CT_CC_GCC_4_3_or_later}" = "y" ]; then
yann@892
    74
                do_cc_core mode=static build_libgcc=yes
yann@892
    75
            else
yann@1980
    76
                do_cc_core mode=static
yann@892
    77
            fi
yann@892
    78
            ;;
yann@850
    79
    esac
yann@850
    80
}
yann@850
    81
yann@850
    82
#------------------------------------------------------------------------------
yann@850
    83
# Build core gcc
yann@850
    84
# This function is used to build both the static and the shared core C conpiler,
yann@850
    85
# with or without the target libgcc. We need to know wether:
yann@850
    86
#  - we're building static, shared or bare metal: mode=[static|shared|baremetal]
yann@1980
    87
#  - we need to build libgcc or not             : build_libgcc=[yes|no]     (default: no)
yann@1983
    88
#  - we need to build libstdc++ or not          : build_libstdcxx=[yes|no]  (default: no)
yann@850
    89
# Usage: do_cc_core_static mode=[static|shared|baremetal] build_libgcc=[yes|no]
yann@850
    90
do_cc_core() {
yann@850
    91
    local mode
yann@1980
    92
    local build_libgcc=no
yann@1983
    93
    local build_libstdcxx=no
yann@850
    94
    local core_prefix_dir
yann@1107
    95
    local lang_opt
yann@1479
    96
    local tmp
yann@1479
    97
    local -a extra_config
yann@1892
    98
    local core_LDFLAGS
yann@1981
    99
    local -a core_targets
yann@850
   100
yann@1980
   101
    while [ $# -ne 0 ]; do
yann@1980
   102
        eval "${1}"
yann@1980
   103
        shift
yann@1980
   104
    done
yann@850
   105
yann@1107
   106
    lang_opt=c
yann@850
   107
    case "${mode}" in
yann@850
   108
        static)
yann@850
   109
            core_prefix_dir="${CT_CC_CORE_STATIC_PREFIX_DIR}"
yann@1479
   110
            extra_config+=("--with-newlib")
yann@1479
   111
            extra_config+=("--enable-threads=no")
yann@1479
   112
            extra_config+=("--disable-shared")
yann@1983
   113
            copy_headers=y  # For baremetal, as there's no headers to copy,
yann@1983
   114
                            # we copy an empty directory. So, who cares?
yann@850
   115
            ;;
yann@850
   116
        shared)
yann@850
   117
            core_prefix_dir="${CT_CC_CORE_SHARED_PREFIX_DIR}"
yann@1479
   118
            extra_config+=("--enable-shared")
yann@850
   119
            copy_headers=y
yann@850
   120
            ;;
yann@850
   121
        baremetal)
yann@850
   122
            core_prefix_dir="${CT_PREFIX_DIR}"
yann@1479
   123
            extra_config+=("--with-newlib")
yann@1479
   124
            extra_config+=("--enable-threads=no")
yann@1479
   125
            extra_config+=("--disable-shared")
yann@1107
   126
            [ "${CT_CC_LANG_CXX}" = "y" ] && lang_opt="${lang_opt},c++"
yann@850
   127
            copy_headers=n
yann@850
   128
            ;;
yann@1980
   129
        *)
yann@1980
   130
            CT_Abort "Internal Error: 'mode' must be one of: 'static', 'shared' or 'baremetal', not '${mode:-(empty)}'"
yann@1980
   131
            ;;
yann@850
   132
    esac
yann@850
   133
yann@1980
   134
    CT_DoStep INFO "Installing ${mode} core C compiler"
yann@1980
   135
    mkdir -p "${CT_BUILD_DIR}/build-cc-core-${mode}"
yann@1980
   136
    cd "${CT_BUILD_DIR}/build-cc-core-${mode}"
yann@1980
   137
linux@1898
   138
    # Bare metal delivers the core compiler as final compiler, so add version info and bugurl
linux@1898
   139
    [ -n "${CT_CC_BUGURL}" ]     && extra_config+=("--with-bugurl=${CT_CC_BUGURL}")
linux@1898
   140
    [ -n "${CT_CC_PKGVERSION}" ] && extra_config+=("--with-pkgversion=${CT_CC_PKGVERSION}")
linux@1898
   141
yann@850
   142
    if [ "${copy_headers}" = "y" ]; then
yann@850
   143
        CT_DoLog DEBUG "Copying headers to install area of bootstrap gcc, so it can build libgcc2"
yann@1979
   144
        CT_DoExecLog ALL cp -a "${CT_HEADERS_DIR}" "${core_prefix_dir}/${CT_TARGET}/include"
yann@850
   145
    fi
yann@850
   146
yann@850
   147
    CT_DoLog EXTRA "Configuring ${mode} core C compiler"
yann@850
   148
yann@1479
   149
    for tmp in ARCH ABI CPU TUNE FPU FLOAT; do
yann@1479
   150
        eval tmp="\${CT_ARCH_WITH_${tmp}}"
yann@1479
   151
        if [ -n "${tmp}" ]; then
yann@1479
   152
            extra_config+=("${tmp}")
yann@1479
   153
        fi
yann@1479
   154
    done
yann@850
   155
    if [ "${CT_CC_CXA_ATEXIT}" = "y" ]; then
yann@1479
   156
        extra_config+=("--enable-__cxa_atexit")
yann@850
   157
    else
yann@1479
   158
        extra_config+=("--disable-__cxa_atexit")
yann@850
   159
    fi
yann@850
   160
yann@1892
   161
    # When companion libraries are build static (eg !shared),
yann@1892
   162
    # the libstdc++ is not pulled automatically, although it
yann@1892
   163
    # is needed. Shoe-horn it in our LDFLAGS
yann@1893
   164
    if [ "${CT_COMPLIBS_SHARED}" != "y" ]; then
yann@1892
   165
        core_LDFLAGS='-lstdc++'
yann@1892
   166
    fi
yann@1893
   167
    if [ "${CT_CC_GCC_USE_GMP_MPFR}" = "y" ]; then
yann@1893
   168
        extra_config+=("--with-gmp=${CT_COMPLIBS_DIR}")
yann@1893
   169
        extra_config+=("--with-mpfr=${CT_COMPLIBS_DIR}")
yann@1893
   170
    fi
yann@2014
   171
    if [ "${CT_CC_GCC_USE_PPL_CLOOG}" = "y" ]; then
yann@1893
   172
        extra_config+=("--with-ppl=${CT_COMPLIBS_DIR}")
yann@1893
   173
        extra_config+=("--with-cloog=${CT_COMPLIBS_DIR}")
yann@2014
   174
    fi
yann@2014
   175
    if [ "${CT_CC_GCC_USE_MPC_LIBELF}" = "y" ]; then
yann@1893
   176
        extra_config+=("--with-mpc=${CT_COMPLIBS_DIR}")
yann@1920
   177
        extra_config+=("--with-libelf=${CT_COMPLIBS_DIR}")
yann@1920
   178
    fi
yann@1893
   179
titus@1972
   180
    if [ "${CT_CC_GCC_ENABLE_TARGET_OPTSPACE}" = "y" ]; then
titus@1972
   181
        extra_config+=("--enable-target-optspace")
titus@1972
   182
    fi
titus@1972
   183
yann@1893
   184
    CT_DoLog DEBUG "Extra config passed: '${extra_config[*]}'"
yann@1892
   185
yann@850
   186
    # Use --with-local-prefix so older gccs don't look in /usr/local (http://gcc.gnu.org/PR10532)
yann@1041
   187
    CC_FOR_BUILD="${CT_BUILD}-gcc"                  \
yann@850
   188
    CFLAGS="${CT_CFLAGS_FOR_HOST}"                  \
yann@1892
   189
    LDFLAGS="${core_LDFLAGS}"                       \
yann@850
   190
    CT_DoExecLog ALL                                \
yann@1389
   191
    "${CT_SRC_DIR}/gcc-${CT_CC_VERSION}/configure"  \
yann@1041
   192
        --build=${CT_BUILD}                         \
yann@850
   193
        --host=${CT_HOST}                           \
yann@850
   194
        --target=${CT_TARGET}                       \
yann@850
   195
        --prefix="${core_prefix_dir}"               \
yann@850
   196
        --with-local-prefix="${CT_SYSROOT_DIR}"     \
yann@850
   197
        --disable-multilib                          \
yann@2043
   198
        --disable-libmudflap                        \
yann@850
   199
        ${CC_CORE_SYSROOT_ARG}                      \
yann@1479
   200
        "${extra_config[@]}"                        \
yann@850
   201
        --disable-nls                               \
yann@850
   202
        --enable-symvers=gnu                        \
yann@1107
   203
        --enable-languages="${lang_opt}"            \
yann@850
   204
        ${CT_CC_CORE_EXTRA_CONFIG}
yann@850
   205
yann@850
   206
    if [ "${build_libgcc}" = "yes" ]; then
yann@850
   207
        # HACK: we need to override SHLIB_LC from gcc/config/t-slibgcc-elf-ver or
yann@850
   208
        # gcc/config/t-libunwind so -lc is removed from the link for
yann@850
   209
        # libgcc_s.so, as we do not have a target -lc yet.
yann@850
   210
        # This is not as ugly as it appears to be ;-) All symbols get resolved
yann@850
   211
        # during the glibc build, and we provide a proper libgcc_s.so for the
yann@850
   212
        # cross toolchain during the final gcc build.
yann@850
   213
        #
yann@850
   214
        # As we cannot modify the source tree, nor override SHLIB_LC itself
yann@850
   215
        # during configure or make, we have to edit the resultant
yann@850
   216
        # gcc/libgcc.mk itself to remove -lc from the link.
yann@850
   217
        # This causes us to have to jump through some hoops...
yann@850
   218
        #
yann@850
   219
        # To produce libgcc.mk to edit we firstly require libiberty.a,
yann@850
   220
        # so we configure then build it.
yann@850
   221
        # Next we have to configure gcc, create libgcc.mk then edit it...
yann@850
   222
        # So much easier if we just edit the source tree, but hey...
yann@1389
   223
        if [ ! -f "${CT_SRC_DIR}/gcc-${CT_CC_VERSION}/gcc/BASE-VER" ]; then
yann@850
   224
            CT_DoExecLog ALL make configure-libiberty
yann@850
   225
            CT_DoExecLog ALL make ${PARALLELMFLAGS} -C libiberty libiberty.a
yann@850
   226
            CT_DoExecLog ALL make configure-gcc configure-libcpp
yann@850
   227
            CT_DoExecLog ALL make ${PARALLELMFLAGS} all-libcpp
yann@850
   228
        else
yann@850
   229
            CT_DoExecLog ALL make configure-gcc configure-libcpp configure-build-libiberty
yann@850
   230
            CT_DoExecLog ALL make ${PARALLELMFLAGS} all-libcpp all-build-libiberty
yann@850
   231
        fi
yann@850
   232
        # HACK: gcc-4.2 uses libdecnumber to build libgcc.mk, so build it here.
yann@1389
   233
        if [ -d "${CT_SRC_DIR}/gcc-${CT_CC_VERSION}/libdecnumber" ]; then
yann@850
   234
            CT_DoExecLog ALL make configure-libdecnumber
yann@850
   235
            CT_DoExecLog ALL make ${PARALLELMFLAGS} -C libdecnumber libdecnumber.a
yann@850
   236
        fi
yann@850
   237
yann@850
   238
        # Starting with GCC 4.3, libgcc.mk is no longer built,
yann@850
   239
        # and libgcc.mvars is used instead.
yann@850
   240
yann@892
   241
        if [ "${CT_CC_GCC_4_3_or_later}" = "y" ]; then
yann@850
   242
            libgcc_rule="libgcc.mvars"
yann@1981
   243
            core_targets=( gcc target-libgcc )
yann@850
   244
        else
yann@850
   245
            libgcc_rule="libgcc.mk"
yann@1981
   246
            core_targets=( gcc )
yann@850
   247
        fi
yann@850
   248
linux@1926
   249
        # On bare metal and canadian build the host-compiler is used when
linux@1926
   250
        # actually the build-system compiler is required. Choose the correct
linux@1926
   251
        # compilers for canadian build and use the defaults on other
linux@1926
   252
        # configurations.
linux@1926
   253
        if [ "${CT_BARE_METAL},${CT_CANADIAN}" = "y,y" ]; then
linux@1926
   254
            repair_cc="CC_FOR_BUILD=${CT_BUILD}-gcc \
linux@1926
   255
                       GCC_FOR_TARGET=${CT_TARGET}-gcc"
linux@1926
   256
        else
linux@1926
   257
            repair_cc=""
linux@1926
   258
        fi
linux@1926
   259
linux@1926
   260
        CT_DoExecLog ALL make ${PARALLELMFLAGS} -C gcc ${libgcc_rule} \
linux@1926
   261
                              ${repair_cc}
yann@850
   262
        sed -r -i -e 's@-lc@@g' gcc/${libgcc_rule}
yann@850
   263
    else # build_libgcc
yann@1981
   264
        core_targets=( gcc )
yann@850
   265
    fi   # ! build libgcc
yann@1983
   266
    if [    "${build_libstdcxx}" = "yes"    \
yann@1983
   267
         -a "${CT_CC_LANG_CXX}"  = "y"      \
yann@1983
   268
       ]; then
yann@1983
   269
        core_targets+=( target-libstdc++-v3 )
yann@1983
   270
    fi
yann@850
   271
yann@850
   272
    CT_DoLog EXTRA "Building ${mode} core C compiler"
yann@1981
   273
    CT_DoExecLog ALL make ${PARALLELMFLAGS} "${core_targets[@]/#/all-}"
yann@850
   274
yann@850
   275
    CT_DoLog EXTRA "Installing ${mode} core C compiler"
yann@1981
   276
    CT_DoExecLog ALL make "${core_targets[@]/#/install-}"
yann@850
   277
yann@1269
   278
    # Create a symlink ${CT_TARGET}-cc to ${CT_TARGET}-gcc to always be able
yann@1269
   279
    # to call the C compiler with the same, somewhat canonical name.
linux@1924
   280
    # check whether compiler has an extension
linux@1924
   281
    file="$( ls -1 "${core_prefix_dir}/bin/${CT_TARGET}-gcc."* 2>/dev/null || true )"
linux@1924
   282
    [ -z "${file}" ] || ext=".${file##*.}"
linux@1924
   283
    CT_DoExecLog ALL ln -sv "${CT_TARGET}-gcc${ext}" "${core_prefix_dir}/bin/${CT_TARGET}-cc${ext}"
yann@1269
   284
yann@850
   285
    CT_EndStep
yann@850
   286
}
yann@850
   287
yann@850
   288
#------------------------------------------------------------------------------
yann@850
   289
# Build final gcc
yann@850
   290
do_cc() {
yann@1479
   291
    local -a extra_config
yann@1479
   292
    local tmp
yann@1892
   293
    local final_LDFLAGS
yann@1479
   294
yann@850
   295
    # If building for bare metal, nothing to be done here, the static core conpiler is enough!
yann@850
   296
    [ "${CT_BARE_METAL}" = "y" ] && return 0
yann@850
   297
yann@850
   298
    CT_DoStep INFO "Installing final compiler"
yann@850
   299
yann@850
   300
    mkdir -p "${CT_BUILD_DIR}/build-cc"
yann@850
   301
    cd "${CT_BUILD_DIR}/build-cc"
yann@850
   302
yann@850
   303
    CT_DoLog EXTRA "Configuring final compiler"
yann@850
   304
yann@850
   305
    # Enable selected languages
yann@850
   306
    lang_opt="c"
yann@850
   307
    [ "${CT_CC_LANG_CXX}" = "y"      ] && lang_opt="${lang_opt},c++"
yann@850
   308
    [ "${CT_CC_LANG_FORTRAN}" = "y"  ] && lang_opt="${lang_opt},fortran"
yann@850
   309
    [ "${CT_CC_LANG_ADA}" = "y"      ] && lang_opt="${lang_opt},ada"
yann@850
   310
    [ "${CT_CC_LANG_JAVA}" = "y"     ] && lang_opt="${lang_opt},java"
yann@850
   311
    [ "${CT_CC_LANG_OBJC}" = "y"     ] && lang_opt="${lang_opt},objc"
yann@850
   312
    [ "${CT_CC_LANG_OBJCXX}" = "y"   ] && lang_opt="${lang_opt},obj-c++"
yann@850
   313
    CT_Test "Building ADA language is not yet supported. Will try..." "${CT_CC_LANG_ADA}" = "y"
yann@850
   314
    CT_Test "Building Objective-C language is not yet supported. Will try..." "${CT_CC_LANG_OBJC}" = "y"
yann@850
   315
    CT_Test "Building Objective-C++ language is not yet supported. Will try..." "${CT_CC_LANG_OBJCXX}" = "y"
yann@850
   316
    CT_Test "Building ${CT_CC_LANG_OTHERS//,/ } language(s) is not yet supported. Will try..." -n "${CT_CC_LANG_OTHERS}"
yann@850
   317
    lang_opt=$(echo "${lang_opt},${CT_CC_LANG_OTHERS}" |sed -r -e 's/,+/,/g; s/,*$//;')
yann@850
   318
yann@1479
   319
    extra_config+=("--enable-languages=${lang_opt}")
yann@1479
   320
    extra_config+=("--disable-multilib")
yann@1479
   321
    for tmp in ARCH ABI CPU TUNE FPU FLOAT; do
yann@1479
   322
        eval tmp="\${CT_ARCH_WITH_${tmp}}"
yann@1479
   323
        if [ -n "${tmp}" ]; then
yann@1479
   324
            extra_config+=("${tmp}")
yann@1479
   325
        fi
yann@1479
   326
    done
yann@1479
   327
yann@1479
   328
    [ "${CT_SHARED_LIBS}" = "y" ]                   || extra_config+=("--disable-shared")
yann@1479
   329
    [ -n "${CT_CC_PKGVERSION}" ]                    && extra_config+=("--with-pkgversion=${CT_CC_PKGVERSION}")
yann@1479
   330
    [ -n "${CT_CC_BUGURL}" ]                        && extra_config+=("--with-bugurl=${CT_CC_BUGURL}")
yann@2042
   331
    case "${CT_CC_GCC_SJLJ_EXCEPTIONS}" in
yann@2042
   332
        y)  extra_config+=("--enable-sjlj-exceptions");;
yann@2042
   333
        m)  ;;
yann@2042
   334
        "") extra_config+=("--disable-sjlj-exceptions");;
yann@2042
   335
    esac
yann@850
   336
    if [ "${CT_CC_CXA_ATEXIT}" = "y" ]; then
yann@1479
   337
        extra_config+=("--enable-__cxa_atexit")
yann@850
   338
    else
yann@1479
   339
        extra_config+=("--disable-__cxa_atexit")
yann@850
   340
    fi
yann@1484
   341
    if [ -n "${CC_ENABLE_CXX_FLAGS}" ]; then
yann@1484
   342
        extra_config+=("--enable-cxx-flags=${CC_ENABLE_CXX_FLAGS}")
yann@1484
   343
    fi
yann@2043
   344
    if [ "${CT_CC_GCC_LIBMUDFLAP}" = "y" ]; then
yann@2043
   345
        extra_config+=(--enable-libmudflap)
yann@2043
   346
    else
yann@2043
   347
        extra_config+=(--disable-libmudflap)
yann@2043
   348
    fi
yann@1893
   349
yann@1893
   350
    # When companion libraries are build static (eg !shared),
yann@1893
   351
    # the libstdc++ is not pulled automatically, although it
yann@1893
   352
    # is needed. Shoe-horn it in our LDFLAGS
yann@1893
   353
    if [ "${CT_COMPLIBS_SHARED}" != "y" ]; then
yann@1893
   354
        final_LDFLAGS='-lstdc++'
yann@1893
   355
    fi
lacombar@1880
   356
    if [ "${CT_CC_GCC_USE_GMP_MPFR}" = "y" ]; then
yann@1893
   357
        extra_config+=("--with-gmp=${CT_COMPLIBS_DIR}")
yann@1893
   358
        extra_config+=("--with-mpfr=${CT_COMPLIBS_DIR}")
yann@1848
   359
    fi
yann@2014
   360
    if [ "${CT_CC_GCC_USE_PPL_CLOOG}" = "y" ]; then
yann@1893
   361
        extra_config+=("--with-ppl=${CT_COMPLIBS_DIR}")
yann@1893
   362
        extra_config+=("--with-cloog=${CT_COMPLIBS_DIR}")
yann@2014
   363
    fi
yann@2014
   364
    if [ "${CT_CC_GCC_USE_MPC_LIBELF}" = "y" ]; then
yann@1893
   365
        extra_config+=("--with-mpc=${CT_COMPLIBS_DIR}")
yann@1920
   366
        extra_config+=("--with-libelf=${CT_COMPLIBS_DIR}")
yann@1920
   367
    fi
yann@850
   368
lacombar@1881
   369
    if [ "${CT_THREADS}" = "none" ]; then
lacombar@1881
   370
        extra_config+=("--disable-threads")
lacombar@1881
   371
        if [ "${CT_CC_GCC_4_2_or_later}" = y ]; then
lacombar@1881
   372
            extra_config+=("--disable-libgomp")
lacombar@1881
   373
        fi
lacombar@1881
   374
    else
bartvdrmeulen@2017
   375
        if [ "${CT_THREADS}" = "win32" ]; then
bartvdrmeulen@2017
   376
            extra_config+=("--enable-threads=win32")
bartvdrmeulen@2017
   377
            extra_config+=("--disable-win32-registry")
bartvdrmeulen@2017
   378
        else
bartvdrmeulen@2017
   379
            extra_config+=("--enable-threads=posix")
bartvdrmeulen@2017
   380
        fi
lacombar@1881
   381
    fi
lacombar@1881
   382
titus@1972
   383
    if [ "${CT_CC_GCC_ENABLE_TARGET_OPTSPACE}" = "y" ]; then
titus@1972
   384
        extra_config+=("--enable-target-optspace")
titus@1972
   385
    fi
yann@1991
   386
    if [ "${CT_CC_GCC_DISABLE_PCH}" = "y" ]; then
yann@1991
   387
        extra_config+=("--disable-libstdcxx-pch")
yann@1991
   388
    fi
titus@1972
   389
yann@1479
   390
    CT_DoLog DEBUG "Extra config passed: '${extra_config[*]}'"
yann@850
   391
yann@850
   392
    # --enable-symvers=gnu really only needed for sh4 to work around a
yann@850
   393
    # detection problem only matters for gcc-3.2.x and later, I think.
yann@850
   394
    # --disable-nls to work around crash bug on ppc405, but also because
yann@850
   395
    # embedded systems don't really need message catalogs...
yann@1122
   396
    CC_FOR_BUILD="${CT_BUILD}-gcc"                  \
yann@1122
   397
    CFLAGS="${CT_CFLAGS_FOR_HOST}"                  \
yann@1892
   398
    LDFLAGS="${final_LDFLAGS}"                      \
yann@1122
   399
    CFLAGS_FOR_TARGET="${CT_TARGET_CFLAGS}"         \
yann@1122
   400
    CXXFLAGS_FOR_TARGET="${CT_TARGET_CFLAGS}"       \
yann@1122
   401
    LDFLAGS_FOR_TARGET="${CT_TARGET_LDFLAGS}"       \
yann@1122
   402
    CT_DoExecLog ALL                                \
yann@1389
   403
    "${CT_SRC_DIR}/gcc-${CT_CC_VERSION}/configure"  \
yann@1122
   404
        --build=${CT_BUILD}                         \
yann@1122
   405
        --host=${CT_HOST}                           \
yann@1122
   406
        --target=${CT_TARGET}                       \
yann@1122
   407
        --prefix="${CT_PREFIX_DIR}"                 \
yann@1122
   408
        ${CC_SYSROOT_ARG}                           \
yann@1479
   409
        "${extra_config[@]}"                        \
yann@1122
   410
        --with-local-prefix="${CT_SYSROOT_DIR}"     \
yann@1122
   411
        --disable-nls                               \
yann@1122
   412
        --enable-symvers=gnu                        \
yann@1122
   413
        --enable-c99                                \
yann@1122
   414
        --enable-long-long                          \
yann@850
   415
        ${CT_CC_EXTRA_CONFIG}
yann@850
   416
yann@850
   417
    if [ "${CT_CANADIAN}" = "y" ]; then
yann@850
   418
        CT_DoLog EXTRA "Building libiberty"
yann@850
   419
        CT_DoExecLog ALL make ${PARALLELMFLAGS} all-build-libiberty
yann@850
   420
    fi
yann@850
   421
yann@850
   422
    CT_DoLog EXTRA "Building final compiler"
yann@850
   423
    CT_DoExecLog ALL make ${PARALLELMFLAGS} all
yann@850
   424
yann@850
   425
    CT_DoLog EXTRA "Installing final compiler"
yann@850
   426
    CT_DoExecLog ALL make install
yann@850
   427
yann@850
   428
    # Create a symlink ${CT_TARGET}-cc to ${CT_TARGET}-gcc to always be able
yann@850
   429
    # to call the C compiler with the same, somewhat canonical name.
linux@1924
   430
    # check whether compiler has an extension
bartvdrmeulen@2031
   431
    file="$( ls -1 "${CT_PREFIX_DIR}/bin/${CT_TARGET}-gcc."* 2>/dev/null || true )"
linux@1924
   432
    [ -z "${file}" ] || ext=".${file##*.}"
linux@1924
   433
    CT_DoExecLog ALL ln -sv "${CT_TARGET}-gcc${ext}" "${CT_PREFIX_DIR}/bin/${CT_TARGET}-cc${ext}"
yann@850
   434
yann@850
   435
    CT_EndStep
yann@850
   436
}