summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTravis Tilley <lv@gentoo.org>2004-05-20 08:39:50 +0000
committerTravis Tilley <lv@gentoo.org>2004-05-20 08:39:50 +0000
commit01ae2d66a0afb01829dfc0c7fd1a7004c9fb43eb (patch)
treeb7e580f43b63d38af2da1060bd31c77396e07dae
parentmark stable, security fix (diff)
downloadhistorical-01ae2d66a0afb01829dfc0c7fd1a7004c9fb43eb.tar.gz
historical-01ae2d66a0afb01829dfc0c7fd1a7004c9fb43eb.tar.bz2
historical-01ae2d66a0afb01829dfc0c7fd1a7004c9fb43eb.zip
my bad... 3.4.0-r3 was horribly broken, so i am doing a revision bump to encourage all users who installed this version to upgrade. i have also removed backwards compatibility support because it was horribly broken on a few archs other than x86 and amd64. please keep gcc 3.3.x or 3.2.x around if you need the older libstdc++ for running binary-only c++ apps.
-rw-r--r--sys-devel/gcc/ChangeLog12
-rw-r--r--sys-devel/gcc/Manifest6
-rw-r--r--sys-devel/gcc/files/digest-gcc-3.4.0-r4 (renamed from sys-devel/gcc/files/digest-gcc-3.4.0-r3)0
-rw-r--r--sys-devel/gcc/gcc-3.4.0-r4.ebuild (renamed from sys-devel/gcc/gcc-3.4.0-r3.ebuild)67
4 files changed, 31 insertions, 54 deletions
diff --git a/sys-devel/gcc/ChangeLog b/sys-devel/gcc/ChangeLog
index b8a80c56c9ec..d54a8ec77d76 100644
--- a/sys-devel/gcc/ChangeLog
+++ b/sys-devel/gcc/ChangeLog
@@ -1,6 +1,16 @@
# ChangeLog for sys-devel/gcc
# Copyright 2002-2004 Gentoo Technologies, Inc.; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/sys-devel/gcc/ChangeLog,v 1.246 2004/05/19 13:13:42 lv Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/gcc/ChangeLog,v 1.247 2004/05/20 08:39:50 lv Exp $
+
+*gcc-3.4.0-r4 (21 May 2004)
+
+ 21 May 2004; Travis Tilley <lv@gentoo.org> -gcc-3.4.0-r3.ebuild,
+ +gcc-3.4.0-r4.ebuild:
+ 3.4.0-r3 was horribly broken, so i am doing a revision bump to encourage all
+ users who installed this version to upgrade. i have also removed backwards
+ compatibility support because it was horribly broken on a few archs other than
+ x86 and amd64. please keep gcc 3.3.x or 3.2.x around if you need the older
+ libstdc++ for running binary-only c++ apps.
*gcc-3.4.0-r3 (20 May 2004)
diff --git a/sys-devel/gcc/Manifest b/sys-devel/gcc/Manifest
index ed34e31795fc..a8365085748c 100644
--- a/sys-devel/gcc/Manifest
+++ b/sys-devel/gcc/Manifest
@@ -11,6 +11,7 @@ MD5 42871c605b839610632d237b41e38866 gcc-3.3.2-r5.ebuild 21460
MD5 7eb36ba5811423e02b4ae4c11d8869c5 gcc-3.3.3_pre20040215.ebuild 22195
MD5 d8d35a54609911a201727872dc3ffe26 gcc-3.3.3_pre20040322.ebuild 22621
MD5 b2c168723aee82080bc1ee741848ef40 gcc-3.3.3-r4.ebuild 25550
+MD5 edec243f40d2c27d1a4c07a9a7e5a209 gcc-3.4.0-r4.ebuild 27245
MD5 1aabd842d43a507ea8d2e988f6f88707 gcc-3.3.2-r7.ebuild 21865
MD5 ca6cec20814fc6a27d5b1394ef02c867 gcc-3.2.1-r7.ebuild 14773
MD5 2091041850f831fdef34656fc3308604 gcc-3.3.2-r2.ebuild 18118
@@ -22,10 +23,9 @@ MD5 14cf69f1206d85356781dd2ad63eb7ca gcc-3.3.2-r4.ebuild 20741
MD5 8c9407ec40e58c4ebeabe5ee6e93a52a gcc-3.2.2.ebuild 16096
MD5 c7e55fc7f4bfd637f45786c0c5fbb365 gcc-2.95.3-r8.ebuild 9095
MD5 b5f1d4d71ad38c5c5e489466ac0ad399 gcc-3.3.3-r3.ebuild 24690
-MD5 5b17022fb2ef0a58b805a8f56103e26b gcc-3.4.0-r3.ebuild 28651
MD5 9fb6a5505f97c736a3f40f84ea9c71da gcc-3.3.2-r6.ebuild 21217
MD5 e6ead3ed008a1fe7adc73ddae996ade3 gcc-3.3.2-r1.ebuild 17965
-MD5 acffea20a38eb40fd2952700f53cdc90 ChangeLog 51309
+MD5 6badef3ef1aabff99503803d459cbb40 ChangeLog 51790
MD5 f00b83c775e21267dcfc5c57412dc961 gcc-3.3.2.ebuild 17908
MD5 3b2fd4637666e71aae9954782cd23016 gcc-3.3.3_pre20040426.ebuild 22633
MD5 567094e03359ffc1c95af7356395228d metadata.xml 162
@@ -50,7 +50,7 @@ MD5 e58b6c1f3122b79a5d0d273acc3c008c files/digest-gcc-3.3.2-r7 361
MD5 5a9db19cd5ad6ad16b0f838d525d842a files/digest-gcc-3.3.3-r3 522
MD5 d476dba058ac32b251723e136c6dfa8e files/digest-gcc-3.3.3-r4 526
MD5 3a68d40d170427ffbfcf181b5099d693 files/digest-gcc-3.3.3-r5 528
-MD5 887868d00e0bee0ea5dbe9ab3ff2f491 files/digest-gcc-3.4.0-r3 367
+MD5 887868d00e0bee0ea5dbe9ab3ff2f491 files/digest-gcc-3.4.0-r4 367
MD5 ac529391146ca1021405f8ec7a4b0579 files/digest-gcc-3.3.3_pre20040130 138
MD5 9996ea8d65888808363832ea1571fe0a files/digest-gcc-3.3.3_pre20040215 138
MD5 9996ea8d65888808363832ea1571fe0a files/digest-gcc-3.3.3_pre20040322 138
diff --git a/sys-devel/gcc/files/digest-gcc-3.4.0-r3 b/sys-devel/gcc/files/digest-gcc-3.4.0-r4
index d15ab4ef7534..d15ab4ef7534 100644
--- a/sys-devel/gcc/files/digest-gcc-3.4.0-r3
+++ b/sys-devel/gcc/files/digest-gcc-3.4.0-r4
diff --git a/sys-devel/gcc/gcc-3.4.0-r3.ebuild b/sys-devel/gcc/gcc-3.4.0-r4.ebuild
index 40ca7eb25be8..6e456f80ea3a 100644
--- a/sys-devel/gcc/gcc-3.4.0-r3.ebuild
+++ b/sys-devel/gcc/gcc-3.4.0-r4.ebuild
@@ -1,6 +1,6 @@
# Copyright 1999-2004 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/sys-devel/gcc/gcc-3.4.0-r3.ebuild,v 1.2 2004/05/20 04:24:27 lv Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/gcc/gcc-3.4.0-r4.ebuild,v 1.1 2004/05/20 08:39:50 lv Exp $
IUSE="static nls bootstrap java build X multilib gcj f77 objc hardened uclibc"
@@ -122,8 +122,8 @@ HOMEPAGE="http://www.gnu.org/software/gcc/gcc.html"
LICENSE="GPL-2 LGPL-2.1"
-KEYWORDS="-*"
-#KEYWORDS="amd64 ~x86 ~ppc ~sparc ~mips ~ia64 ~ppc64 ~hppa ~alpha ~s390"
+#KEYWORDS="-*"
+KEYWORDS="amd64 ~x86 ~ppc ~sparc ~mips ~ia64 ~ppc64 ~hppa ~alpha ~s390"
# Ok, this is a hairy one again, but lets assume that we
# are not cross compiling, than we want SLOT to only contain
@@ -152,7 +152,7 @@ DEPEND="virtual/glibc
hardened? ( >=sys-libs/glibc-2.3.3_pre20040420-r1 )
( !sys-devel/hardened-gcc )
>=sys-devel/binutils-2.14.90.0.8-r1
- hardened? ( >=sys-devel/binutils-2.15.90.0.1.1-r2 )
+ !amd64? ( hardened? ( >=sys-devel/binutils-2.15.90.0.3 ) )
>=sys-devel/bison-1.875
>=sys-devel/gcc-config-1.3.1
amd64? ( multilib? ( >=app-emulation/emul-linux-x86-baselibs-1.0 ) )
@@ -170,21 +170,6 @@ RDEPEND="virtual/glibc
PDEPEND="sys-devel/gcc-config"
-gcc_compat() {
- einfo "GCC 3.4 provides a new (incompatible) version of libstdc++, so"
- einfo "binaries linked to an older libstdc++ will break if that older"
- einfo "version is uninstalled. To make sure nothing breaks, the libs"
- einfo "from your previous gcc $@ installation will be backed up and"
- einfo "included in this install."
-
- cd ${ROOT} || die "Failed to chdir to root: ${ROOT}"
- tar cvf ${WORKDIR}/gcc-libs.tar $(find ${ROOT}/${LOC}/lib/gcc-lib/${CCHOST}/$@ -type f -name '*.so*') || die "failed to create tarball"
- cd ${D} || die "failed to enter \$D: $D"
- tar -mxvf ${WORKDIR}/gcc-libs.tar || die "failed to extract tarball"
-
- export BULIB=$@
-}
-
chk_gcc_version() {
# This next bit is for updating libtool linker scripts ...
local OLD_GCC_VERSION="`gcc -dumpversion`"
@@ -296,14 +281,10 @@ update_gcc_for_libc_ssp() {
src_unpack() {
local release_version="Gentoo Linux ${PVR}"
- ewarn "GCC 3.4 support in Gentoo is still in an early experimental stage."
- ewarn "While the compiler itself appears to be pretty solid at this point,"
- ewarn "there is still a lot of software that will not compile with it. It"
- ewarn "might be a good idea to keep your older compiler installed. Do not"
- ewarn "hold gentoo accountable if GCC 3.4 wont compile your favorite piece"
- ewarn "of software, emits strange and confusing error messages, frustrates"
- ewarn "you and your porting efforts, eats your cat, humps your leg, or pees"
- ewarn "on your rug. You have been warned!"
+ ewarn "GCC 3.3 compatibility has been removed. It was always broken, and overall"
+ ewarn "a bad way to do things. I added it as a temporary fix until a real one"
+ ewarn "could be implemented, but it breaks on a number of archs."
+ ewarn "It would be a /very/ good idea to keep gcc 3.3.x or 3.2.x installed."
ewarn "NOTE: the piessp patch isnt as complete as the 3.3.3 version"
if [ -n "${PP_VER}" ] && [ "${ARCH}" != "hppa" ]
@@ -392,10 +373,16 @@ src_unpack() {
cp ${WORKDIR}/gcc/protector.c ${WORKDIR}/${P}/gcc/ || die "protector.c not found"
cp ${WORKDIR}/gcc/protector.h ${WORKDIR}/${P}/gcc/ || die "protector.h not found"
cp -R ${WORKDIR}/gcc/testsuite/* ${WORKDIR}/${P}/gcc/testsuite/ || die "testsuite not found"
+
epatch ${FILESDIR}/3.4.0/gcc-3.4.0-move-propolice-into-glibc.patch
- epatch ${WORKDIR}/protectonly.dif
- #use uclibc && epatch ${FILESDIR}/3.3.3/gcc-3.3.3-uclibc-add-ssp.patch
+ use uclibc && epatch ${FILESDIR}/3.3.3/gcc-3.3.3-uclibc-add-ssp.patch
+
+ # we apply only the needed parts of protectonly.dif
+ sed -e 's|^CRTSTUFF_CFLAGS = |CRTSTUFF_CFLAGS = -fno-stack-protector-all |' \
+ -i gcc/Makefile.in || die "Failed to update crtstuff!"
+ sed -e 's|^\(LIBGCC2_CFLAGS.*\)$|\1 -fno-stack-protector-all|' \
+ -i ${S}/gcc/Makefile.in || die "Failed to update libgcc!"
release_version="${release_version}, ssp-${PP_FVER}"
@@ -632,26 +619,6 @@ src_install() {
ln -s gcc-lib ${D}/${LOC}/lib/gcc
LIBPATH=${LIBPATH/lib\/gcc/lib\/gcc-lib}
- # Due to the fact that GCC 3.4 provides an incompatible version of
- # libstdc++, we need to provide compatibility for binary-only apps
- # which are linked against the old version. Every arch should have
- # one of these marked stable, so lets look for the newest version
- # first. We need to check for the .so instead of just the directory
- # because there may or may not be any shared objects to back up...
- # The PPC-specific gcc 3.3.3 ebuilds for some reason install directly
- # to /usr/lib/ on PPC64, so we'll have to add logic for this later. :/
- # Travis Tilley <lv@gentoo.org>
- if [ -f ${LOC}/lib/gcc-lib/${CCHOST}/3.3.3/libstdc++.so ]
- then
- gcc_compat 3.3.3
- elif [ -f ${LOC}/lib/gcc-lib/${CCHOST}/3.3.2/libstdc++.so ]
- then
- gcc_compat 3.3.2
- elif [ -f ${LOC}/lib/gcc-lib/${CCHOST}/3.2.3/libstdc++.so ]
- then
- gcc_compat 3.2.3
- fi
-
dodir /lib /usr/bin
dodir /etc/env.d/gcc
echo "PATH=\"${BINPATH}\"" > ${D}/etc/env.d/gcc/${CCHOST}-${MY_PV_FULL}
@@ -842,9 +809,9 @@ src_install() {
# having one compiler installed at a time, but since these directories
# exist outside the versioned directories, versions from gcc 3.3 and
# 3.4 will overwrite each other. not good.
- cp -pfd ${D}/${LIBPATH}/../lib64/libgcc_s* ${D}/${LIBPATH}
use multilib && \
cp -pfd ${D}/${LIBPATH}/../lib32/libgcc_s* ${D}/${LIBPATH}
+ cp -pfd ${D}/${LIBPATH}/../lib64/libgcc_s* ${D}/${LIBPATH}
fi
}