scripts/build/cc_gcc.sh
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Mon May 07 09:04:02 2007 +0000 (2007-05-07)
changeset 63 89b41dbffe8d
parent 50 db48fd40bdb9
child 78 c3868084d81a
permissions -rw-r--r--
Merge the save-sample branch to trunk:
- reorder most of the environment setup,
- geting, extracting and patching are now components' sub-actions,
- save the current config as a sample to be used as a pre-configured target.
yann@1
     1
# This file adds the function to build the final gcc C compiler
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@63
     5
# Download final gcc
yann@63
     6
do_cc_get() {
yann@63
     7
    # Ah! gcc folks are kind of 'different': they store the tarballs in
yann@63
     8
    # subdirectories of the same name! That's because gcc is such /crap/ that
yann@63
     9
    # it is such /big/ that it needs being splitted for distribution! Sad. :-(
yann@63
    10
    # Arrgghh! Some of those versions does not follow this convention:
yann@63
    11
    # gcc-3.3.3 lives in releases/gcc-3.3.3, while gcc-2.95.* isn't in a
yann@63
    12
    # subdirectory! You bastard!
yann@63
    13
    CT_GetFile "${CT_CC_FILE}"                                  \
yann@63
    14
               ftp://ftp.gnu.org/gnu/gcc/${CT_CC_FILE}          \
yann@63
    15
               ftp://ftp.gnu.org/gnu/gcc/releases/${CT_CC_FILE} \
yann@63
    16
               ftp://ftp.gnu.org/gnu/gcc
yann@63
    17
}
yann@63
    18
yann@63
    19
# Extract final gcc
yann@63
    20
do_cc_extract() {
yann@63
    21
    CT_ExtractAndPatch "${CT_CC_FILE}"
yann@63
    22
}
yann@63
    23
yann@63
    24
# Build final gcc
yann@1
    25
do_cc() {
yann@48
    26
    CT_DoStep INFO "Installing final compiler"
yann@1
    27
yann@1
    28
    mkdir -p "${CT_BUILD_DIR}/build-cc"
yann@1
    29
    cd "${CT_BUILD_DIR}/build-cc"
yann@1
    30
yann@50
    31
    CT_DoLog EXTRA "Configuring final compiler"
yann@1
    32
yann@1
    33
    # Enable selected languages
yann@1
    34
    lang_opt="c"
yann@1
    35
    [ "${CT_CC_LANG_CXX}" = "y"      ] && lang_opt="${lang_opt},c++"
yann@1
    36
    [ "${CT_CC_LANG_FORTRAN}" = "y"  ] && lang_opt="${lang_opt},fortran"
yann@1
    37
    [ "${CT_CC_LANG_ADA}" = "y"      ] && lang_opt="${lang_opt},ada"
yann@1
    38
    [ "${CT_CC_LANG_JAVA}" = "y"     ] && lang_opt="${lang_opt},java"
yann@1
    39
    [ "${CT_CC_LANG_OBJC}" = "y"     ] && lang_opt="${lang_opt},objc"
yann@1
    40
    [ "${CT_CC_LANG_OBJCXX}" = "y"   ] && lang_opt="${lang_opt},obj-c++"
yann@1
    41
    CT_Test "Building Fortran language is not yet supported. Will try..." "${CT_CC_LANG_FORTRAN}" = "y"
yann@1
    42
    CT_Test "Building ADA language is not yet supported. Will try..." "${CT_CC_LANG_ADA}" = "y"
yann@1
    43
    CT_Test "Building Java language is not yet supported. Will try..." "${CT_CC_LANG_JAVA}" = "y"
yann@1
    44
    CT_Test "Building Objective-C language is not yet supported. Will try..." "${CT_CC_LANG_OBJC}" = "y"
yann@1
    45
    CT_Test "Building Objective-C++ language is not yet supported. Will try..." "${CT_CC_LANG_OBJCXX}" = "y"
yann@1
    46
    CT_Test "Building ${CT_CC_LANG_OTHERS} language(s) is not yet supported. Will try..." -n "${CT_CC_LANG_OTHERS}"
yann@48
    47
    lang_opt=`echo "${lang_opt},${CT_CC_LANG_OTHERS}" |sed -r -e 's/,+/,/g; s/,*$//;'`
yann@1
    48
yann@1
    49
    extra_config="--enable-languages=${lang_opt}"
yann@1
    50
    [ "${CT_ARCH_FLOAT_SW}" = "y" ] && extra_config="${extra_config} --with-float=soft"
yann@1
    51
    [ "${CT_SHARED_LIBS}" = "y" ] || extra_config="${extra_config} --disable-shared"
yann@45
    52
    [ -n "${CT_ARCH_ABI}" ]  && extra_config="${extra_config} --with-abi=${CT_ARCH_ABI}"
yann@1
    53
    [ -n "${CT_ARCH_CPU}" ]  && extra_config="${extra_config} --with-cpu=${CT_ARCH_CPU}"
yann@1
    54
    [ -n "${CT_ARCH_TUNE}" ] && extra_config="${extra_config} --with-tune=${CT_ARCH_TUNE}"
yann@1
    55
    [ -n "${CT_ARCH_ARCH}" ] && extra_config="${extra_config} --with-arch=${CT_ARCH_ARCH}"
yann@1
    56
    [ -n "${CT_ARCH_FPU}" ] && extra_config="${extra_config} --with-fpu=${CT_ARCH_FPU}"
yann@1
    57
    if [ "${CT_TARGET_MULTILIB}" = "y" ]; then
yann@1
    58
       extra_config="${extra_config} --enable-multilib"
yann@1
    59
    else
yann@1
    60
       extra_config="${extra_config} --disable-multilib"
yann@1
    61
    fi
yann@20
    62
    [ "${CT_CC_CXA_ATEXIT}" == "y" ] && extra_config="${extra_config} --enable-__cxa_atexit"
yann@1
    63
yann@1
    64
    CT_DoLog DEBUG "Extra config passed: \"${extra_config}\""
yann@1
    65
yann@1
    66
    # --enable-symvers=gnu really only needed for sh4 to work around a
yann@1
    67
    # detection problem only matters for gcc-3.2.x and later, I think.
yann@1
    68
    # --disable-nls to work around crash bug on ppc405, but also because
yann@1
    69
    # embedded systems don't really need message catalogs...
yann@1
    70
    CFLAGS="${CT_CFLAGS_FOR_HOST}"                  \
yann@1
    71
    "${CT_SRC_DIR}/${CT_CC_FILE}/configure"     \
yann@1
    72
        ${CT_CANADIAN_OPT}                      \
yann@1
    73
        --target=${CT_TARGET} --host=${CT_HOST} \
yann@1
    74
        --prefix="${CT_PREFIX_DIR}"             \
yann@1
    75
        ${CC_SYSROOT_ARG}                       \
yann@1
    76
        ${extra_config}                         \
yann@1
    77
        --with-local-prefix="${CT_SYSROOT_DIR}" \
yann@1
    78
        --disable-nls                           \
yann@1
    79
        --enable-threads=posix                  \
yann@1
    80
        --enable-symvers=gnu                    \
yann@1
    81
        --enable-c99                            \
yann@1
    82
        --enable-long-long                      \
yann@1
    83
        ${CT_CC_EXTRA_CONFIG}                   2>&1 |CT_DoLog DEBUG
yann@1
    84
yann@1
    85
    if [ ! "${CT_CANADIAN}" = "y" ]; then
yann@1
    86
        CT_DoLog EXTRA "Building libiberty"
yann@1
    87
        make ${PARALLELMFLAGS} all-build-libiberty 2>&1 |CT_DoLog DEBUG
yann@1
    88
    fi
yann@1
    89
yann@1
    90
yann@1
    91
    # Idea from <cort.dougan at gmail.com>:
yann@1
    92
    # Fix lib/lib64 confusion for GCC 3.3.3 on PowerPC64 and x86_64.
yann@1
    93
    # GCC 3.4.0 and up don't suffer from this confusion, and don't need this
yann@1
    94
    # kludge.
yann@1
    95
    # FIXME: we should patch gcc's source rather than uglify crosstool.sh.
yann@1
    96
    # FIXME: is this needed for gcc-3.3.[56]?
yann@1
    97
    case "${CT_CC_FILE}" in
yann@1
    98
      gcc-3.3.[34])
