diff options
author | 2004-12-12 23:35:07 +0000 | |
---|---|---|
committer | 2004-12-12 23:35:07 +0000 | |
commit | e62ee801dd095af282ae3b1dace54c10d6d53f2a (patch) | |
tree | a13802c2926969a34ef4f285fea63fc085859ab1 | |
parent | Fixed a bug in creating /usr/<CHOST32> on sparc64-multilib. (Manifest recommit) (diff) | |
download | gentoo-2-e62ee801dd095af282ae3b1dace54c10d6d53f2a.tar.gz gentoo-2-e62ee801dd095af282ae3b1dace54c10d6d53f2a.tar.bz2 gentoo-2-e62ee801dd095af282ae3b1dace54c10d6d53f2a.zip |
Version bump #68983 by Lars. Also cleanup the sed-scripts to be patches and add an arm big endian fix #74054.
-rw-r--r-- | dev-libs/openssl/ChangeLog | 12 | ||||
-rw-r--r-- | dev-libs/openssl/files/digest-openssl-0.9.7e | 2 | ||||
-rw-r--r-- | dev-libs/openssl/files/openssl-0.9.7-alpha-default-gcc.patch | 12 | ||||
-rw-r--r-- | dev-libs/openssl/files/openssl-0.9.7-arm-big-endian.patch | 22 | ||||
-rw-r--r-- | dev-libs/openssl/files/openssl-0.9.7-hppa-fix-detection.patch | 28 | ||||
-rw-r--r-- | dev-libs/openssl/files/openssl-0.9.7e-gentoo.patch | 16 | ||||
-rw-r--r-- | dev-libs/openssl/openssl-0.9.7e.ebuild | 264 |
7 files changed, 355 insertions, 1 deletions
diff --git a/dev-libs/openssl/ChangeLog b/dev-libs/openssl/ChangeLog index 5b7d9fe68f2e..0adb41cf571a 100644 --- a/dev-libs/openssl/ChangeLog +++ b/dev-libs/openssl/ChangeLog @@ -1,6 +1,16 @@ # ChangeLog for dev-libs/openssl # Copyright 2002-2004 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-libs/openssl/ChangeLog,v 1.99 2004/11/07 09:45:38 kumba Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-libs/openssl/ChangeLog,v 1.100 2004/12/12 23:35:07 vapier Exp $ + +*openssl-0.9.7e (12 Dec 2004) + + 12 Dec 2004; Mike Frysinger <vapier@gentoo.org> + +files/openssl-0.9.7-alpha-default-gcc.patch, + +files/openssl-0.9.7-arm-big-endian.patch, + +files/openssl-0.9.7-hppa-fix-detection.patch, + +files/openssl-0.9.7e-gentoo.patch, +openssl-0.9.7e.ebuild: + Version bump #68983 by Lars. Also cleanup the sed-scripts to be patches and + add an arm big endian fix #74054. 07 Nov 2004; Joshua Kinard <kumba@gentoo.org> openssl-0.9.7d-r2.ebuild: Marked stable on mips. diff --git a/dev-libs/openssl/files/digest-openssl-0.9.7e b/dev-libs/openssl/files/digest-openssl-0.9.7e new file mode 100644 index 000000000000..81d2db421e96 --- /dev/null +++ b/dev-libs/openssl/files/digest-openssl-0.9.7e @@ -0,0 +1,2 @@ +MD5 a8777164bca38d84e5eb2b1535223474 openssl-0.9.7e.tar.gz 3043231 +MD5 1b63bfdca1c37837dddde9f1623498f9 openssl-0.9.6m.tar.gz 2184918 diff --git a/dev-libs/openssl/files/openssl-0.9.7-alpha-default-gcc.patch b/dev-libs/openssl/files/openssl-0.9.7-alpha-default-gcc.patch new file mode 100644 index 000000000000..a56e76e17aaf --- /dev/null +++ b/dev-libs/openssl/files/openssl-0.9.7-alpha-default-gcc.patch @@ -0,0 +1,12 @@ +diff -ur openssl-0.9.7d.orig/config openssl-0.9.7d/config +--- openssl-0.9.7d.orig/config 2004-12-11 19:01:11.077248504 -0500 ++++ openssl-0.9.7d/config 2004-12-11 19:08:52.099162520 -0500 +@@ -452,7 +452,7 @@ + sed 's/.* C V\([0-9]\)\.\([0-9]\).*/\1\2/'` + CCCVER=${CCCVER:-0} + if [ $CCCVER -gt 60 ]; then +- CC=ccc # overrides gcc!!! well, ccc outperforms inoticeably ++ CC=gcc # overrides gcc!!! well, ccc outperforms inoticeably + # only on hash routines and des, otherwise gcc (2.95) + # keeps along rather tight... + fi diff --git a/dev-libs/openssl/files/openssl-0.9.7-arm-big-endian.patch b/dev-libs/openssl/files/openssl-0.9.7-arm-big-endian.patch new file mode 100644 index 000000000000..4d6b64c3796d --- /dev/null +++ b/dev-libs/openssl/files/openssl-0.9.7-arm-big-endian.patch @@ -0,0 +1,22 @@ +diff -ur openssl-0.9.7e.orig/Configure openssl-0.9.7e/Configure +--- openssl-0.9.7e.orig/Configure 2004-12-12 17:44:17.030893680 -0500 ++++ openssl-0.9.7e/Configure 2004-12-12 17:44:39.143532048 -0500 +@@ -423,6 +423,7 @@ + + # Linux on ARM + "linux-elf-arm","gcc:-DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", ++"linux-elf-armb","gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", + + # SCO/Caldera targets. + # +diff -ur openssl-0.9.7e.orig/config openssl-0.9.7e/config +--- openssl-0.9.7e.orig/config 2004-12-12 17:44:17.029893832 -0500 ++++ openssl-0.9.7e/config 2004-12-12 17:44:30.935779816 -0500 +@@ -593,6 +593,7 @@ + + options="$options -mschedule=$CPUSCHEDULE -march=$CPUARCH" + OUT="linux-parisc" ;; ++ arm*b*-*-linux2) OUT="linux-elf-armb" ;; + arm*-*-linux2) OUT="linux-elf-arm" ;; + s390-*-linux2) OUT="linux-s390" ;; + s390x-*-linux?) OUT="linux-s390x" ;; diff --git a/dev-libs/openssl/files/openssl-0.9.7-hppa-fix-detection.patch b/dev-libs/openssl/files/openssl-0.9.7-hppa-fix-detection.patch new file mode 100644 index 000000000000..f52a8b8ea5c8 --- /dev/null +++ b/dev-libs/openssl/files/openssl-0.9.7-hppa-fix-detection.patch @@ -0,0 +1,28 @@ +diff -ur openssl-0.9.7d.orig/Configure openssl-0.9.7d/Configure +--- openssl-0.9.7d.orig/Configure 2004-12-11 19:01:11.078248352 -0500 ++++ openssl-0.9.7d/Configure 2004-12-11 19:06:46.998180760 -0500 +@@ -315,7 +315,7 @@ + "MPE/iX-gcc", "gcc:-D_ENDIAN -DBN_DIV2W -O3 -D_POSIX_SOURCE -D_SOCKET_SOURCE -I/SYSLOG/PUB::(unknown):MPE:-L/SYSLOG/PUB -lsyslog -lsocket -lcurses:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:::", + + #### PARISC Linux setups +-"linux-parisc","gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall -DBN_DIV2W::-D_REENTRANT:::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR::", ++"linux-parisc","gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall -DBN_DIV2W::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", + + # Dec Alpha, OSF/1 - the alpha164-cc is historical, for the conversion + # from the older DEC C Compiler to the newer compiler. It's now the +diff -ur openssl-0.9.7d.orig/config openssl-0.9.7d/config +--- openssl-0.9.7d.orig/config 2004-12-11 19:01:11.077248504 -0500 ++++ openssl-0.9.7d/config 2004-12-11 19:06:55.621869760 -0500 +@@ -564,9 +564,9 @@ + sun4d) OUT="linux-sparcv8" ;; + *) OUT="linux-sparcv7" ;; + esac ;; +- parisc-*-linux2) ++ parisc*-*-linux2) +- CPUARCH=`awk '/cpu family/{print substr($5,1,3)}' /proc/cpuinfo` +- CPUSCHEDULE=`awk '/^cpu.[ ]: PA/{print substr($3,3)}' /proc/cpuinfo` ++ CPUARCH=`awk '/cpu family/{print substr($5,1,3)}' /proc/cpuinfo | head -n 1` ++ CPUSCHEDULE=`awk '/^cpu[[:space:]]*: PA/{print substr($3,3)}' /proc/cpuinfo | head -n 1` + + # ??TODO ?? Model transformations + # 0. CPU Architecture for the 1.1 processor has letter suffixes. We strip that off diff --git a/dev-libs/openssl/files/openssl-0.9.7e-gentoo.patch b/dev-libs/openssl/files/openssl-0.9.7e-gentoo.patch new file mode 100644 index 000000000000..b3753d20de97 --- /dev/null +++ b/dev-libs/openssl/files/openssl-0.9.7e-gentoo.patch @@ -0,0 +1,16 @@ +diff -r -c -C 2 openssl-0.9.6g-orig/test/Makefile openssl-0.9.6g/test/Makefile +*** openssl-0.9.6g-orig/test/Makefile Thu Sep 26 15:20:47 2002 +--- openssl-0.9.6g/test/Makefile Thu Sep 26 15:23:26 2002 +*************** +*** 28,32 **** + DLIBCRYPTO= ../libcrypto.a + DLIBSSL= ../libssl.a +! LIBCRYPTO= -L.. -lcrypto + LIBSSL= -L.. -lssl + +--- 28,32 ---- + DLIBCRYPTO= ../libcrypto.a + DLIBSSL= ../libssl.a +! LIBCRYPTO= -L.. -lcrypto -lcrypt + LIBSSL= -L.. -lssl + diff --git a/dev-libs/openssl/openssl-0.9.7e.ebuild b/dev-libs/openssl/openssl-0.9.7e.ebuild new file mode 100644 index 000000000000..b96aeebf98ec --- /dev/null +++ b/dev-libs/openssl/openssl-0.9.7e.ebuild @@ -0,0 +1,264 @@ +# Copyright 1999-2004 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/dev-libs/openssl/openssl-0.9.7e.ebuild,v 1.1 2004/12/12 23:35:07 vapier Exp $ + +inherit eutils flag-o-matic gcc + +OLD_096_P="${PN}-0.9.6m" + +DESCRIPTION="Toolkit for SSL v2/v3 and TLS v1" +HOMEPAGE="http://www.openssl.org/" +SRC_URI="mirror://openssl/source/${P}.tar.gz + mirror://openssl/source/${OLD_096_P}.tar.gz" + +LICENSE="as-is" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86" +KEYWORDS="-*" +IUSE="emacs uclibc" + +RDEPEND="virtual/libc" +DEPEND="${RDEPEND} + sys-apps/diffutils + >=dev-lang/perl-5 + >=sys-apps/sed-4 + !uclibc? ( sys-devel/bc )" + +S=${WORKDIR} + +src_unpack() { + unpack ${A} + + # openssl-0.9.7 + cd ${WORKDIR}/${P} + + epatch ${FILESDIR}/${PN}-0.9.7c-tempfile.patch + epatch ${FILESDIR}/addppc64support.diff + epatch ${FILESDIR}/${PN}-0.9.7e-gentoo.patch + epatch ${FILESDIR}/${PN}-0.9.7-arm-big-endian.patch + epatch ${FILESDIR}/${PN}-0.9.7-hppa-fix-detection.patch + epatch ${FILESDIR}/${PN}-0.9.7-alpha-default-gcc.patch + + case $(gcc-version) in + 3.2) + filter-flags -fprefetch-loop-arrays -freduce-all-givs -funroll-loop + ;; + 3.4 | 3.3 ) + filter-flags -fprefetch-loop-arrays -freduce-all-givs -funroll-loops + if [ "${ARCH}" = "ppc" -o "${ARCH}" = "ppc64" ] ; then + append-flags -fno-strict-aliasing + fi + ;; + esac + + # replace CFLAGS + OLDIFS=$IFS + IFS=$'\n' + for a in $( grep -n -e "^\"linux-" Configure ); do + LINE=$( echo $a | awk -F: '{print $1}' ) + CUR_CFLAGS=$( echo $a | awk -F: '{print $3}' ) + # for ppc64 I have to be careful given current + # toolchain issues + if [ "${ARCH}" != "ppc64" ]; then + NEW_CFLAGS="$( echo $CUR_CFLAGS | sed -r -e "s|-O[23]||" -e "s/-fomit-frame-pointer//" -e "s/-mcpu=[-a-z0-9]+//" -e "s/-m486//" ) $CFLAGS" + else + NEW_CFLAGS="$( echo $CUR_CFLAGS | sed -r -e "s|-O[23]||" -e "s/-fomit-frame-pointer//" -e "s/-mcpu=[-a-z0-9]+//" -e "s/-m486//" ) " + + fi + + sed -i "${LINE}s/$CUR_CFLAGS/$NEW_CFLAGS/" Configure \ + || die "sed failed" + done + IFS=$OLDIFS + + if [ "$(get_libdir)" != "lib" ] ; then + # using a library directory other than lib requires some magic + sed -i \ + -e "s+\(\$(INSTALL_PREFIX)\$(INSTALLTOP)\)/lib+\1/$(get_libdir)+g" \ + -e "s+libdir=\$\${exec_prefix}/lib+libdir=\$\${exec_prefix}/$(get_libdir)+g" \ + Makefile.org \ + || die "sed failed" + ./config --test-sanity || die "sanity failed" + fi + + # openssl-0.9.6 + test -f ${ROOT}/usr/lib/libssl.so.0.9.6 && { + cd ${WORKDIR}/${OLD_096_P} + + epatch ${FILESDIR}/${OLD_096_P}-gentoo.diff + + case ${ARCH} in + mips) + epatch ${FILESDIR}/openssl-0.9.6-mips.diff + ;; + arm) + # patch linker to add -ldl or things linking aginst libcrypto fail + sed -i -e \ + 's!^"linux-elf-arm"\(.*\)::BN\(.*\)!"linux-elf-arm"\1:-ldl:BN\2!' \ + Configure \ + || die "sed failed" + ;; + hppa) + # Tells to compile a static version of openssl + sed -i -e \ + 's!^"linux-parisc"\(.*\)::BN\(.*\)::!"linux-parisc"\1:-ldl:BN\2::::::::::dlfcn:linux-shared:-fPIC::.so.\\$(SHLIB_MAJOR).\\$(SHLIB_MINOR)!' \ + Configure \ + || die "sed failed" + # Fix detection of parisc running 64 bit kernel + sed -i -e 's/parisc-\*-linux2/parisc\*-\*-linux2/' config \ + || die "sed failed" + esac + + # replace CFLAGS + OLDIFS=$IFS + IFS=$'\n' + for a in $( grep -n -e "^\"linux-" Configure ); do + LINE=$( echo $a | awk -F: '{print $1}' ) + CUR_CFLAGS=$( echo $a | awk -F: '{print $3}' ) + NEW_CFLAGS="$( echo $CUR_CFLAGS | sed -r -e "s|-O[23]||" -e "s/-fomit-frame-pointer//" -e "s/-mcpu=[-a-z0-9]+//" -e "s/-m486//" ) $CFLAGS" + sed -i "${LINE}s/$CUR_CFLAGS/$NEW_CFLAGS/" Configure \ + || die "sed failed" + done + IFS=$OLDIFS + } +} + +src_compile() { + # openssl-0.9.7 + cd ${WORKDIR}/${P} + + # Build correctly for mips, mips64, & mipsel + if use mips; then + if [[ ${CHOST/mipsel} != ${CHOST} ]] ; then + mipsarch="linux-mipsel" + else + mipsarch="linux-mips" + fi + + ./Configure ${mipsarch} --prefix=/usr --openssldir=/etc/ssl \ + shared threads || die + # force sparcv8 on sparc32 profile + elif [ "$PROFILE_ARCH" = "sparc" ]; then + ./Configure linux-sparcv8 --prefix=/usr --openssldir=/etc/ssl \ + shared threads || die + else + ./config --prefix=/usr --openssldir=/etc/ssl shared threads || die + fi + + einfo "Compiling ${P}" + make all || die + + # openssl-0.9.6 + test -f ${ROOT}/usr/lib/libssl.so.0.9.6 && { + cd ${WORKDIR}/${OLD_096_P} + + # force sparcv8 on sparc32 profile + if [ "$PROFILE_ARCH" = "sparc" ]; then + SSH_TARGET="linux-sparcv8" + elif [ "`uname -m`" = "parisc" -o "`uname -m`" = "parisc64" ]; then + SSH_TARGET="linux-parisc" + elif use mips; then + if [ "`echo ${CHOST} | grep "mipsel"`" ]; then + SSH_TARGET="linux-mipsel" + else + SSH_TARGET="linux-mips" + fi + fi + + case ${CHOST} in + alphaev56*|alphaev6*) + SSH_TARGET="linux-alpha+bwx-${CC:-gcc}" + ;; + alpha*) + SSH_TARGET="linux-alpha-${CC:-gcc}" ;; + esac + + if [ ${SSH_TARGET} ]; then + einfo "Forcing ${SSH_TARGET} compile" + ./Configure ${SSH_TARGET} --prefix=/usr \ + --openssldir=/etc/ssl shared threads || die + else + ./config --prefix=/usr --openssldir=/etc/ssl shared threads || die + fi + + einfo "Compiling ${OLD_096_P}" + make all || die + } +} + +src_test() { + cd ${WORKDIR}/${P} + make test || die + + # openssl-0.9.6 + test -f ${ROOT}/usr/lib/libssl.so.0.9.6 && { + cd ${WORKDIR}/${OLD_096_P} + make all || die + } +} + +src_install() { + # openssl-0.9.7 + cd ${WORKDIR}/${P} + make INSTALL_PREFIX=${D} MANDIR=/usr/share/man install || die + dodoc CHANGES* FAQ LICENSE NEWS README + dodoc doc/*.txt + dohtml doc/* + insinto /usr/share/emacs/site-lisp + doins doc/c-indentation.el + + if use emacs ; then + insinto /usr/share/emacs/site-lisp + doins doc/c-indentation.el + fi + + # create the certs directory. Previous openssl builds + # would need to create /usr/lib/ssl/certs but this looks + # to be the more FHS compliant setup... -raker + insinto /etc/ssl/certs + doins certs/*.pem + OPENSSL=${D}/usr/bin/openssl /usr/bin/perl tools/c_rehash ${D}/etc/ssl/certs + + # The man pages rand.3 and passwd.1 conflict with other packages + # Rename them to ssl-* and also make a symlink from openssl-* to ssl-* + cd ${D}/usr/share/man/man1 + mv passwd.1 ssl-passwd.1 + ln -sf ssl-passwd.1 openssl-passwd.1 + cd ${D}/usr/share/man/man3 + mv rand.3 ssl-rand.3 + ln -sf ssl-rand.3 openssl-rand.3 + + # openssl-0.9.6 + test -f ${ROOT}/usr/lib/libssl.so.0.9.6 && { + cd ${WORKDIR}/${OLD_096_P} + make || die + dolib.so ${WORKDIR}/${OLD_096_P}/libcrypto.so.0.9.6||die "libcrypto.so.0.9.6 not found" + dolib.so ${WORKDIR}/${OLD_096_P}/libssl.so.0.9.6|| die "libssl.so.0.9.6 not found" + } + fperms a+x /usr/$(get_libdir)/pkgconfig #34088 +} + +pkg_postinst() { + local BN_H="${ROOT}$(gcc-config -L)/include/openssl/bn.h" + # Breaks things one some boxen, bug #13795. The problem is that + # if we have a 'gcc fixed' version in $(gcc-config -L) from 0.9.6, + # then breaks as it was defined as 'int BN_mod(...)' and in 0.9.7 it + # is a define with BN_div(...) - <azarah@gentoo.org> (24 Sep 2003) + if [ -f "${BN_H}" ] && [ -n "$(grep '^int[[:space:]]*BN_mod(' "${BN_H}")" ] + then + rm -f "${BN_H}" + fi + + test -f ${ROOT}/usr/lib/libssl.so.0.9.6 && { + einfo "You can now re-compile all packages that are linked against" + einfo "OpenSSL 0.9.6 by using revdep-rebuild from gentoolkit:" + einfo "# revdep-rebuild --soname libssl.so.0.9.6" + einfo "# revdep-rebuild --soname libcrypto.so.0.9.6" + einfo "After this, you can delete /usr/lib/libssl.so.0.9.6 and /usr/lib/libcrypto.so.0.9.6" + } + + + ewarn "If you do not etc-update now and update /etc/ssl/misc/der_chop to the new version, your" + ewarn "system IS VULNERABLE to a symlink attack as described in bug 68407" + ewarn "refer to http://bugs.gentoo.org/show_bug.cgi?id=68407 if you have any doubts" +} |