summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNed Ludd <solar@gentoo.org>2005-02-07 17:50:24 +0000
committerNed Ludd <solar@gentoo.org>2005-02-07 17:50:24 +0000
commit57b5032f21926cfa41ff2de4a16af7db85ff561b (patch)
tree4e5f08a00de1fa610adf11ce637830f018a5643d /eclass/flag-o-matic.eclass
parentrevision bump (diff)
downloadhistorical-57b5032f21926cfa41ff2de4a16af7db85ff561b.tar.gz
historical-57b5032f21926cfa41ff2de4a16af7db85ff561b.tar.bz2
historical-57b5032f21926cfa41ff2de4a16af7db85ff561b.zip
- improved fPIC/fPIE handling now that the hardened-toolchain is alot less haskish. obsoleted etexec-flags function
Diffstat (limited to 'eclass/flag-o-matic.eclass')
-rw-r--r--eclass/flag-o-matic.eclass30
1 files changed, 6 insertions, 24 deletions
diff --git a/eclass/flag-o-matic.eclass b/eclass/flag-o-matic.eclass
index 9f8e11945c96..0cf95ff60457 100644
--- a/eclass/flag-o-matic.eclass
+++ b/eclass/flag-o-matic.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/flag-o-matic.eclass,v 1.81 2005/01/29 03:09:45 solar Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/flag-o-matic.eclass,v 1.82 2005/02/07 17:50:24 solar Exp $
#
# Author Bart Verwilst <verwilst@gentoo.org>
@@ -58,11 +58,6 @@ inherit eutils toolchain-funcs multilib
# Remove particular flags from LDFLAGS
# Matches only complete flags
#
-#### etexec-flags ####
-# hooked function for hardened gcc that appends
-# -fno-pic to {C,CXX,LD}FLAGS
-# when a package is filtering -fpic, -fPIC, -fpie, -fPIE
-#
#### fstack-flags ####
# hooked function for hardened gcc that appends
# -fno-stack-protector to {C,CXX,LD}FLAGS
@@ -108,8 +103,10 @@ filter-flags() {
for x in "$@" ; do
case "${x}" in
- -fPIC|-fpic|-fPIE|-fpie|-pie) etexec-flags;;
- -fstack-protector|-fstack-protector-all) fstack-flags;;
+ -fPIC|-fpic|-fPIE|-fpie|-pie)
+ append-flags `test_flag -fno-pie`;;
+ -fstack-protector|-fstack-protector-all)
+ fstack-flags;;
esac
done
@@ -140,6 +137,7 @@ append-lfs-flags() {
}
append-flags() {
+ [[ -z $* ]] && return 0
export CFLAGS="${CFLAGS} $*"
export CXXFLAGS="${CXXFLAGS} $*"
[ -n "`is-flag -fno-stack-protector`" -o \
@@ -430,22 +428,6 @@ filter-ldflags() {
return 0
}
-etexec-flags() {
- # if you're not using a hardened compiler you wont need this
- # PIC/no-pic kludge in the first place.
- has_hardened || return 0
- use amd64 && return 0
- use mips && return 0
-
- if has_pie || has_pic; then
- [ -z "`is-flag -fno-pic`" ] &&
- export CFLAGS="${CFLAGS} `test_flag -fno-pic`"
- [ -z "`is-flag -nopie`" ] &&
- export CFLAGS="${CFLAGS} `test_flag -nopie`"
- fi
- return 0
-}
-
fstack-flags() {
if has_ssp; then
[ -z "`is-flag -fno-stack-protector`" ] &&