# Copyright 1999-2007 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Header: /var/cvsroot/gentoo-x86/sys-devel/gcc/gcc-3.4.4-r1.ebuild,v 1.18 2007/07/22 06:35:08 dberkholz Exp $ MAN_VER="" PATCH_VER="1.7" UCLIBC_VER="1.2" PIE_VER="8.7.8" PP_VER="1.0" HTB_VER="1.00" GCC_LIBSSP_SUPPORT="true" ETYPE="gcc-compiler" # Punt redhat patch #87631 GENTOO_PATCH_EXCLUDE="08_all_gcc34-chk.patch" # arch/libc configurations known to be stable with {PIE,SSP}-by-default SSP_STABLE="x86 sparc amd64 ppc ppc64" SSP_UCLIBC_STABLE="arm mips ppc x86" PIE_GLIBC_STABLE="x86 sparc amd64 ppc ppc64" PIE_UCLIBC_STABLE="x86 mips ppc" # arch/libc configurations known to be broken with {PIE,SSP}-by-default SSP_UNSUPPORTED="hppa" SSP_UCLIBC_UNSUPPORTED="${SSP_UNSUPPORTED}" PIE_UCLIBC_UNSUPPORTED="alpha amd64 arm hppa ia64 m68k ppc64 s390 sh sparc" PIE_GLIBC_UNSUPPORTED="hppa" # whether we should split out specs files for multiple {PIE,SSP}-by-default # and vanilla configurations. SPLIT_SPECS=${SPLIT_SPECS-true} #GENTOO_PATCH_EXCLUDE="" #PIEPATCH_EXCLUDE="" inherit toolchain eutils DESCRIPTION="The GNU Compiler Collection. Includes C/C++, java compilers, pie+ssp extensions, Haj Ten Brugge runtime bounds checking" # Stuff to test before adding ~arch KEYWORDS="-* alpha amd64 arm -hppa ~ia64 mips ppc ppc64 ~s390 sh ~sparc x86" # we need a proper glibc version for the Scrt1.o provided to the pie-ssp specs # NOTE: we SHOULD be using at least binutils 2.15.90.0.1 everywhere for proper # .eh_frame ld optimisation and symbol visibility support, but it hasnt been # well tested in gentoo on any arch other than amd64!! RDEPEND="|| ( >=sys-devel/gcc-config-1.3.12-r4 app-admin/eselect-compiler ) >=sys-libs/zlib-1.1.4 elibc_glibc? ( >=sys-libs/glibc-2.3.3_pre20040420-r1 hardened? ( >=sys-libs/glibc-2.3.3_pre20040529 ) ) !build? ( gcj? ( gtk? ( x11-libs/libXt x11-libs/libX11 x11-libs/libXtst x11-proto/xproto x11-proto/xextproto >=x11-libs/gtk+-2.2 ) >=media-libs/libart_lgpl-2.1 ) >=sys-libs/ncurses-5.2-r2 nls? ( sys-devel/gettext ) )" if [[ ${CATEGORY/cross-} != ${CATEGORY} ]]; then RDEPEND="${RDEPEND} ${CATEGORY}/binutils" fi DEPEND="${RDEPEND} >=sys-apps/texinfo-4.2-r4 >=sys-devel/bison-1.875 >=sys-devel/binutils-2.14.90.0.8-r1 amd64? ( >=sys-devel/binutils-2.15.90.0.1.1-r1 )" PDEPEND="|| ( sys-devel/gcc-config app-admin/eselect-compiler ) x86? ( !nocxx? ( !elibc_uclibc? ( !build? ( || ( sys-libs/libstdc++-v3 =sys-devel/gcc-3.3* ) ) ) ) )" src_unpack() { gcc_src_unpack # misc patches that havent made it into a patch tarball yet [[ ${CHOST} == ${CTARGET} ]] && epatch "${FILESDIR}"/gcc-spec-env.patch # nothing in the tree provides libssp.so, so nothing will ever trigger this # logic, but having the patch in the tree makes life so much easier for me # since I dont have to also have an overlay for this. want_libssp && epatch "${FILESDIR}"/3.4.3/libssp.patch # Anything useful and objc will require libffi. Seriously. Lets just force # libffi to install with USE="objc", even though it normally only installs # if you attempt to build gcj. if ! use build && use objc && ! use gcj ; then epatch "${FILESDIR}"/3.4.3/libffi-without-libgcj.patch #epatch ${FILESDIR}/3.4.3/libffi-nogcj-lib-path-fix.patch fi # Fix cross-compiling epatch "${FILESDIR}"/3.4.4/gcc-3.4.4-cross-compile.patch [[ ${CTARGET} == *-softfloat-* ]] && epatch "${FILESDIR}"/3.4.4/gcc-3.4.4-softfloat.patch # Arch stuff case $(tc-arch) in mips) # If mips, and we DON'T want multilib, then rig gcc to only use n32 OR n64 if ! is_multilib; then use n32 && epatch ${FILESDIR}/3.4.1/gcc-3.4.1-mips-n32only.patch use n64 && epatch ${FILESDIR}/3.4.1/gcc-3.4.1-mips-n64only.patch fi # Patch forward-ported from a gcc-3.0.x patch that adds -march=r10000 and # -mtune=r10000 support to gcc (Allows the compiler to generate code to # take advantage of R10k's second ALU, perform shifts, etc.. # # Needs re-porting to DFA in gcc-4.0 - Any Volunteers? :) epatch ${FILESDIR}/3.4.2/gcc-3.4.x-mips-add-march-r10k.patch # This is a very special patch -- it allows us to build semi-usable kernels # on SGI IP28 (Indigo2 Impact R10000) systems. The patch is henceforth # regarded as a kludge by upstream, and thus, it will never get accepted upstream, # but for our purposes of building a kernel, it works. # Unless you're building an IP28 kernel, you really don't need care about what # this patch does, because if you are, you are probably already aware of what # it does. # All that said, the abilities of this patch are disabled by default and need # to be enabled by passing -mip28-cache-barrier. Only used to build kernels, # There is the possibility it may be used for very specific userland apps too. if use ip28; then epatch ${FILESDIR}/3.4.2/gcc-3.4.2-mips-ip28_cache_barriers-v2.patch fi ;; amd64) if is_multilib ; then sed -i -e '/GLIBCXX_IS_NATIVE=/s:false:true:' libstdc++-v3/configure || die fi ;; esac }