1# $NetBSD: Makefile,v 1.11 2016/04/13 21:33:52 christos Exp $ 2 3# RCSid: 4# Id: Makefile,v 1.33 1998/11/11 11:53:53 sjg Exp 5# 6# @(#) Copyright (c) 1994 Simon J. Gerraty 7# 8# This file is provided in the hope that it will 9# be of use. There is absolutely NO WARRANTY. 10# Permission to copy, redistribute or otherwise 11# use this file is hereby granted provided that 12# the above copyright notice and this notice are 13# left intact. 14# 15# Please send copies of changes and bug-fixes to: 16# sjg@quick.com.au 17# 18 19LIB= crypto 20USE_FORT?= yes # cryptographic software 21USE_SHLIBDIR= yes 22USE_FIPS= no 23 24.include <bsd.own.mk> 25.include <bsd.shlib.mk> 26 27# XXX There's a bit of work to do before we can enable warnings. 28WARNS=0 29CWARNFLAGS.clang+= -Wno-empty-body -Wno-unused-value -Wno-parentheses 30 31CPPFLAGS+= -Dlib${LIB} -I. -I${OPENSSLSRC}/crypto -I${OPENSSLSRC} 32CPPFLAGS+= -I${OPENSSLSRC}/crypto/asn1 -I${OPENSSLSRC}/crypto/evp 33 34CRYPTODIST= ${NETBSDSRCDIR}/crypto 35 36.include "${NETBSDSRCDIR}/crypto/Makefile.openssl" 37.PATH: ${OPENSSLSRC} 38 39.include "srcs.inc" 40 41AFLAGS+=-DELF 42LIBDPLIBS+= crypt ${NETBSDSRCDIR}/lib/libcrypt 43 44OS_VERSION!= ${HOST_SH} ${NETBSDSRCDIR}/sys/conf/osrelease.sh 45 46# XXX CFLAGS: While it would be nice to know which compiler flags 47# XXX the library was built with, we don't want pathname information 48# XXX for the host toolchain embedded in the image. 49${SRCS}: buildinf.h 50buildinf.h: Makefile 51 @echo "#ifndef MK1MF_BUILD" >buildinf.h 52 @echo "#define CFLAGS \"`${CC} -v 2>&1 | grep 'gcc version'`\"" >>buildinf.h 53 @echo "#define PLATFORM \"NetBSD-${MACHINE_ARCH}\"" >>buildinf.h 54 @echo "#define DATE \"NetBSD ${OS_VERSION}\"" >>buildinf.h 55 @echo "#endif" >>buildinf.h 56 57CLEANFILES+= buildinf.h 58 59# This list is built from the contents of the include/openssl 60# directory in the OpenSSL source distribution. 61INCS+= aes.h asn1.h asn1_mac.h asn1t.h bio.h blowfish.h bn.h \ 62 buffer.h cast.h cmac.h cms.h comp.h conf.h conf_api.h crypto.h des.h \ 63 dh.h dsa.h dso.h e_os2.h ebcdic.h ec.h ecdh.h ecdsa.h engine.h \ 64 err.h evp.h hmac.h krb5_asn.h lhash.h md2.h md4.h md5.h modes.h \ 65 obj_mac.h objects.h ocsp.h opensslconf.h opensslv.h ossl_typ.h \ 66 pem.h pem2.h pkcs12.h pkcs7.h rand.h rc2.h rc4.h ripemd.h \ 67 rsa.h safestack.h sha.h srp.h stack.h store.h symhacks.h ts.h txt_db.h \ 68 ui.h ui_compat.h x509.h x509_vfy.h x509v3.h pqueue.h camellia.h \ 69 whrlpool.h seed.h 70# des_old.h 71 72# IDEA - patented, but we install the header anyways 73INCS+= idea.h 74 75# RC5 - patented, but we install the header anyways 76INCS+= rc5.h 77 78# MDC2 - patented, but we install the header anyways 79INCS+= mdc2.h 80 81.if (${USE_FIPS} != "no") 82# FIPS 83# This part is always included, because OpenSSL does not protect 84# The FIPS include files 85.PATH: ${OPENSSLSRC}/fips ${OPENSSLSRC}/fips/rand 86INCS+= fips.h fips_rand.h 87.endif 88 89.if (${USE_FIPS} != "no") 90CPPFLAGS+=-DOPENSSL_FIPS 91.PATH: ${OPENSSLSRC}/fips/aes 92SRCS+=fips_aes_core.c fips_aes_selftest.c 93.PATH: ${OPENSSLSRC}/fips/des 94SRCS+=fips_des_enc.c fips_des_selftest.c fips_set_key.c 95# asm/fips-dx86-elf.s 96.PATH: ${OPENSSLSRC}/fips/dh 97SRCS+=fips_dh_check.c fips_dh_gen.c fips_dh_key.c 98.PATH: ${OPENSSLSRC}/fips/dsa 99SRCS+=fips_dsa_ossl.c fips_dsa_gen.c fips_dsa_selftest.c 100#.PATH: ${OPENSSLSRC}/fips/rand 101SRCS+=fips_rand.c 102.PATH: ${OPENSSLSRC}/fips/rsa 103SRCS+=fips_rsa_eay.c fips_rsa_gen.c fips_rsa_selftest.c 104SRCS+=fips_sha1dgst.c fips_sha1_selftest.c 105# asm/sx86-elf.s 106.PATH: ${OPENSSLSRC}/fips/sha1 107#.PATH: ${OPENSSLSRC}/fips 108SRCS+=fips.c fips_err_wrapper.c 109 110SRCS+=rc5_skey.c i_skey.c mdc2dgst.c 111.endif 112 113COPTS.eng_padlock.c = -Wno-stack-protector 114 115INCSDIR=/usr/include/openssl 116 117PKGCONFIG=libcrypto 118.include "${.CURDIR}/../../pkgconfig.mk" 119 120.include <bsd.lib.mk> 121# RC5 warning 122LDFLAGS+=-Wl,--no-fatal-warnings 123