# HG changeset patch # User "Yann E. MORIN" # Date 1293643180 -3600 # Node ID 49fa28e62b076e8c7c1d7b8aab61395965101ea2 # Parent c69f8ef4bc7c2c6ddb4266443f2e2ed75c418e5f binutils/binutils: add wrapper to gold and ld When both gold and ld are installed, add a wrapper that calls to either gold or ld. In case the wrapper is installed, we also need to symlink ld.bfd and ld.gold for the core_cc steps. Signed-off-by: "Yann E. MORIN" diff -r c69f8ef4bc7c -r 49fa28e62b07 config/binutils/binutils.in --- a/config/binutils/binutils.in Sun Jan 02 13:52:16 2011 +0100 +++ b/config/binutils/binutils.in Wed Dec 29 18:19:40 2010 +0100 @@ -100,6 +100,7 @@ depends on BINUTILS_HAS_GOLD depends on EXPERIMENTAL select BINUTILS_GOLD_INSTALLED + select BINUTILS_LINKER_BOTH help Both the historical ld and the new gold linkers will be installed, with ld being the default linker used. @@ -112,6 +113,7 @@ depends on BINUTILS_HAS_GOLD depends on EXPERIMENTAL select BINUTILS_GOLD_INSTALLED + select BINUTILS_LINKER_BOTH help Both the historical ld and the new gold linkers will be installed, with gold being the default linker used. @@ -131,6 +133,9 @@ When configured with threads, gold can link in parallel, possibly cooperating with a make jobserver. +config BINUTILS_LINKER_BOTH + bool + config BINUTILS_LINKERS_LIST string default "ld" if BINUTILS_LINKER_LD @@ -138,6 +143,25 @@ default "ld,gold" if BINUTILS_LINKER_LD_GOLD default "gold,ld" if BINUTILS_LINKER_GOLD_LD +config BINUTILS_LD_WRAPPER + bool + prompt "| Add ld wrapper" + depends on BINUTILS_LINKER_BOTH + help + Add an ld wrapper that calls to either gold or ld. + + By default, the wrapper will call to the default wrapper, + but if you set the environment variable CTNG_LD_IS, you + can change which linker will get called: + CTNG_LD_IS=gold will unconditionally call the gold linker + CTNG_LD_IS=bfd will unconditionally call the old bfd ld linker + +config BINUTILS_LINKER_DEFAULT + string + depends on BINUTILS_LD_WRAPPER + default "bfd" if BINUTILS_LINKER_LD_GOLD + default "gold" if BINUTILS_LINKER_GOLD_LD + endif # BINUTILS_HAS_GOLD config BINUTILS_PLUGINS diff -r c69f8ef4bc7c -r 49fa28e62b07 scripts/build/binutils/binutils-ld.in --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/scripts/build/binutils/binutils-ld.in Wed Dec 29 18:19:40 2010 +0100 @@ -0,0 +1,11 @@ +#!/bin/sh + +call_to=@@DEFAULT_LD@@ + +case "${CTNG_LD_IS}" in + bfd) call_to=bfd;; + gold) call_to=gold;; +esac + +exec "${0}.${call_to}" "$@" +exit $? diff -r c69f8ef4bc7c -r 49fa28e62b07 scripts/build/binutils/binutils.sh --- a/scripts/build/binutils/binutils.sh Sun Jan 02 13:52:16 2011 +0100 +++ b/scripts/build/binutils/binutils.sh Wed Dec 29 18:19:40 2010 +0100 @@ -19,6 +19,7 @@ do_binutils() { local -a extra_config local -a extra_make_flags + local -a binutils_tools mkdir -p "${CT_BUILD_DIR}/build-binutils" cd "${CT_BUILD_DIR}/build-binutils" @@ -27,19 +28,24 @@ CT_DoLog EXTRA "Configuring binutils" + binutils_tools=( ar as ld strip ) if [ "${CT_BINUTILS_HAS_GOLD}" = "y" ]; then case "${CT_BINUTILS_LINKERS_LIST}" in ld) extra_config+=( --enable-ld=yes --enable-gold=no ) + binutils_tools+=( ld.bfd ) ;; gold) extra_config+=( --enable-ld=no --enable-gold=yes ) + binutils_tools+=( ld.gold ) ;; ld,gold) extra_config+=( --enable-ld=default --enable-gold=yes ) + binutils_tools+=( ld.bfd ld.gold ) ;; gold,ld) extra_config+=( --enable-ld=yes --enable-gold=default ) + binutils_tools+=( ld.bfd ld.gold ) ;; esac if [ "${CT_BINUTILS_GOLD_THREADED}" = "y" ]; then @@ -79,6 +85,16 @@ CT_DoLog EXTRA "Installing binutils" CT_DoExecLog ALL make install + # Install the wrapper if needed + if [ "${CT_BINUTILS_LD_WRAPPER}" = "y" ]; then + CT_DoLog EXTRA "Installing ld wrapper" + rm -f "${CT_PREFIX_DIR}/bin/${CT_TARGET}-ld" + sed -r -e "s/@@DEFAULT_LD@@/${CT_BINUTILS_LINKER_DEFAULT}/" \ + "${CT_LIB_DIR}/scripts/build/binutils/binutils-ld.in" \ + >"${CT_PREFIX_DIR}/bin/${CT_TARGET}-ld" + chmod +x "${CT_PREFIX_DIR}/bin/${CT_TARGET}-ld" + fi + # Make those new tools available to the core C compilers to come. # Note: some components want the ${TARGET}-{ar,as,ld,strip} commands as # well. Create that. @@ -86,7 +102,7 @@ mkdir -p "${CT_CC_CORE_STATIC_PREFIX_DIR}/bin" mkdir -p "${CT_CC_CORE_SHARED_PREFIX_DIR}/${CT_TARGET}/bin" mkdir -p "${CT_CC_CORE_SHARED_PREFIX_DIR}/bin" - for t in ar as ld strip; do + for t in "${binutils_tools[@]}"; do ln -sv "${CT_PREFIX_DIR}/bin/${CT_TARGET}-${t}" "${CT_CC_CORE_STATIC_PREFIX_DIR}/${CT_TARGET}/bin/${t}" ln -sv "${CT_PREFIX_DIR}/bin/${CT_TARGET}-${t}" "${CT_CC_CORE_STATIC_PREFIX_DIR}/bin/${CT_TARGET}-${t}" ln -sv "${CT_PREFIX_DIR}/bin/${CT_TARGET}-${t}" "${CT_CC_CORE_SHARED_PREFIX_DIR}/${CT_TARGET}/bin/${t}"