diff options
author | Travis Tilley <lv@gentoo.org> | 2004-10-04 03:55:11 +0000 |
---|---|---|
committer | Travis Tilley <lv@gentoo.org> | 2004-10-04 03:55:11 +0000 |
commit | 30fec329b0696f715bfa1ac0aa8ea1256e404dc3 (patch) | |
tree | 2f314ed89a4ec198425a9e74e20cd5d02f4e8c75 /eclass | |
parent | switched custom ARCH setting code to use set_arch_to_* from eutils (diff) | |
download | historical-30fec329b0696f715bfa1ac0aa8ea1256e404dc3.tar.gz historical-30fec329b0696f715bfa1ac0aa8ea1256e404dc3.tar.bz2 historical-30fec329b0696f715bfa1ac0aa8ea1256e404dc3.zip |
add support for creating a pie-but-not-ssp hardened specs file, and add a do_gcc_config for calling gcc-config in a way that remembers your specsfile choice.
Diffstat (limited to 'eclass')
-rw-r--r-- | eclass/toolchain.eclass | 36 |
1 files changed, 34 insertions, 2 deletions
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass index 8f4b992a2f81..dabdb672ee78 100644 --- a/eclass/toolchain.eclass +++ b/eclass/toolchain.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2004 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/toolchain.eclass,v 1.22 2004/10/03 22:11:40 lv Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/toolchain.eclass,v 1.23 2004/10/04 03:55:11 lv Exp $ # # This eclass should contain general toolchain-related functions that are # expected to not change, or change much. @@ -487,9 +487,41 @@ create_hardened_specs_file() { } +create_hardenednossp_specs_file() { + pushd ${WORKDIR}/build/gcc > /dev/null + cp Makefile Makefile.orig + sed -i -e 's#ALL_CFLAGS = #ALL_CFLAGS = -DEFAULT_PIE #' Makefile + mv xgcc xgcc.moo + mv gcc.o gcc.o.moo + make xgcc + einfo "Creating a hardened no-ssp gcc specs file" + ./xgcc -dumpspecs > ${WORKDIR}/build/hardenednossp.specs + # restore everything to normal + mv gcc.o.moo gcc.o + mv xgcc.moo xgcc + mv Makefile.orig Makefile + popd > /dev/null +} + + split_out_specs_files() { - create_hardened_specs_file || die "failes to split out hardened specs" + create_hardened_specs_file || die "failed to split out hardened specs" create_vanilla_specs_file || die "failed to split out vanilla specs" + create_hardenednossp_specs_file || die "failed to create nossp hardened specs" +} + + +do_gcc_config() { + local current_gcc_config="$(gcc-config -c)" + local current_specs="$(echo ${current_gcc_config} | awk -F - '{ print $6 }')" + [ -n "${current_specs}" ] && local use_specs="-${current_specs}" + + # we only want to switch compilers if installing to / and we're not + # building a cross-compiler. + if [ "${ROOT}" == "/" -a "${CHOST}" == "${CCHOST}" ] ; then + # we dont want to lose the current specs setting! + gcc-config --use-portage-chost ${CCHOST}-${MY_PV_FULL}${use_specs} + fi } |