scripts/build/debug/200-duma.sh
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Wed May 27 21:16:01 2009 +0000 (2009-05-27)
branchgcc-4.4
changeset 1393 b432bd628b10
parent 1238 73c8b86a05b1
child 1489 8c45efc97e7f
permissions -rw-r--r--
/devel/gcc-4.4:
- add gcc-4.4.0 patches, vampirised from the Gentoo patchset
- gcc-4.4.0 auto-selects and uses appropriate companion linraries

-------- diffstat follows --------
/devel/gcc-4.4/scripts/build/cc/gcc.sh | 20 18 2 0 +
/devel/gcc-4.4/patches/gcc/4.4.0/280-freebsd.patch | 188 188 0 0 ++++++++++
/devel/gcc-4.4/patches/gcc/4.4.0/140-default-format-security.patch | 98 98 0 0 +++++
/devel/gcc-4.4/patches/gcc/4.4.0/290-freebsd.patch | 128 128 0 0 +++++++
/devel/gcc-4.4/patches/gcc/4.4.0/310-uclibc-conf.patch | 70 70 0 0 ++++
/devel/gcc-4.4/patches/gcc/4.4.0/240-libstdc++-pic.patch | 106 106 0 0 ++++++
/devel/gcc-4.4/patches/gcc/4.4.0/260-sh-libgcc-stacks.patch | 50 50 0 0 +++
/devel/gcc-4.4/patches/gcc/4.4.0/100-alpha-mieee-default.patch | 48 48 0 0 +++
/devel/gcc-4.4/patches/gcc/4.4.0/180-libgomp-no-werror.patch | 24 24 0 0 +
/devel/gcc-4.4/patches/gcc/4.4.0/170-sparc64-bsd.patch | 58 58 0 0 +++
/devel/gcc-4.4/patches/gcc/4.4.0/200-libiberty.h-asprintf.patch | 30 30 0 0 ++
/devel/gcc-4.4/patches/gcc/4.4.0/220-libiberty-pic.patch | 22 22 0 0 +
/devel/gcc-4.4/patches/gcc/4.4.0/110-trampolinewarn.patch | 54 54 0 0 +++
/devel/gcc-4.4/patches/gcc/4.4.0/160-netbsd-symbolic.patch | 22 22 0 0 +
/devel/gcc-4.4/patches/gcc/4.4.0/190-flatten-switch-stmt-00.patch | 48 48 0 0 +++
/devel/gcc-4.4/patches/gcc/4.4.0/150-default-fortify-source.patch | 52 52 0 0 +++
/devel/gcc-4.4/patches/gcc/4.4.0/340-libmudflap-susv3-legacy.patch | 96 96 0 0 +++++
/devel/gcc-4.4/patches/gcc/4.4.0/120-java-nomulti.patch | 92 92 0 0 +++++
/devel/gcc-4.4/patches/gcc/4.4.0/270-sh-pr24836.patch | 48 48 0 0 +++
/devel/gcc-4.4/patches/gcc/4.4.0/330-c99-snprintf.patch | 24 24 0 0 +
/devel/gcc-4.4/patches/gcc/4.4.0/230-superh-default-multilib.patch | 24 24 0 0 +
/devel/gcc-4.4/patches/gcc/4.4.0/250-ia64-noteGNUstack.patch | 158 158 0 0 +++++++++
/devel/gcc-4.4/patches/gcc/4.4.0/300-pr40105.patch | 360 360 0 0 ++++++++++++++++++++
/devel/gcc-4.4/patches/gcc/4.4.0/210-arm-unbreak-armv4t.patch | 24 24 0 0 +
/devel/gcc-4.4/patches/gcc/4.4.0/130-cross-compile.patch | 78 78 0 0 ++++
/devel/gcc-4.4/patches/gcc/4.4.0/320-missing-execinfo_h.patch | 24 24 0 0 +
/devel/gcc-4.4/config/cc/gcc.in | 1 1 0 0 +
27 files changed, 1945 insertions(+), 2 deletions(-)
     1 # Build script for D.U.M.A.
     2 
     3 do_debug_duma_get() {
     4     CT_GetFile "duma_${CT_DUMA_VERSION}" http://mesh.dl.sourceforge.net/sourceforge/duma/
     5     # Downloading from sourceforge leaves garbage, cleanup
     6     CT_DoExecLog ALL rm -f "${CT_TARBALLS_DIR}/showfiles.php"*
     7 }
     8 
     9 do_debug_duma_extract() {
    10     CT_Extract "duma_${CT_DUMA_VERSION}"
    11     CT_Pushd "${CT_SRC_DIR}/duma_${CT_DUMA_VERSION}"
    12     # Even if DUMA uses _ and not -, crosstool-NG uses the dash to split the
    13     # name from the version in order to find the appropriate patches
    14     # YEM: FIXME: make CT_Patch more intelligent, Eg.: CT_Patch duma _ "${CT_DUMA_VERSION}"
    15     CT_DoExecLog DEBUG touch "${CT_SRC_DIR}/.duma-${CT_DUMA_VERSION}.extracted"
    16     CT_Patch "duma-${CT_DUMA_VERSION}" nochdir
    17     CT_Popd
    18 }
    19 
    20 do_debug_duma_build() {
    21     CT_DoStep INFO "Installing D.U.M.A."
    22     CT_DoLog EXTRA "Copying sources"
    23     cp -a "${CT_SRC_DIR}/duma_${CT_DUMA_VERSION}" "${CT_BUILD_DIR}/build-duma"
    24     CT_Pushd "${CT_BUILD_DIR}/build-duma"
    25 
    26     DUMA_CPP=
    27     [ "${CT_CC_LANG_CXX}" = "y" ] && DUMA_CPP=1
    28 
    29     # The shared library needs some love: some version have libduma.so.0.0,
    30     # while others have libduma.so.0.0.0
    31     duma_so=$(make -n -p 2>&1 |grep -E '^libduma.so[^:]*:' |head -n 1 |cut -d : -f 1)
    32 
    33     libs=
    34     [ "${CT_DUMA_A}" = "y" ] && libs="${libs} libduma.a"
    35     [ "${CT_DUMA_SO}" = "y" ] && libs="${libs} ${duma_so}"
    36     libs="${libs# }"
    37     CT_DoLog EXTRA "Building libraries '${libs}'"
    38     CT_DoExecLog ALL                    \
    39     make HOSTCC="${CT_BUILD}-gcc"       \
    40          CC="${CT_TARGET}-gcc"          \
    41          CXX="${CT_TARGET}-gcc"         \
    42          RANLIB="${CT_TARGET}-ranlib"   \
    43          DUMA_CPP="${DUMA_CPP}"         \
    44          ${libs}
    45     CT_DoLog EXTRA "Installing libraries '${libs}'"
    46     CT_DoExecLog ALL install -m 644 ${libs} "${CT_SYSROOT_DIR}/usr/lib"
    47     if [ "${CT_DUMA_SO}" = "y" ]; then
    48         CT_DoLog EXTRA "Installing shared library link"
    49         ln -vsf ${duma_so} "${CT_SYSROOT_DIR}/usr/lib/libduma.so"   2>&1 |CT_DoLog ALL
    50         CT_DoLog EXTRA "Installing wrapper script"
    51         mkdir -p "${CT_DEBUGROOT_DIR}/usr/bin"
    52         # Install a simpler, smaller, safer wrapper than the one provided by D.U.M.A.
    53         sed -r -e 's:^LIBDUMA_SO=.*:LIBDUMA_SO=/usr/lib/'"${duma_so}"':;'   \
    54             "${CT_LIB_DIR}/scripts/build/debug/duma.in"                     \
    55             >"${CT_DEBUGROOT_DIR}/usr/bin/duma"
    56         chmod 755 "${CT_DEBUGROOT_DIR}/usr/bin/duma"
    57     fi
    58 
    59     CT_Popd
    60     CT_EndStep
    61 }
    62