a3980c464b
Changes between 1.0.2e and 1.0.2f [28 Jan 2016] *) DH small subgroups Historically OpenSSL only ever generated DH parameters based on "safe" primes. More recently (in version 1.0.2) support was provided for generating X9.42 style parameter files such as those required for RFC 5114 support. The primes used in such files may not be "safe". Where an application is using DH configured with parameters based on primes that are not "safe" then an attacker could use this fact to find a peer's private DH exponent. This attack requires that the attacker complete multiple handshakes in which the peer uses the same private DH exponent. For example this could be used to discover a TLS server's private DH exponent if it's reusing the private DH exponent or it's using a static DH ciphersuite. OpenSSL provides the option SSL_OP_SINGLE_DH_USE for ephemeral DH (DHE) in TLS. It is not on by default. If the option is not set then the server reuses the same private DH exponent for the life of the server process and would be vulnerable to this attack. It is believed that many popular applications do set this option and would therefore not be at risk. The fix for this issue adds an additional check where a "q" parameter is available (as is the case in X9.42 based parameters). This detects the only known attack, and is the only possible defense for static DH ciphersuites. This could have some performance impact. Additionally the SSL_OP_SINGLE_DH_USE option has been switched on by default and cannot be disabled. This could have some performance impact. This issue was reported to OpenSSL by Antonio Sanso (Adobe). (CVE-2016-0701) [Matt Caswell] *) SSLv2 doesn't block disabled ciphers A malicious client can negotiate SSLv2 ciphers that have been disabled on the server and complete SSLv2 handshakes even if all SSLv2 ciphers have been disabled, provided that the SSLv2 protocol was not also disabled via SSL_OP_NO_SSLv2. This issue was reported to OpenSSL on 26th December 2015 by Nimrod Aviram and Sebastian Schinzel. (CVE-2015-3197) [Viktor Dukhovni] *) Reject DH handshakes with parameters shorter than 1024 bits. [Kurt Roeckx]
172 lines
4.7 KiB
Makefile
172 lines
4.7 KiB
Makefile
# $NetBSD: Makefile,v 1.220 2016/01/28 16:30:42 jperkin Exp $
|
|
|
|
DISTNAME= openssl-1.0.2f
|
|
CATEGORIES= security
|
|
MASTER_SITES= https://www.openssl.org/source/
|
|
|
|
MAINTAINER= pkgsrc-users@NetBSD.org
|
|
HOMEPAGE= https://www.openssl.org/
|
|
COMMENT= Secure Socket Layer and cryptographic library
|
|
LICENSE= openssl
|
|
|
|
CONFLICTS= SSLeay-[0-9]* ssleay-[0-9]*
|
|
|
|
CRYPTO= yes
|
|
|
|
BUILD_DEPENDS+= p5-Perl4-CoreLibs-[0-9]*:../../devel/p5-Perl4-CoreLibs
|
|
|
|
USE_GCC_RUNTIME= yes
|
|
|
|
.include "../../mk/bsd.prefs.mk"
|
|
.include "../../mk/compiler.mk"
|
|
|
|
USE_TOOLS+= fgrep gmake perl
|
|
BUILD_TARGET= depend all
|
|
TEST_TARGET= tests
|
|
MAKE_JOBS_SAFE= no
|
|
|
|
HAS_CONFIGURE= yes
|
|
CONFIGURE_SCRIPT= ./config
|
|
CONFIGURE_ARGS+= --prefix=${PREFIX}
|
|
CONFIGURE_ARGS+= --install_prefix=${DESTDIR}
|
|
CONFIGURE_ARGS+= --openssldir=${PKG_SYSCONFDIR}
|
|
CONFIGURE_ARGS+= shared no-fips
|
|
|
|
# Avoid dependency on 'makedepend' on platforms where the default CC is set
|
|
# to 'cc' not 'gcc' in boostrap-mk-files. OpenSSL only supports the latter.
|
|
.if ${PKGSRC_COMPILER} == "gcc" && ${CC} == "cc"
|
|
CC= gcc
|
|
.endif
|
|
|
|
.if ${OPSYS} == "SunOS"
|
|
. if ${MACHINE_ARCH} == "sparc"
|
|
OPENSSL_MACHINE_ARCH= sparcv7
|
|
. elif ${MACHINE_ARCH} == "sparc64"
|
|
OPENSSL_MACHINE_ARCH= sparcv9
|
|
. elif ${MACHINE_ARCH} == "i386"
|
|
OPENSSL_MACHINE_ARCH= x86
|
|
. elif ${MACHINE_ARCH} == "x86_64"
|
|
OPENSSL_MACHINE_ARCH= ${MACHINE_ARCH}
|
|
. endif
|
|
# only override the configure target if we know the platform, falling
|
|
# back to ./config's autodetection if not.
|
|
. if defined(OPENSSL_MACHINE_ARCH) && !empty(OPENSSL_MACHINE_ARCH)
|
|
CONFIGURE_SCRIPT= ./Configure
|
|
. if ${PKGSRC_COMPILER} == "clang" || ${PKGSRC_COMPILER} == "gcc"
|
|
CONFIGURE_ARGS+= solaris${${ABI}==64:?64:}-${OPENSSL_MACHINE_ARCH}-gcc
|
|
. else
|
|
CONFIGURE_ARGS+= solaris${${ABI}==64:?64:}-${OPENSSL_MACHINE_ARCH}-cc
|
|
. endif
|
|
. endif
|
|
.elif ${OPSYS} == "IRIX"
|
|
CONFIGURE_ARGS+= no-asm
|
|
. if defined(ABI) && ${ABI} == "64"
|
|
CONFIGURE_SCRIPT= ./Configure
|
|
. if !empty(CC_VERSION:Mgcc*)
|
|
CONFIGURE_ARGS+= irix64-mips4-gcc
|
|
. else
|
|
CONFIGURE_ARGS+= irix64-mips4-cc
|
|
. endif
|
|
. endif
|
|
.elif ${OPSYS} == "OSF1"
|
|
USE_PLIST_SHLIB= no
|
|
CONFIGURE_SCRIPT= ./Configure
|
|
. if !empty(CC_VERSION:Mgcc*)
|
|
CONFIGURE_ARGS+= tru64-alpha-gcc
|
|
. else
|
|
CONFIGURE_ARGS+= tru64-alpha-cc
|
|
. endif
|
|
.elif ${OPSYS} == "Darwin"
|
|
CONFIGURE_SCRIPT= ./Configure
|
|
. if defined(ABI) && ${ABI} == "64"
|
|
CONFIGURE_ARGS+= darwin64-${MACHINE_ARCH}-cc
|
|
. elif ${MACHINE_ARCH} == "powerpc"
|
|
CONFIGURE_ARGS+= darwin-ppc-cc
|
|
. else
|
|
CONFIGURE_ARGS+= darwin-${MACHINE_ARCH}-cc
|
|
. endif
|
|
|
|
SUBST_CLASSES+= dl
|
|
SUBST_MESSAGE.dl= Adding dynamic link compatibility library.
|
|
SUBST_STAGE.dl= post-configure
|
|
SUBST_FILES.dl= Makefile apps/Makefile crypto/Makefile \
|
|
crypto/pkcs7/Makefile test/Makefile
|
|
SUBST_SED.dl= -e 's,^EX_LIBS=,EX_LIBS=${DL_LDFLAGS:Q} ,g'
|
|
|
|
.elif ${OPSYS} == "AIX"
|
|
CONFIGURE_SCRIPT= ./Configure
|
|
. if defined(ABI) && ${ABI} == "64"
|
|
. if !empty(CC_VERSION:Mgcc*)
|
|
CONFIGURE_ARGS+= aix64-gcc
|
|
. else
|
|
CONFIGURE_ARGS+= aix64-cc
|
|
. endif
|
|
. else
|
|
. if !empty(CC_VERSION:Mgcc*)
|
|
CONFIGURE_ARGS+= aix-gcc
|
|
. else
|
|
CONFIGURE_ARGS+= aix-cc
|
|
. endif
|
|
. endif
|
|
.elif ${OPSYS} == "Interix"
|
|
SUBST_CLASSES+= soname
|
|
SUBST_STAGE.soname= post-configure
|
|
SUBST_FILES.soname= Makefile.shared
|
|
SUBST_SED.soname= -e 's/-Wl,-soname=/-Wl,-h,/g'
|
|
.elif ${OPSYS} == "HPUX"
|
|
CONFIGURE_SCRIPT= ./Configure
|
|
. if defined(ABI) && ${ABI} == "64"
|
|
. if ${MACHINE_ARCH} == "hppa64"
|
|
CONFIGURE_ARGS+= hpux64-parisc2-${CC}
|
|
. else
|
|
CONFIGURE_ARGS+= hpux64-ia64-${CC}
|
|
. endif
|
|
. else
|
|
. if ${MACHINE_ARCH} == "hppa"
|
|
CONFIGURE_ARGS+= hpux-parisc-${CC}
|
|
. else
|
|
CONFIGURE_ARGS+= hpux-ia64-${CC}
|
|
. endif
|
|
. endif
|
|
.elif ${OPSYS} == "Linux"
|
|
. if ${MACHINE_ARCH} == "powerpc64"
|
|
CONFIGURE_SCRIPT= ./Configure
|
|
CONFIGURE_ARGS+= linux-ppc64
|
|
. elif ${MACHINE_ARCH} == "i386"
|
|
CONFIGURE_SCRIPT= ./Configure
|
|
CONFIGURE_ARGS+= linux-elf
|
|
. endif
|
|
.elif ${OS_VARIANT} == "SCOOSR5"
|
|
# SIGILL in _sha1_block_data_order_ssse3().
|
|
CONFIGURE_ARGS+= no-sse2
|
|
.endif
|
|
|
|
.include "../../security/openssl/options.mk"
|
|
|
|
CONFIGURE_ARGS+= ${CFLAGS} ${LDFLAGS}
|
|
CONFIGURE_ENV+= PERL=${PERL5:Q}
|
|
|
|
PKGCONFIG_OVERRIDE+= libcrypto.pc libssl.pc openssl.pc
|
|
PKGCONFIG_OVERRIDE_STAGE= post-build
|
|
|
|
PLIST_SRC+= ${PKGDIR}/PLIST.common
|
|
USE_PLIST_SHLIB?= yes
|
|
.if ${USE_PLIST_SHLIB} == "yes"
|
|
PLIST_SRC+= ${PKGDIR}/PLIST.shlib
|
|
.endif
|
|
PLIST_SUBST+= SHLIB_VERSION=${OPENSSL_VERS:C/[^0-9]*$//}
|
|
PLIST_SUBST+= SHLIB_MAJOR=${OPENSSL_VERS:C/\..*$//}
|
|
|
|
PKG_SYSCONFSUBDIR= openssl
|
|
CONF_FILES= ${PREFIX}/share/examples/openssl/openssl.cnf \
|
|
${PKG_SYSCONFDIR}/openssl.cnf
|
|
OWN_DIRS= ${PKG_SYSCONFDIR}/certs ${PKG_SYSCONFDIR}/private
|
|
|
|
INSTALLATION_DIRS+= share/examples/openssl
|
|
|
|
# Fix the path to perl in various scripts.
|
|
pre-configure:
|
|
cd ${WRKSRC} && ${PERL5} util/perlpath.pl ${PERL5}
|
|
|
|
.include "../../mk/dlopen.buildlink3.mk"
|
|
.include "../../mk/bsd.pkg.mk"
|