/[gentoo-x86]/eclass/flag-o-matic.eclass
Gentoo

Diff of /eclass/flag-o-matic.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.40 Revision 1.89
1# Copyright 1999-2003 Gentoo Technologies, Inc. 1# Copyright 1999-2005 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/flag-o-matic.eclass,v 1.40 2004/03/12 11:21:15 vapier Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/flag-o-matic.eclass,v 1.89 2005/07/06 20:23:20 agriffis Exp $
4#
5# Author Bart Verwilst <verwilst@gentoo.org>
6 4
7ECLASS=flag-o-matic 5
8INHERITED="$INHERITED $ECLASS" 6# need access to emktemp()
7inherit eutils toolchain-funcs multilib
9 8
10# 9#
11#### filter-flags <flags> #### 10#### filter-flags <flags> ####
12# Remove particular flags from C[XX]FLAGS 11# Remove particular flags from C[XX]FLAGS
13# Matches only complete flags 12# Matches only complete flags
16# Add extra flags to your current C[XX]FLAGS 15# Add extra flags to your current C[XX]FLAGS
17# 16#
18#### replace-flags <orig.flag> <new.flag> ### 17#### replace-flags <orig.flag> <new.flag> ###
19# Replace a flag by another one 18# Replace a flag by another one
20# 19#
21#### replace-cpu-flags <new.cpu> <old.cpus> ### 20#### replace-cpu-flags <old.cpus> <new.cpu> ###
22# Replace march/mcpu flags that specify <old.cpus> 21# Replace march/mcpu flags that specify <old.cpus>
23# with flags that specify <new.cpu> 22# with flags that specify <new.cpu>
24# 23#
25#### is-flag <flag> #### 24#### is-flag <flag> ####
26# Returns "true" if flag is set in C[XX]FLAGS 25# Returns "true" if flag is set in C[XX]FLAGS
47# will leave the user with -mfpmath=386 46# will leave the user with -mfpmath=386
48# 47#
49#### append-ldflags #### 48#### append-ldflags ####
50# Add extra flags to your current LDFLAGS 49# Add extra flags to your current LDFLAGS
51# 50#
52#### etexec-flags #### 51#### filter-ldflags <flags> ####
53# hooked function for hardened-gcc that appends 52# Remove particular flags from LDFLAGS
54# -yet_exec {C,CXX,LD}FLAGS when hardened-gcc is installed 53# Matches only complete flags
55# and a package is filtering -fPIC,-fpic, -fPIE, -fpie
56# 54#
57#### fstack-flags #### 55#### fstack-flags ####
58# hooked function for hardened-gcc that appends 56# hooked function for hardened gcc that appends
59# -yno_propolice to {C,CXX,LD}FLAGS when hardened-gcc is installed 57# -fno-stack-protector to {C,CXX,LD}FLAGS
60# and a package is filtering -fstack-protector, -fstack-protector-all 58# when a package is filtering -fstack-protector, -fstack-protector-all
59# notice: modern automatic specs files will also suppress -fstack-protector-all
60# when only -fno-stack-protector is given
61#
62#### has_pic ####
63# Returns true if the compiler by default or with current CFLAGS
64# builds position-independent code.
65#
66#### has_ssp_all ####
67# Returns true if the compiler by default or with current CFLAGS
68# generates stack smash protections for all functions
69#
70#### has_ssp ####
71# Returns true if the compiler by default or with current CFLAGS
72# generates stack smash protections for most vulnerable functions
61# 73#
62 74
63# C[XX]FLAGS that we allow in strip-flags 75# C[XX]FLAGS that we allow in strip-flags
64setup-allowed-flags() { 76setup-allowed-flags() {
65 export ALLOWED_FLAGS="-O -O1 -O2 -mcpu -march -mtune -fstack-protector -pipe -g" 77 if [[ -z ${ALLOWED_FLAGS} ]] ; then
66 case "${ARCH}" in 78 export ALLOWED_FLAGS="-pipe"
67 mips) ALLOWED_FLAGS="${ALLOWED_FLAGS} -mips1 -mips2 -mips3 -mips4 -mabi" ;; 79 export ALLOWED_FLAGS="${ALLOWED_FLAGS} -O -O0 -O1 -O2 -mcpu -march -mtune"
68 amd64) ALLOWED_FLAGS="${ALLOWED_FLAGS} -fPIC" ;; 80 export ALLOWED_FLAGS="${ALLOWED_FLAGS} -fstack-protector -fstack-protector-all"
69 alpha) ALLOWED_FLAGS="${ALLOWED_FLAGS} -fPIC" ;; 81 export ALLOWED_FLAGS="${ALLOWED_FLAGS} -fbounds-checking -fno-bounds-checking"
70 ia64) ALLOWED_FLAGS="${ALLOWED_FLAGS} -fPIC" ;; 82 export ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-pie -fno-unit-at-a-time"
71 esac 83 export ALLOWED_FLAGS="${ALLOWED_FLAGS} -g -g0 -g1 -g2 -g3 -ggdb -ggdb0 -ggdb1 -ggdb2 -ggdb3"
84 fi
85 # allow a bunch of flags that negate features / control ABI
86 ALLOWED_FLAGS="${ALLOWED_FLAGS} -fno-stack-protector -fno-stack-protector-all"
87 ALLOWED_FLAGS="${ALLOWED_FLAGS} -mregparm -mno-app-regs -mapp-regs \
88 -mno-mmx -mno-sse -mno-sse2 -mno-sse3 -mno-3dnow \
89 -mips1 -mips2 -mips3 -mips4 -mips32 -mips64 -mips16 \
90 -msoft-float -mno-soft-float -mhard-float -mno-hard-float -mfpu \
91 -mflat -mno-flat -mno-faster-structs -mfaster-structs \
92 -m32 -m64 -mabi -mlittle-endian -mbig-endian -EL -EB -fPIC \
93 -mlive-g0 -mcmodel -mstack-bias -mno-stack-bias"
72 94
73 # C[XX]FLAGS that we are think is ok, but needs testing 95 # C[XX]FLAGS that we are think is ok, but needs testing
74 # NOTE: currently -Os have issues with gcc3 and K6* arch's 96 # NOTE: currently -Os have issues with gcc3 and K6* arch's
75 export UNSTABLE_FLAGS="-Os -O3 -freorder-blocks -fprefetch-loop-arrays" 97 export UNSTABLE_FLAGS="-Os -O3 -freorder-blocks -fprefetch-loop-arrays"
76 return 0 98 return 0
77} 99}
78 100
79filter-flags() { 101filter-flags() {
102 local x f fset
103 declare -a new_CFLAGS new_CXXFLAGS
104
80 for x in "$@" ; do 105 for x in "$@" ; do
81 case "${x}" in 106 case "${x}" in
82 -fPIC|-fpic|-fPIE|-fpie|-pie) etexec-flags;; 107 -fPIC|-fpic|-fPIE|-fpie|-pie)
108 append-flags `test_flag -fno-pie`;;
83 -fstack-protector|-fstack-protector-all) fstack-flags;; 109 -fstack-protector|-fstack-protector-all)
84 *) ;; 110 fstack-flags;;
85 esac 111 esac
86 done 112 done
87 113
88 # we do this fancy spacing stuff so as to not filter 114 for fset in CFLAGS CXXFLAGS; do
89 # out part of a flag ... we want flag atoms ! :D 115 # Looping over the flags instead of using a global
90 CFLAGS=" ${CFLAGS} " 116 # substitution ensures that we're working with flag atoms.
91 CXXFLAGS=" ${CXXFLAGS} " 117 # Otherwise globs like -O* have the potential to wipe out the
118 # list of flags.
119 for f in ${!fset}; do
92 for x in "$@" ; do 120 for x in "$@"; do
93 CFLAGS="${CFLAGS// ${x} / }" 121 # Note this should work with globs like -O*
94 CXXFLAGS="${CXXFLAGS// ${x} / }" 122 [[ ${f} == ${x} ]] && continue 2
123 done
124 eval new_${fset}\[\${\#new_${fset}\[@]}]=\${f}
95 done 125 done
96 CFLAGS="${CFLAGS:1:${#CFLAGS}-2}" 126 eval export ${fset}=\${new_${fset}\[*]}
97 CXXFLAGS="${CXXFLAGS:1:${#CXXFLAGS}-2}" 127 done
128
98 return 0 129 return 0
99} 130}
100 131
101filter-lfs-flags() { 132filter-lfs-flags() {
102 filter-flags -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE 133 filter-flags -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE
103} 134}
104 135
136append-lfs-flags() {
137 append-flags -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE
138}
139
105append-flags() { 140append-flags() {
141 [[ -z $* ]] && return 0
106 export CFLAGS="${CFLAGS} $@" 142 export CFLAGS="${CFLAGS} $*"
107 export CXXFLAGS="${CXXFLAGS} $@" 143 export CXXFLAGS="${CXXFLAGS} $*"
108 [ "`is-flag -fno-stack-protector`" -o "`is-flag -fno-stack-protector-all`" ] && fstack-flags 144 [ -n "`is-flag -fno-stack-protector`" -o \
145 -n "`is-flag -fno-stack-protector-all`" ] && fstack-flags
109 return 0 146 return 0
110} 147}
111 148
112replace-flags() { 149replace-flags() {
113 # we do this fancy spacing stuff so as to not filter 150 local f fset
114 # out part of a flag ... we want flag atoms ! :D 151 declare -a new_CFLAGS new_CXXFLAGS
115 CFLAGS=" ${CFLAGS} " 152
116 CXXFLAGS=" ${CXXFLAGS} " 153 for fset in CFLAGS CXXFLAGS; do
117 CFLAGS="${CFLAGS// ${1} / ${2} }" 154 # Looping over the flags instead of using a global
118 CXXFLAGS="${CXXFLAGS// ${1} / ${2} }" 155 # substitution ensures that we're working with flag atoms.
119 CFLAGS="${CFLAGS:1:${#CFLAGS}-2}" 156 # Otherwise globs like -O* have the potential to wipe out the
120 CXXFLAGS="${CXXFLAGS:1:${#CXXFLAGS}-2}" 157 # list of flags.
158 for f in ${!fset}; do
159 # Note this should work with globs like -O*
160 [[ ${f} == ${1} ]] && f=${2}
161 eval new_${fset}\[\${\#new_${fset}\[@]}]=\${f}
162 done
163 eval export ${fset}=\${new_${fset}\[*]}
164 done
165
121 return 0 166 return 0
122} 167}
123 168
124replace-cpu-flags() { 169replace-cpu-flags() {
125 local newcpu="$1" ; shift 170 local newcpu="$#" ; newcpu="${!newcpu}"
126 local oldcpu="" 171 while [ $# -gt 1 ] ; do
127 for oldcpu in "$@" ; do 172 # quote to make sure that no globbing is done (particularly on
173 # ${oldcpu} prior to calling replace-flags
128 replace-flags -march=${oldcpu} -march=${newcpu} 174 replace-flags "-march=${1}" "-march=${newcpu}"
129 replace-flags -mcpu=${oldcpu} -mcpu=${newcpu} 175 replace-flags "-mcpu=${1}" "-mcpu=${newcpu}"
130 replace-flags -mtune=${oldcpu} -mtune=${newcpu} 176 replace-flags "-mtune=${1}" "-mtune=${newcpu}"
177 shift
131 done 178 done
132 return 0 179 return 0
133} 180}
134 181
135is-flag() { 182is-flag() {
183 local x
184
136 for x in ${CFLAGS} ${CXXFLAGS} ; do 185 for x in ${CFLAGS} ${CXXFLAGS} ; do
186 # Note this should work with globs like -mcpu=ultrasparc*
137 if [ "${x}" == "$1" ] ; then 187 if [[ ${x} == ${1} ]]; then
138 echo true 188 echo true
139 return 0 189 return 0
140 fi 190 fi
141 done 191 done
142 return 1 192 return 1
143} 193}
144 194
145filter-mfpmath() { 195filter-mfpmath() {
196 local orig_mfpmath new_math prune_math
197
146 # save the original -mfpmath flag 198 # save the original -mfpmath flag
147 local orig_mfpmath="`get-flag -mfpmath`" 199 orig_mfpmath="`get-flag -mfpmath`"
148 # get the value of the current -mfpmath flag 200 # get the value of the current -mfpmath flag
149 local new_math=" `get-flag mfpmath | tr , ' '` " 201 new_math=" `get-flag mfpmath | tr , ' '` "
150 # figure out which math values are to be removed 202 # figure out which math values are to be removed
151 local prune_math="" 203 prune_math=""
152 for prune_math in "$@" ; do 204 for prune_math in "$@" ; do
153 new_math="${new_math/ ${prune_math} / }" 205 new_math="${new_math/ ${prune_math} / }"
154 done 206 done
155 new_math="`echo ${new_math:1:${#new_math}-2} | tr ' ' ,`" 207 new_math="`echo ${new_math:1:${#new_math}-2} | tr ' ' ,`"
156 208
165 fi 217 fi
166 return 0 218 return 0
167} 219}
168 220
169strip-flags() { 221strip-flags() {
222 local x y flag NEW_CFLAGS NEW_CXXFLAGS
223
170 setup-allowed-flags 224 setup-allowed-flags
171 225
172 local NEW_CFLAGS="" 226 local NEW_CFLAGS=""
173 local NEW_CXXFLAGS="" 227 local NEW_CXXFLAGS=""
174 228
175 # Allow unstable C[XX]FLAGS if we are using unstable profile ... 229 # Allow unstable C[XX]FLAGS if we are using unstable profile ...
176 if [ `has ~${ARCH} ${ACCEPT_KEYWORDS}` ] ; then 230 if has ~$(tc-arch) ${ACCEPT_KEYWORDS} ; then
177 [ `use debug` ] && einfo "Enabling the use of some unstable flags"
178 ALLOWED_FLAGS="${ALLOWED_FLAGS} ${UNSTABLE_FLAGS}" 231 ALLOWED_FLAGS="${ALLOWED_FLAGS} ${UNSTABLE_FLAGS}"
179 fi 232 fi
180 233
181 set -f 234 set -f # disable pathname expansion
182 235
183 for x in ${CFLAGS} 236 for x in ${CFLAGS}; do
184 do
185 for y in ${ALLOWED_FLAGS} 237 for y in ${ALLOWED_FLAGS}; do
186 do
187 flag=${x%%=*} 238 flag=${x%%=*}
188 if [ "${flag%%${y}}" = "" ] 239 if [ "${flag%%${y}}" = "" ] ; then
189 then
190 NEW_CFLAGS="${NEW_CFLAGS} ${x}" 240 NEW_CFLAGS="${NEW_CFLAGS} ${x}"
191 break 241 break
192 fi 242 fi
193 done 243 done
194 done 244 done
195 245
196 for x in ${CXXFLAGS} 246 for x in ${CXXFLAGS}; do
197 do
198 for y in ${ALLOWED_FLAGS} 247 for y in ${ALLOWED_FLAGS}; do
199 do
200 flag=${x%%=*} 248 flag=${x%%=*}
201 if [ "${flag%%${y}}" = "" ] 249 if [ "${flag%%${y}}" = "" ] ; then
202 then
203 NEW_CXXFLAGS="${NEW_CXXFLAGS} ${x}" 250 NEW_CXXFLAGS="${NEW_CXXFLAGS} ${x}"
204 break 251 break
205 fi 252 fi
206 done 253 done
207 done 254 done
212 fi 259 fi
213 if [ "${CXXFLAGS/-O}" != "${CXXFLAGS}" -a "${NEW_CXXFLAGS/-O}" = "${NEW_CXXFLAGS}" ]; then 260 if [ "${CXXFLAGS/-O}" != "${CXXFLAGS}" -a "${NEW_CXXFLAGS/-O}" = "${NEW_CXXFLAGS}" ]; then
214 NEW_CXXFLAGS="${NEW_CXXFLAGS} -O2" 261 NEW_CXXFLAGS="${NEW_CXXFLAGS} -O2"
215 fi 262 fi
216 263
217 set +f 264 set +f # re-enable pathname expansion
218
219 [ `use debug` ] \
220 && einfo "CFLAGS=\"${NEW_CFLAGS}\"" \
221 && einfo "CXXFLAGS=\"${NEW_CXXFLAGS}\""
222 265
223 export CFLAGS="${NEW_CFLAGS}" 266 export CFLAGS="${NEW_CFLAGS}"
224 export CXXFLAGS="${NEW_CXXFLAGS}" 267 export CXXFLAGS="${NEW_CXXFLAGS}"
225 return 0 268 return 0
226} 269}
227 270
228test_flag() { 271test_flag() {
229 if gcc -S -xc "$@" -o /dev/null /dev/null >/dev/null 2>&1; then 272 if $(tc-getCC) -S -xc "$@" -o "$(emktemp)" /dev/null &>/dev/null; then
230 echo "$@" 273 printf "%s\n" "$*"
231 return 0 274 return 0
232 fi 275 fi
233 return 1 276 return 1
234} 277}
235 278
279test_version_info() {
280 if [[ $($(tc-getCC) --version 2>&1) == *$1* ]]; then
281 return 0
282 else
283 return 1
284 fi
285}
286
236strip-unsupported-flags() { 287strip-unsupported-flags() {
288 local NEW_CFLAGS NEW_CXXFLAGS
289
237 for x in ${CFLAGS} ; do 290 for x in ${CFLAGS} ; do
238 NEW_CFLAGS=${NEW_CFLAGS}" ""`test_flag ${x}`" 291 NEW_CFLAGS="${NEW_CFLAGS} `test_flag ${x}`"
239 done 292 done
240 for x in ${CXXFLAGS} ; do 293 for x in ${CXXFLAGS} ; do
241 NEW_CXXFLAGS=${NEW_CXXFLAGS}" ""`test_flag ${x}`" 294 NEW_CXXFLAGS="${NEW_CXXFLAGS} `test_flag ${x}`"
242 done 295 done
243 296
244 export CFLAGS="${NEW_CFLAGS}" 297 export CFLAGS="${NEW_CFLAGS}"
245 export CXXFLAGS="${NEW_CXXFLAGS}" 298 export CXXFLAGS="${NEW_CXXFLAGS}"
246} 299}
247 300
248get-flag() { 301get-flag() {
302 local f findflag="$1"
303
249 # this code looks a little flaky but seems to work for 304 # this code looks a little flaky but seems to work for
250 # everything we want ... 305 # everything we want ...
251 # for example, if CFLAGS="-march=i686": 306 # for example, if CFLAGS="-march=i686":
252 # `get-flags -march` == "-march=i686" 307 # `get-flag -march` == "-march=i686"
253 # `get-flags march` == "i686" 308 # `get-flag march` == "i686"
254 local findflag="$1"
255 for f in ${CFLAGS} ${CXXFLAGS} ; do 309 for f in ${CFLAGS} ${CXXFLAGS} ; do
256 if [ "${f/${findflag}}" != "${f}" ] ; then 310 if [ "${f/${findflag}}" != "${f}" ] ; then
257 echo "${f/-${findflag}=}" 311 printf "%s\n" "${f/-${findflag}=}"
258 return 0 312 return 0
259 fi 313 fi
260 done 314 done
261 return 1 315 return 1
262} 316}
263 317
318has_hardened() {
319 test_version_info Hardened && return 0
320 # the specs file wont exist unless gcc has GCC_SPECS support
321 [ -f "${GCC_SPECS}" -a "${GCC_SPECS}" != "${GCC_SPECS/hardened/}" ] && \
322 return 0
323 return 1
324}
325
326# indicate whether PIC is set
327has_pic() {
328 [ "${CFLAGS/-fPIC}" != "${CFLAGS}" ] && return 0
329 [ "${CFLAGS/-fpic}" != "${CFLAGS}" ] && return 0
330 [ "$(echo | $(tc-getCC) ${CFLAGS} -E -dM - | grep __PIC__)" ] && return 0
331 return 1
332}
333
334# indicate whether PIE is set
335has_pie() {
336 [ "${CFLAGS/-fPIE}" != "${CFLAGS}" ] && return 0
337 [ "${CFLAGS/-fpie}" != "${CFLAGS}" ] && return 0
338 [ "$(echo | $(tc-getCC) ${CFLAGS} -E -dM - | grep __PIE__)" ] && return 0
339 # test PIC while waiting for specs to be updated to generate __PIE__
340 [ "$(echo | $(tc-getCC) ${CFLAGS} -E -dM - | grep __PIC__)" ] && return 0
341 return 1
342}
343
344# indicate whether code for SSP is being generated for all functions
345has_ssp_all() {
346 # note; this matches only -fstack-protector-all
347 [ "${CFLAGS/-fstack-protector-all}" != "${CFLAGS}" ] && return 0
348 [ "$(echo | $(tc-getCC) ${CFLAGS} -E -dM - | grep __SSP_ALL__)" ] && return 0
349 return 1
350}
351
352# indicate whether code for SSP is being generated
353has_ssp() {
354 # note; this matches both -fstack-protector and -fstack-protector-all
355 [ "${CFLAGS/-fstack-protector}" != "${CFLAGS}" ] && return 0
356 [ "$(echo | $(tc-getCC) ${CFLAGS} -E -dM - | grep __SSP__)" ] && return 0
357 return 1
358}
359
360has_m64() {
361 # this doesnt test if the flag is accepted, it tests if the flag
362 # actually -WORKS-. non-multilib gcc will take both -m32 and -m64!
363 # please dont replace this function with test_flag in some future
364 # clean-up!
365 local temp="$(emktemp)"
366 echo "int main() { return(0); }" > ${temp}.c
367 MY_CC=$(tc-getCC)
368 ${MY_CC/ .*/} -m64 -o "$(emktemp)" ${temp}.c > /dev/null 2>&1
369 local ret=$?
370 rm -f ${temp}.c
371 [ "$ret" != "1" ] && return 0
372 return 1
373}
374
375has_m32() {
376 # this doesnt test if the flag is accepted, it tests if the flag
377 # actually -WORKS-. non-multilib gcc will take both -m32 and -m64!
378 # please dont replace this function with test_flag in some future
379 # clean-up!
380
381 [ "$(tc-arch)" = "amd64" ] && has_multilib_profile && return 0
382
383 local temp="$(emktemp)"
384 echo "int main() { return(0); }" > ${temp}.c
385 MY_CC=$(tc-getCC)
386 ${MY_CC/ .*/} -m32 -o "$(emktemp)" ${temp}.c > /dev/null 2>&1
387 local ret=$?
388 rm -f ${temp}.c
389 [ "$ret" != "1" ] && return 0
390 return 1
391}
392
264replace-sparc64-flags() { 393replace-sparc64-flags() {
265 local SPARC64_CPUS="ultrasparc v9" 394 local SPARC64_CPUS="ultrasparc v9"
266 395
267 if [ "${CFLAGS/mtune}" != "${CFLAGS}" ] 396 if [ "${CFLAGS/mtune}" != "${CFLAGS}" ]; then
268 then
269 for x in ${SPARC64_CPUS} 397 for x in ${SPARC64_CPUS}; do
270 do
271 CFLAGS="${CFLAGS/-mcpu=${x}/-mcpu=v8}" 398 CFLAGS="${CFLAGS/-mcpu=${x}/-mcpu=v8}"
272 done 399 done
273 else 400 else
274 for x in ${SPARC64_CPUS} 401 for x in ${SPARC64_CPUS}; do
275 do
276 CFLAGS="${CFLAGS/-mcpu=${x}/-mcpu=v8 -mtune=${x}}" 402 CFLAGS="${CFLAGS/-mcpu=${x}/-mcpu=v8 -mtune=${x}}"
277 done 403 done
278 fi 404 fi
279 405
280 if [ "${CXXFLAGS/mtune}" != "${CXXFLAGS}" ] 406 if [ "${CXXFLAGS/mtune}" != "${CXXFLAGS}" ]; then
281 then
282 for x in ${SPARC64_CPUS} 407 for x in ${SPARC64_CPUS}; do
283 do
284 CXXFLAGS="${CXXFLAGS/-mcpu=${x}/-mcpu=v8}" 408 CXXFLAGS="${CXXFLAGS/-mcpu=${x}/-mcpu=v8}"
285 done 409 done
286 else 410 else
287 for x in ${SPARC64_CPUS} 411 for x in ${SPARC64_CPUS}; do
288 do
289 CXXFLAGS="${CXXFLAGS/-mcpu=${x}/-mcpu=v8 -mtune=${x}}" 412 CXXFLAGS="${CXXFLAGS/-mcpu=${x}/-mcpu=v8 -mtune=${x}}"
290 done 413 done
291 fi 414 fi
415
416 export CFLAGS CXXFLAGS
292} 417}
293 418
294append-ldflags() { 419append-ldflags() {
420 export LDFLAGS="${LDFLAGS} $*"
421 return 0
422}
423
424filter-ldflags() {
425 local x
426
427 # we do this fancy spacing stuff so as to not filter
428 # out part of a flag ... we want flag atoms ! :D
295 LDFLAGS="${LDFLAGS} $@" 429 LDFLAGS=" ${LDFLAGS} "
430 for x in "$@" ; do
431 LDFLAGS=${LDFLAGS// ${x} / }
432 done
433 [[ -z ${LDFLAGS// } ]] \
434 && LDFLAGS="" \
435 || LDFLAGS=${LDFLAGS:1:${#LDFLAGS}-2}
436 export LDFLAGS
296 return 0 437 return 0
297}
298
299etexec-flags() {
300 has_version sys-devel/hardened-gcc
301 if [ $? == 0 ] ; then
302 if [ "`is-flag -yet_exec`" != "true" ]; then
303 debug-print ">>> appending flags -yet_exec"
304 append-flags -yet_exec
305 append-ldflags -yet_exec
306 fi
307 fi
308} 438}
309 439
310fstack-flags() { 440fstack-flags() {
311 has_version sys-devel/hardened-gcc 441 if has_ssp; then
312 if [ $? == 0 ] ; then 442 [ -z "`is-flag -fno-stack-protector`" ] &&
313 if [ "`is-flag -yno_propolice`" != "true" ]; then 443 export CFLAGS="${CFLAGS} `test_flag -fno-stack-protector`"
314 debug-print ">>> appending flags -yno_propolice"
315 append-flags -yno_propolice
316 append-ldflags -yno_propolice
317 fi 444 fi
318 fi 445 return 0
319} 446}
447
448# This is thanks to great work from Paul de Vrieze <gentoo-user@devrieze.net>,
449# bug #9016. Also thanks to Jukka Salmi <salmi@gmx.net> (bug #13907) for more
450# fixes.
451#
452# Export CFLAGS and CXXFLAGS that are compadible with gcc-2.95.3
453gcc2-flags() {
454 if [[ $(tc-arch) == "x86" || $(tc-arch) == "amd64" ]] ; then
455 CFLAGS=${CFLAGS//-mtune=/-mcpu=}
456 CXXFLAGS=${CXXFLAGS//-mtune=/-mcpu=}
457 fi
458
459 replace-cpu-flags k6-{2,3} k6
460 replace-cpu-flags athlon{,-{tbird,4,xp,mp}} i686
461
462 replace-cpu-flags pentium-mmx i586
463 replace-cpu-flags pentium{2,3,4} i686
464
465 replace-cpu-flags ev6{7,8} ev6
466
467 export CFLAGS CXXFLAGS
468}

Legend:
Removed from v.1.40  
changed lines
  Added in v.1.89

  ViewVC Help
Powered by ViewVC 1.1.20