yann@1
    99
        case "${CT_TARGET}" in
yann@1
   100
          powerpc64-unknown-linux-gnu|x86_64-unknown-linux-gnu)
yann@1
   101
            for d in `find "${CT_SYSROOT_DIR}" -name lib -type d -empty`; do
yann@1
   102
              if [ -d `dirname "${d}"`/lib64 ] ; then
yann@1
   103
                rm -rf "${d}"
yann@1
   104
                ln -s `dirname "${d}"`/lib64 "${d}"
yann@1
   105
              fi
yann@1
   106
            done ;;
yann@1
   107
          *) ;;
yann@1
   108
        esac ;;
yann@1
   109
    esac
yann@1
   110
yann@50
   111
    CT_DoLog EXTRA "Building final compiler"
yann@1
   112
    make ${PARALLELMFLAGS} all 2>&1 |CT_DoLog DEBUG
yann@1
   113
yann@50
   114
    CT_DoLog EXTRA "Installing final compiler"
yann@1
   115
    make install 2>&1 |CT_DoLog DEBUG
yann@1
   116
yann@1
   117
    # FIXME: shouldn't people who want this just --disable-multilib in final gcc
yann@1
   118
    # and be done with it?
yann@1
   119
    # This code should probably be deleted, it was written long ago and hasn't
yann@1
   120
    # been tested in ages.
yann@1
   121
    # kludge: If the chip does not have a floating point unit
yann@1
   122
    # (i.e. if GLIBC_EXTRA_CONFIG contains --without-fp),
yann@1
   123
    # and there are shared libraries in /lib/nof, copy them to /lib
yann@1
   124
    # so they get used by default.
yann@1
   125
    # FIXME: only rs6000/powerpc seem to use nof.  See MULTILIB_DIRNAMES
yann@1
   126
    # in $GCC_DIR/gcc/config/$TARGET/* to see what your arch calls it.
yann@1
   127
    #case "${CT_LIBC_EXTRA_CONFIG}" in
yann@1
   128
    #    *--without-fp*)
yann@1
   129
    #        if test -d "${CT_SYSROOT_DIR}/lib/nof"; then
yann@1
   130
    #            cp -af "${CT_SYSROOT_DIR}/lib/nof/"*.so* "${CT_SYSROOT_DIR}/lib" || true
yann@1
   131
    #        fi
yann@1
   132
    #    ;;
yann@1
   133
    #esac
yann@1
   134
yann@1
   135
    CT_EndStep
yann@1
   136
}