diff options
author | fredb <fredb> | 2002-08-04 15:47:43 +0000 |
---|---|---|
committer | fredb <fredb> | 2002-08-04 15:47:43 +0000 |
commit | 213202a3857e444d654c0b0d3179b32746a6a70f (patch) | |
tree | ee6a0575eb2345de5de1b37a57459a79ab918ccf /security/openssl/Makefile | |
parent | e4d56c730dc0fbbe914e5d0df3e9a9865d5e3e2d (diff) | |
download | pkgsrc-213202a3857e444d654c0b0d3179b32746a6a70f.tar.gz |
Update openssl to 0.9.6e. This update fixes multiple vulnerabilities,
and also changes the ABI of "libcrypto" and "libssl". (So the shared
library majors and buildlink requirements are bumped, too.) The code
base is now synced perfectly with NetBSD HEAD and netbsd-1-6 branches
as of 2002-08-04, the optimization levels are reduced to "-O2", but
I've retained some of the processor optimization flags and different code
path #defines in the "Configure" script, just to keep things interesting.
The default "certs" directory on NetBSD is now "/etc/openssl/certs", to
give continuity to those who find themselves using the package system's
"openssl" after upgrading a package that formerly used the base system's.
[Suggested by itojun.] The best way to avoid such problems, however, is
to upgrade your base system *first*.
I'm making use of the new and improved build system as much as possible.
This gives us a cleaner way to make shared libraries and real man pages,
but loses many of the symlinks to the openssl binary.
I've culled items from the "CHANGES" file that appear to have security
implications or are particularly interesting for NetBSD users, below.
My comments are marked off with '===>'.
===> This is from the netbsd-20020804-patch
*) Fix ASN1 checks. Check for overflow by comparing with LONG_MAX
and get fix the header length calculation.
[Florian Weimer <Weimer@CERT.Uni-Stuttgart.DE>,
Alon Kantor <alonk@checkpoint.com> (and others),
Steve Henson]
Changes between 0.9.6d and 0.9.6e [30 Jul 2002]
*) New option
SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS
for disabling the SSL 3.0/TLS 1.0 CBC vulnerability countermeasure
that was added in OpenSSL 0.9.6d.
As the countermeasure turned out to be incompatible with some
broken SSL implementations, the new option is part of SSL_OP_ALL.
SSL_OP_ALL is usually employed when compatibility with weird SSL
implementations is desired (e.g. '-bugs' option to 's_client' and
's_server'), so the new option is automatically set in many
applications.
[Bodo Moeller]
*) Changes in security patch:
Changes marked "(CHATS)" were sponsored by the Defense Advanced
Research Projects Agency (DARPA) and Air Force Research Laboratory,
Air Force Materiel Command, USAF, under agreement number
F30602-01-2-0537.
*) Add various sanity checks to asn1_get_length() to reject
the ASN1 length bytes if they exceed sizeof(long), will appear
negative or the content length exceeds the length of the
supplied buffer.
[Steve Henson, Adi Stav <stav@mercury.co.il>, James Yonan <jim@ntlp.com>]
*) Assertions for various potential buffer overflows, not known to
happen in practice.
[Ben Laurie (CHATS)]
*) Various temporary buffers to hold ASCII versions of integers were
too small for 64 bit platforms. (CAN-2002-0655)
[Matthew Byng-Maddick <mbm@aldigital.co.uk> and Ben Laurie (CHATS)>
*) Remote buffer overflow in SSL3 protocol - an attacker could
supply an oversized session ID to a client. (CAN-2002-0656)
[Ben Laurie (CHATS)]
*) Remote buffer overflow in SSL2 protocol - an attacker could
supply an oversized client master key. (CAN-2002-0656)
[Ben Laurie (CHATS)]
Changes between 0.9.6c and 0.9.6d [9 May 2002]
*) Implement a countermeasure against a vulnerability recently found
in CBC ciphersuites in SSL 3.0/TLS 1.0: Send an empty fragment
before application data chunks to avoid the use of known IVs
with data potentially chosen by the attacker.
[Bodo Moeller]
Changes between 0.9.6a and 0.9.6b [9 Jul 2001]
*) Change ssleay_rand_bytes (crypto/rand/md_rand.c)
to avoid a SSLeay/OpenSSL PRNG weakness pointed out by
Markku-Juhani O. Saarinen <markku-juhani.saarinen@nokia.com>:
PRNG state recovery was possible based on the output of
one PRNG request appropriately sized to gain knowledge on
'md' followed by enough consecutive 1-byte PRNG requests
to traverse all of 'state'.
1. When updating 'md_local' (the current thread's copy of 'md')
during PRNG output generation, hash all of the previous
'md_local' value, not just the half used for PRNG output.
2. Make the number of bytes from 'state' included into the hash
independent from the number of PRNG bytes requested.
The first measure alone would be sufficient to avoid
Markku-Juhani's attack. (Actually it had never occurred
to me that the half of 'md_local' used for chaining was the
half from which PRNG output bytes were taken -- I had always
assumed that the secret half would be used.) The second
measure makes sure that additional data from 'state' is never
mixed into 'md_local' in small portions; this heuristically
further strengthens the PRNG.
[Bodo Moeller]
*) The countermeasure against Bleichbacher's attack on PKCS #1 v1.5
RSA encryption was accidentally removed in s3_srvr.c in OpenSSL 0.9.5
when fixing the server behaviour for backwards-compatible 'client
hello' messages. (Note that the attack is impractical against
SSL 3.0 and TLS 1.0 anyway because length and version checking
means that the probability of guessing a valid ciphertext is
around 2^-40; see section 5 in Bleichenbacher's CRYPTO '98
paper.)
Before 0.9.5, the countermeasure (hide the error by generating a
random 'decryption result') did not work properly because
ERR_clear_error() was missing, meaning that SSL_get_error() would
detect the supposedly ignored error.
Both problems are now fixed.
[Bodo Moeller]
Changes between 0.9.6 and 0.9.6a [5 Apr 2001]
===> This is our ABI change.
*) Rename 'des_encrypt' to 'des_encrypt1'. This avoids the clashes
with des_encrypt() defined on some operating systems, like Solaris
and UnixWare.
[Richard Levitte]
*) Don't use getenv in library functions when run as setuid/setgid.
New function OPENSSL_issetugid().
[Ulf Moeller]
*) Store verify_result within SSL_SESSION also for client side to
avoid potential security hole. (Re-used sessions on the client side
always resulted in verify_result==X509_V_OK, not using the original
result of the server certificate verification.)
[Lutz Jaenicke]
===> package doesn't doesn't do this. We'll bump major versions
===> as necessary.
*) Make sure that shared libraries get the internal name engine with
the full version number and not just 0. This should mark the
shared libraries as not backward compatible. Of course, this should
be changed again when we can guarantee backward binary compatibility.
[Richard Levitte]
*) Rework the system to generate shared libraries:
- Make note of the expected extension for the shared libraries and
if there is a need for symbolic links from for example libcrypto.so.0
to libcrypto.so.0.9.7. There is extended info in Configure for
that.
- Make as few rebuilds of the shared libraries as possible.
- Still avoid linking the OpenSSL programs with the shared libraries.
- When installing, install the shared libraries separately from the
static ones.
Diffstat (limited to 'security/openssl/Makefile')
-rw-r--r-- | security/openssl/Makefile | 140 |
1 files changed, 33 insertions, 107 deletions
diff --git a/security/openssl/Makefile b/security/openssl/Makefile index fb50d11d908..70c81541212 100644 --- a/security/openssl/Makefile +++ b/security/openssl/Makefile @@ -1,7 +1,6 @@ -# $NetBSD: Makefile,v 1.52 2002/07/28 05:36:29 schmonz Exp $ +# $NetBSD: Makefile,v 1.53 2002/08/04 15:47:43 fredb Exp $ -DISTNAME= openssl-0.9.6 -PKGREVISION= 2 +DISTNAME= openssl-0.9.6e SVR4_PKGNAME= ossl CATEGORIES= security MASTER_SITES= ftp://ftp.openssl.org/source/ @@ -12,7 +11,7 @@ COMMENT= Secure Socket Layer and cryptographic library USE_PERL5= build -CONFLICTS= SSLeay-[0-9]* ssleay-[0-9]* base64-[0-9]* \ +CONFLICTS= SSLeay-[0-9]* ssleay-[0-9]* base64-[0-9]* \ glimpse-[0-9] CRYPTO= YES @@ -20,28 +19,46 @@ CRYPTO= YES # openssl supplies IDEA/RC5. IDEA/RC5 need license for commercial use. LICENCE= fee-based-commercial-use -# matches what's in `Configure' (except sparc64) -ONLY_FOR_PLATFORM= NetBSD-*-alpha NetBSD-*-arm32 NetBSD-*-i386 \ - NetBSD-*-m68k NetBSD-*-mips NetBSD-*-mipseb \ - NetBSD-*-mipsel NetBSD-*-ns32k NetBSD-*-powerpc \ - NetBSD-*-sparc NetBSD-*-vax \ - SunOS-* Linux-*-* Darwin-*-* - CONFIGURE_SCRIPT= config -CONFIGURE_ARGS= -fPIC -DPIC --openssldir=${PREFIX} --prefix=${PREFIX} \ - ${LDFLAGS} +CONFIGURE_ARGS= shared --openssldir=${PKG_SYSCONFDIR} --prefix=${PREFIX} CONFIGURE_ENV= CC="${CC}" +CONF_FILES= ${PREFIX}/share/examples/openssl/openssl.cnf \ + ${PKG_SYSCONFDIR}/openssl.cnf +PKG_SYSCONFSUBDIR= openssl +PLIST_SRC= ${WRKDIR}/.PLIST_SRC +PLIST_SUBST= PKG_SYSCONFDIR=${PKG_SYSCONFDIR} + +do-configure: + cd ${WRKSRC} \ + && ${PERL5} util/perlpath.pl ${LOCALBASE}/bin \ + && ${SETENV} ${CONFIGURE_ENV} ./${CONFIGURE_SCRIPT} \ + ${CONFIGURE_ARGS} + +post-build: + ${CAT} ${PKGDIR}/PLIST.${LOWER_OPSYS} ${PLIST_RSAREF} \ + ${PKGDIR}/PLIST.common > ${PLIST_SRC} + +test: all + @cd ${WRKSRC}/test \ + && ${SETENV} ${LD_PATH_VARNAME}=${WRKSRC} ${MAKE} tests \ + && ${ECHO} "*** Tests successful. ***" + .include "../../mk/bsd.prefs.mk" .if ${OPSYS} == "NetBSD" PATCH_SITES= ${MASTER_SITE_LOCAL} -PATCHFILES= openssl-0.9.6-20010914-netbsd.patch.gz +PATCHFILES= openssl-0.9.6e-20020804-netbsd.patch.gz +PATCH_DIST_STRIP= -p1 -MAKE_ENV= LD_LIBRARY_PATH=${WRKSRC} MAKELIB=${FILESDIR}/makelib +PKG_SYSCONFBASE= /etc .endif -PLIST_SRC= ${WRKDIR}/.PLIST_SRC +.if ${OPSYS} == "Darwin" +LD_PATH_VARNAME= DYLD_LIBRARY_PATH +.else +LD_PATH_VARNAME= LD_LIBRARY_PATH +.endif .if ${OPSYS} == "NetBSD" && !exists(/usr/libexec/ld.elf_so) && !exists(/usr/libexec/ld.so) IGNORE= ${PKGNAME} requires shared object support @@ -58,95 +75,4 @@ CONFIGURE_SCRIPT= Configure CONFIGURE_ARGS+= solaris-${SPARC_TARGET_ARCH}-${CC} .endif -# The Perl stuff doesn't work yet (nor did it work properly in SSLeay...) -do-configure: - @cd ${WRKSRC} && ${PERL5} util/perlpath.pl ${LOCALBASE}/bin - @cd ${WRKSRC} && ${SETENV} ${CONFIGURE_ENV} ./${CONFIGURE_SCRIPT} \ - ${CONFIGURE_ARGS} - -#post-build: -# @cd ${WRKSRC}/perl && ${MAKE} - -do-install: - ${INSTALL_PROGRAM} ${WRKSRC}/apps/openssl ${PREFIX}/bin - @cd ${PREFIX}/bin && \ - for file in asn1parse base64 bf bf-cbc bf-cfb bf-ecb bf-ofb ca \ - cast cast-cbc cast5-cbc cast5-cfb cast5-ecb cast5-ofb ciphers crl \ - crl2pkcs7 des des-cbc des-cfb des-ecb des-ede des-ede-cbc des-ede-cfb \ - des-ede-ofb des-ede3 des-ede3-cbc des-ede3-cfb des-ede3-ofb \ - des-ofb des3 desx dgst dh dsa dsaparam enc errstr gendh gendsa \ - genrsa idea idea-cbc idea-cfb idea-ecb idea-ofb md2 mdc2 nseq \ - pkcs12 pkcs7 pkcs8 rc2 rc2-cbc rc2-cfb rc2-ecb rc2-ofb rc4 rc5 \ - rc5-cbc rc5-cfb rc5-ecb rc5-ofb req rmd160 rsa s_client s_server \ - s_time sess_id sha sha1 speed verify version x509; do \ - ${RM} -f $$file ; \ - ${LN} -sf openssl $$file; \ - done - cd ${WRKSRC}/tools && ${INSTALL_SCRIPT} \ - c_hash c_info c_issuer c_name c_rehash ${PREFIX}/bin - ${SED} -e s,/usr/local,${PREFIX}, ${WRKSRC}/apps/der_chop >${WRKDIR}/der_chop && \ - ${INSTALL_SCRIPT} ${WRKDIR}/der_chop ${PREFIX}/bin - cd ${WRKSRC}/apps && ${INSTALL_SCRIPT} CA.sh CA.pl ${PREFIX}/bin - ${INSTALL_DATA} ${WRKSRC}/apps/openssl.cnf ${PREFIX}/etc/openssl.cnf.example - cd ${WRKSRC} && ${INSTALL_DATA} libcrypto.a libssl.a ${PREFIX}/lib -.if ${OPSYS} == "NetBSD" - cd ${WRKSRC} && ${INSTALL_DATA} libcrypto.so.200.0 libssl.so.200.0 ${PREFIX}/lib -.if ${OBJECT_FMT} == "ELF" -.for shared_lib in libcrypto.so.200.0 libssl.so.200.0 - cd ${PREFIX}/lib && ${LN} -s ${shared_lib} ${shared_lib:R} && \ - ${LN} -s ${shared_lib} ${shared_lib:R:R} -.endfor -.endif -.endif -.if exists(/usr/bin/ranlib) - /usr/bin/ranlib ${PREFIX}/lib/libcrypto.a - /usr/bin/ranlib ${PREFIX}/lib/libssl.a -.endif -.if defined(USE_RSAREF2) && ${USE_RSAREF2} == YES - # libRSAglue.a is only useful if you are using the RSAREF2 library. - cd ${WRKSRC} && ${INSTALL_DATA} libRSAglue.a ${PREFIX}/lib -.endif - ${INSTALL_DATA_DIR} ${PREFIX}/include/openssl - cd ${WRKSRC}/include/openssl && \ - for file in \ - asn1.h asn1_mac.h bio.h blowfish.h bn.h buffer.h cast.h comp.h conf.h \ - crypto.h des.h dh.h dsa.h e_os.h e_os2.h ebcdic.h err.h evp.h hmac.h \ - idea.h lhash.h md2.h md4.h md5.h mdc2.h obj_mac.h objects.h \ - opensslconf.h opensslv.h pem.h pem2.h pkcs12.h pkcs7.h rand.h rc2.h \ - rc4.h rc5.h ripemd.h rsa.h safestack.h sha.h ssl.h ssl2.h ssl23.h \ - ssl3.h stack.h symhacks.h tls1.h tmdiff.h txt_db.h x509.h x509_vfy.h \ - x509v3.h ; do \ - ${INSTALL_DATA} $$file ${PREFIX}/include/openssl; \ - done -# @cd ${WRKSRC}/perl && ${MAKE} install - ${INSTALL_DATA_DIR} ${PREFIX}/share/doc/openssl - ${INSTALL_DATA_DIR} ${PREFIX}/share/doc/openssl/apps - ${INSTALL_DATA_DIR} ${PREFIX}/share/doc/openssl/crypto - ${INSTALL_DATA_DIR} ${PREFIX}/share/doc/openssl/ssl - ${INSTALL_DATA} ${WRKSRC}/doc/apps/* \ - ${PREFIX}/share/doc/openssl/apps - ${INSTALL_DATA} ${WRKSRC}/doc/crypto/* \ - ${PREFIX}/share/doc/openssl/crypto - ${INSTALL_DATA} ${WRKSRC}/doc/ssl/* \ - ${PREFIX}/share/doc/openssl/ssl - for file in README c-indentation.el openssl.txt openssl_button.gif \ - openssl_button.html ssleay.txt ; do \ - ${INSTALL_DATA} ${WRKSRC}/doc/$$file \ - ${PREFIX}/share/doc/openssl; \ - done - ${INSTALL_DATA_DIR} ${PREFIX}/certs - ${INSTALL_DATA_DIR} ${PREFIX}/private - @if [ ! -f ${PREFIX}/etc/openssl.cnf ]; then \ - ${CP} -p ${PREFIX}/etc/openssl.cnf.example ${PREFIX}/etc/openssl.cnf; \ - fi - -post-install: - ${CAT} ${PKGDIR}/PLIST.common ${PKGDIR}/PLIST.${LOWER_OPSYS} \ - ${PLIST_RSAREF} > ${PLIST_SRC} - .include "../../mk/bsd.pkg.mk" - -test: all - @cd ${WRKSRC}/test && ${SETENV} LD_LIBRARY_PATH=${WRKSRC} \ - MAKELIB=${FILESDIR}/makelib ${MAKE} tests - @${ECHO} "*** Tests successful. ***" |