5 kx # Nettle Makefile
5 kx
5 kx @SET_MAKE@
5 kx
5 kx srcdir = @srcdir@
5 kx VPATH = @srcdir@
5 kx
5 kx INSTALL = @INSTALL@
5 kx INSTALL_DATA = @INSTALL_DATA@
5 kx INSTALL_PROGRAM = @INSTALL_PROGRAM@
5 kx INSTALL_SCRIPT = @INSTALL_SCRIPT@
5 kx INSTALL_STRIP_PROGRAM = $(INSTALL_PROGRAM) -s
5 kx MKDIR_P = @MKDIR_P@
5 kx
5 kx OPT_NETTLE_OBJS = @OPT_NETTLE_OBJS@
5 kx OPT_HOGWEED_OBJS = @OPT_HOGWEED_OBJS@
5 kx
5 kx OPT_NETTLE_SOURCES = @OPT_NETTLE_SOURCES@
5 kx
5 kx FAT_TEST_LIST = @FAT_TEST_LIST@
5 kx
5 kx SUBDIRS = tools testsuite examples
5 kx
5 kx include config.make
5 kx
5 kx PRE_CPPFLAGS = -I.
5 kx EXTRA_CFLAGS = $(CCPIC)
5 kx
5 kx # FIXME: Add configuration of LIBEXT?
5 kx LIBTARGETS = @IF_STATIC@ libnettle.a @IF_HOGWEED@ libhogweed.a
5 kx SHLIBTARGETS = @IF_SHARED@ $(LIBNETTLE_FORLINK) @IF_HOGWEED@ $(LIBHOGWEED_FORLINK)
5 kx
5 kx getopt_SOURCES = getopt.c getopt1.c
5 kx getopt_TARGETS = $(getopt_SOURCES:.c=.$(OBJEXT))
5 kx
5 kx internal_SOURCES = nettle-internal.c
5 kx internal_TARGETS = $(internal_SOURCES:.c=.$(OBJEXT))
5 kx
5 kx TARGETS = $(getopt_TARGETS) $(internal_TARGETS) \
5 kx $(LIBTARGETS) $(SHLIBTARGETS)
5 kx
5 kx DOCTARGETS = @IF_DOCUMENTATION@ nettle.info nettle.html nettle.pdf
5 kx
5 kx PKGCONFIG_FILES = nettle.pc @IF_HOGWEED@ hogweed.pc
5 kx pkgconfigdir = $(libdir)/pkgconfig
5 kx
5 kx all check install uninstall:
5 kx $(MAKE) $@-here
5 kx set -e; for d in $(SUBDIRS); do \
5 kx echo "Making $@ in $$d" ; (cd $$d && $(MAKE) $@); done
5 kx
5 kx clean distclean mostlyclean maintainer-clean tags:
5 kx set -e; for d in $(SUBDIRS); do \
5 kx echo "Making $@ in $$d" ; (cd $$d && $(MAKE) $@); done
5 kx $(MAKE) $@-here
5 kx
5 kx check-here:
5 kx true
5 kx
5 kx # Tries different settings of NETTLE_FAT_OVERRIDE. Note that this
5 kx # requires that corresponding processor features are available on the
5 kx # test machine.
5 kx check-fat:
5 kx [ -z "$(FAT_TEST_LIST)" ] || \
5 kx set -e; cd testsuite && for f in $(FAT_TEST_LIST) ; do \
5 kx echo NETTLE_FAT_OVERRIDE=$$f ; \
5 kx NETTLE_FAT_OVERRIDE=$$f $(MAKE) check ; \
5 kx done
5 kx
5 kx # FIXME: Remove. These targets aren't supported, but they are expected by the
5 kx # automake generated Makefiles in the lsh build.
5 kx dvi installcheck uninstallcheck:
5 kx true
5 kx
5 kx all-here: $(TARGETS) $(DOCTARGETS)
5 kx
5 kx nettle_SOURCES = aes-decrypt-internal.c aes-decrypt.c \
5 kx aes-encrypt-internal.c aes-encrypt.c aes-encrypt-table.c \
5 kx aes-invert-internal.c aes-set-key-internal.c \
5 kx aes-set-encrypt-key.c aes-set-decrypt-key.c \
5 kx aes128-set-encrypt-key.c aes128-set-decrypt-key.c \
5 kx aes128-meta.c \
5 kx aes192-set-encrypt-key.c aes192-set-decrypt-key.c \
5 kx aes192-meta.c \
5 kx aes256-set-encrypt-key.c aes256-set-decrypt-key.c \
5 kx aes256-meta.c \
5 kx arcfour.c arcfour-crypt.c \
5 kx arctwo.c arctwo-meta.c blowfish.c blowfish-bcrypt.c \
5 kx base16-encode.c base16-decode.c base16-meta.c \
5 kx base64-encode.c base64-decode.c base64-meta.c \
5 kx base64url-encode.c base64url-decode.c base64url-meta.c \
5 kx buffer.c buffer-init.c \
5 kx camellia-crypt-internal.c camellia-table.c \
5 kx camellia-absorb.c camellia-invert-key.c \
5 kx camellia128-set-encrypt-key.c camellia128-crypt.c \
5 kx camellia128-set-decrypt-key.c \
5 kx camellia128-meta.c \
5 kx camellia192-meta.c \
5 kx camellia256-set-encrypt-key.c camellia256-crypt.c \
5 kx camellia256-set-decrypt-key.c \
5 kx camellia256-meta.c \
5 kx cast128.c cast128-meta.c cbc.c \
5 kx ccm.c ccm-aes128.c ccm-aes192.c ccm-aes256.c cfb.c \
5 kx siv-cmac.c siv-cmac-aes128.c siv-cmac-aes256.c \
5 kx cnd-memcpy.c \
5 kx chacha-crypt.c chacha-core-internal.c \
5 kx chacha-poly1305.c chacha-poly1305-meta.c \
5 kx chacha-set-key.c chacha-set-nonce.c \
5 kx ctr.c ctr16.c des.c des3.c \
5 kx eax.c eax-aes128.c eax-aes128-meta.c \
5 kx gcm.c gcm-aes.c \
5 kx gcm-aes128.c gcm-aes128-meta.c \
5 kx gcm-aes192.c gcm-aes192-meta.c \
5 kx gcm-aes256.c gcm-aes256-meta.c \
5 kx gcm-camellia128.c gcm-camellia128-meta.c \
5 kx gcm-camellia256.c gcm-camellia256-meta.c \
5 kx cmac.c cmac64.c cmac-aes128.c cmac-aes256.c cmac-des3.c \
5 kx cmac-aes128-meta.c cmac-aes256-meta.c cmac-des3-meta.c \
5 kx gost28147.c gosthash94.c gosthash94-meta.c \
5 kx hmac.c hmac-gosthash94.c hmac-md5.c hmac-ripemd160.c \
5 kx hmac-sha1.c hmac-sha224.c hmac-sha256.c hmac-sha384.c \
5 kx hmac-sha512.c hmac-streebog.c \
5 kx hmac-md5-meta.c hmac-ripemd160-meta.c hmac-sha1-meta.c \
5 kx hmac-sha224-meta.c hmac-sha256-meta.c hmac-sha384-meta.c \
5 kx hmac-sha512-meta.c hmac-streebog-meta.c \
5 kx knuth-lfib.c hkdf.c \
5 kx md2.c md2-meta.c md4.c md4-meta.c \
5 kx md5.c md5-compress.c md5-compat.c md5-meta.c \
5 kx memeql-sec.c memxor.c memxor3.c \
5 kx nettle-lookup-hash.c \
5 kx nettle-meta-aeads.c nettle-meta-armors.c \
5 kx nettle-meta-ciphers.c nettle-meta-hashes.c nettle-meta-macs.c \
5 kx pbkdf2.c pbkdf2-hmac-gosthash94.c pbkdf2-hmac-sha1.c \
5 kx pbkdf2-hmac-sha256.c pbkdf2-hmac-sha384.c pbkdf2-hmac-sha512.c \
5 kx poly1305-aes.c poly1305-internal.c \
5 kx realloc.c \
5 kx ripemd160.c ripemd160-compress.c ripemd160-meta.c \
5 kx salsa20-core-internal.c salsa20-crypt-internal.c \
5 kx salsa20-crypt.c salsa20r12-crypt.c salsa20-set-key.c \
5 kx salsa20-set-nonce.c \
5 kx salsa20-128-set-key.c salsa20-256-set-key.c \
5 kx sha1.c sha1-compress.c sha1-meta.c \
5 kx sha256.c sha256-compress.c sha224-meta.c sha256-meta.c \
5 kx sha512.c sha512-compress.c sha384-meta.c sha512-meta.c \
5 kx sha512-224-meta.c sha512-256-meta.c \
5 kx sha3.c sha3-permute.c \
5 kx sha3-224.c sha3-224-meta.c sha3-256.c sha3-256-meta.c \
5 kx sha3-384.c sha3-384-meta.c sha3-512.c sha3-512-meta.c \
5 kx shake256.c \
5 kx serpent-set-key.c serpent-encrypt.c serpent-decrypt.c \
5 kx serpent-meta.c \
5 kx streebog.c streebog-meta.c \
5 kx twofish.c twofish-meta.c \
5 kx umac-nh.c umac-nh-n.c umac-l2.c umac-l3.c \
5 kx umac-poly64.c umac-poly128.c umac-set-key.c \
5 kx umac32.c umac64.c umac96.c umac128.c \
5 kx version.c \
5 kx write-be32.c write-le32.c write-le64.c \
5 kx yarrow256.c yarrow_key_event.c \
5 kx xts.c xts-aes128.c xts-aes256.c
5 kx
5 kx hogweed_SOURCES = sexp.c sexp-format.c \
5 kx sexp-transport.c sexp-transport-format.c \
5 kx bignum.c bignum-random.c bignum-random-prime.c \
5 kx sexp2bignum.c \
5 kx pkcs1.c pkcs1-encrypt.c pkcs1-decrypt.c \
5 kx pkcs1-sec-decrypt.c \
5 kx pkcs1-rsa-digest.c pkcs1-rsa-md5.c pkcs1-rsa-sha1.c \
5 kx pkcs1-rsa-sha256.c pkcs1-rsa-sha512.c \
5 kx pss.c pss-mgf1.c \
5 kx rsa.c rsa-sign.c rsa-sign-tr.c rsa-verify.c \
5 kx rsa-sec-compute-root.c \
5 kx rsa-pkcs1-sign.c rsa-pkcs1-sign-tr.c rsa-pkcs1-verify.c \
5 kx rsa-md5-sign.c rsa-md5-sign-tr.c rsa-md5-verify.c \
5 kx rsa-sha1-sign.c rsa-sha1-sign-tr.c rsa-sha1-verify.c \
5 kx rsa-sha256-sign.c rsa-sha256-sign-tr.c rsa-sha256-verify.c \
5 kx rsa-sha512-sign.c rsa-sha512-sign-tr.c rsa-sha512-verify.c \
5 kx rsa-pss-sha256-sign-tr.c rsa-pss-sha256-verify.c \
5 kx rsa-pss-sha512-sign-tr.c rsa-pss-sha512-verify.c \
5 kx rsa-encrypt.c rsa-decrypt.c \
5 kx rsa-sec-decrypt.c rsa-decrypt-tr.c \
5 kx rsa-keygen.c rsa-blind.c \
5 kx rsa2sexp.c sexp2rsa.c \
5 kx dsa.c dsa-compat.c dsa-compat-keygen.c dsa-gen-params.c \
5 kx dsa-sign.c dsa-verify.c dsa-keygen.c dsa-hash.c \
5 kx dsa-sha1-sign.c dsa-sha1-verify.c \
5 kx dsa-sha256-sign.c dsa-sha256-verify.c \
5 kx dsa2sexp.c sexp2dsa.c \
5 kx pgp-encode.c rsa2openpgp.c \
5 kx der-iterator.c der2rsa.c der2dsa.c \
5 kx sec-add-1.c sec-sub-1.c sec-tabselect.c \
5 kx gmp-glue.c cnd-copy.c \
5 kx ecc-mod.c ecc-mod-inv.c \
5 kx ecc-mod-arith.c ecc-pp1-redc.c ecc-pm1-redc.c \
5 kx ecc-curve25519.c ecc-curve448.c \
5 kx ecc-gost-gc256b.c ecc-gost-gc512a.c \
5 kx ecc-secp192r1.c ecc-secp224r1.c ecc-secp256r1.c \
5 kx ecc-secp384r1.c ecc-secp521r1.c \
5 kx ecc-size.c ecc-j-to-a.c ecc-a-to-j.c \
5 kx ecc-dup-jj.c ecc-add-jja.c ecc-add-jjj.c \
5 kx ecc-eh-to-a.c \
5 kx ecc-dup-eh.c ecc-add-eh.c ecc-add-ehh.c \
5 kx ecc-dup-th.c ecc-add-th.c ecc-add-thh.c \
5 kx ecc-mul-g-eh.c ecc-mul-a-eh.c ecc-mul-m.c \
5 kx ecc-mul-g.c ecc-mul-a.c ecc-hash.c ecc-random.c \
5 kx ecc-point.c ecc-scalar.c ecc-point-mul.c ecc-point-mul-g.c \
5 kx ecc-ecdsa-sign.c ecdsa-sign.c \
5 kx ecc-ecdsa-verify.c ecdsa-verify.c ecdsa-keygen.c \
5 kx ecc-gostdsa-sign.c gostdsa-sign.c \
5 kx ecc-gostdsa-verify.c gostdsa-verify.c gostdsa-vko.c \
5 kx curve25519-mul-g.c curve25519-mul.c curve25519-eh-to-x.c \
5 kx curve448-mul-g.c curve448-mul.c curve448-eh-to-x.c \
5 kx eddsa-compress.c eddsa-decompress.c eddsa-expand.c \
5 kx eddsa-hash.c eddsa-pubkey.c eddsa-sign.c eddsa-verify.c \
5 kx ed25519-sha512.c ed25519-sha512-pubkey.c \
5 kx ed25519-sha512-sign.c ed25519-sha512-verify.c \
5 kx ed448-shake256.c ed448-shake256-pubkey.c \
5 kx ed448-shake256-sign.c ed448-shake256-verify.c
5 kx
5 kx OPT_SOURCES = fat-arm.c fat-ppc.c fat-x86_64.c mini-gmp.c
5 kx
5 kx HEADERS = aes.h arcfour.h arctwo.h asn1.h blowfish.h \
5 kx base16.h base64.h bignum.h buffer.h camellia.h cast128.h \
5 kx cbc.h ccm.h cfb.h chacha.h chacha-poly1305.h ctr.h \
5 kx curve25519.h curve448.h des.h dsa.h dsa-compat.h eax.h \
5 kx ecc-curve.h ecc.h ecdsa.h eddsa.h \
5 kx gcm.h gostdsa.h gosthash94.h hmac.h \
5 kx knuth-lfib.h hkdf.h \
5 kx macros.h \
5 kx cmac.h siv-cmac.h \
5 kx md2.h md4.h \
5 kx md5.h md5-compat.h \
5 kx memops.h memxor.h \
5 kx nettle-meta.h nettle-types.h \
5 kx pbkdf2.h \
5 kx pgp.h pkcs1.h pss.h pss-mgf1.h realloc.h ripemd160.h rsa.h \
5 kx salsa20.h sexp.h \
5 kx serpent.h sha.h sha1.h sha2.h sha3.h streebog.h twofish.h \
5 kx umac.h yarrow.h xts.h poly1305.h
5 kx
5 kx INSTALL_HEADERS = $(HEADERS) version.h @IF_MINI_GMP@ mini-gmp.h
5 kx
5 kx SOURCES = $(nettle_SOURCES) $(hogweed_SOURCES) \
5 kx $(getopt_SOURCES) $(internal_SOURCES) \
5 kx $(OPT_SOURCES) \
5 kx aesdata.c desdata.c twofishdata.c shadata.c gcmdata.c eccdata.c
5 kx
5 kx # NOTE: This list must include all source files, with no duplicates,
5 kx # independently of which source files are included in the build.
5 kx DISTFILES = $(SOURCES) $(HEADERS) getopt.h getopt_int.h \
5 kx .bootstrap run-tests \
5 kx aclocal.m4 configure.ac \
5 kx configure stamp-h.in version.h.in \
5 kx libnettle.map.in libhogweed.map.in \
5 kx config.guess config.sub install-sh texinfo.tex \
5 kx config.h.in config.m4.in config.make.in Makefile.in \
5 kx README CONTRIBUTING.md AUTHORS COPYING.LESSERv3 COPYINGv2 COPYINGv3 \
5 kx INSTALL NEWS ChangeLog \
5 kx nettle.pc.in hogweed.pc.in \
5 kx desdata.stamp $(des_headers) descore.README \
5 kx aes-internal.h block-internal.h blowfish-internal.h camellia-internal.h \
5 kx gcm-internal.h gost28147-internal.h poly1305-internal.h \
5 kx serpent-internal.h cast128_sboxes.h desinfo.h desCode.h \
5 kx ripemd160-internal.h sha2-internal.h \
5 kx memxor-internal.h nettle-internal.h nettle-write.h \
5 kx ctr-internal.h chacha-internal.h sha3-internal.h \
5 kx salsa20-internal.h umac-internal.h hogweed-internal.h \
5 kx rsa-internal.h pkcs1-internal.h dsa-internal.h eddsa-internal.h \
5 kx gmp-glue.h ecc-internal.h fat-setup.h \
5 kx mini-gmp.h asm.m4 m4-utils.m4 \
5 kx nettle.texinfo nettle.info nettle.html nettle.pdf sha-example.c
5 kx
5 kx # Rules building static libraries
5 kx nettle_OBJS = $(nettle_SOURCES:.c=.$(OBJEXT)) \
5 kx $(OPT_NETTLE_SOURCES:.c=.$(OBJEXT)) $(OPT_NETTLE_OBJS)
5 kx
5 kx hogweed_OBJS = $(hogweed_SOURCES:.c=.$(OBJEXT)) \
5 kx $(OPT_HOGWEED_OBJS) @IF_MINI_GMP@ mini-gmp.$(OBJEXT)
5 kx
5 kx libnettle.a: $(nettle_OBJS)
5 kx -rm -f $@
5 kx $(AR) $(ARFLAGS) $@ $(nettle_OBJS)
5 kx $(RANLIB) $@
5 kx echo nettle > libnettle.stamp
5 kx
5 kx libhogweed.a: $(hogweed_OBJS)
5 kx -rm -f $@
5 kx $(AR) $(ARFLAGS) $@ $(hogweed_OBJS)
5 kx $(RANLIB) $@
5 kx echo hogweed > libhogweed.stamp
5 kx
5 kx %.$(OBJEXT): %.asm $(srcdir)/m4-utils.m4 $(srcdir)/asm.m4 config.m4 machine.m4
5 kx $(M4) $(srcdir)/m4-utils.m4 $(srcdir)/asm.m4 config.m4 machine.m4 $< >$*.s
5 kx $(COMPILE) -c $*.s
5 kx
5 kx %.$(OBJEXT): %.c
5 kx $(COMPILE) -c $< \
5 kx && $(DEP_PROCESS)
5 kx
5 kx # Rules building shared libraries.
5 kx $(LIBNETTLE_FORLINK): $(nettle_OBJS)
5 kx $(LIBNETTLE_LINK) $(nettle_OBJS) @EXTRA_LINKER_FLAGS@ -o $@ $(LIBNETTLE_LIBS)
5 kx -mkdir .lib 2>/dev/null
5 kx (cd .lib \
5 kx && rm -f $(LIBNETTLE_FORLINK) \
5 kx && $(LN_S) ../$(LIBNETTLE_FORLINK) $(LIBNETTLE_FORLINK) \
5 kx && [ -z "$(LIBNETTLE_SONAME)" ] \
5 kx || { rm -f $(LIBNETTLE_SONAME) \
5 kx && $(LN_S) $(LIBNETTLE_FORLINK) $(LIBNETTLE_SONAME) ; } )
5 kx echo nettle > libnettle.stamp
5 kx
5 kx $(LIBHOGWEED_FORLINK): $(hogweed_OBJS) $(LIBNETTLE_FORLINK)
5 kx $(LIBHOGWEED_LINK) $(hogweed_OBJS) @EXTRA_HOGWEED_LINKER_FLAGS@ -o $@ $(LIBHOGWEED_LIBS)
5 kx -mkdir .lib 2>/dev/null
5 kx (cd .lib \
5 kx && rm -f $(LIBHOGWEED_FORLINK) \
5 kx && $(LN_S) ../$(LIBHOGWEED_FORLINK) $(LIBHOGWEED_FORLINK) \
5 kx && [ -z "$(LIBHOGWEED_SONAME)" ] \
5 kx || { rm -f $(LIBHOGWEED_SONAME) \
5 kx && $(LN_S) $(LIBHOGWEED_FORLINK) $(LIBHOGWEED_SONAME) ; } )
5 kx echo hogweed > libhogweed.stamp
5 kx
5 kx # For building the various *data.c programs. -lm needed for shadata.
5 kx %$(EXEEXT_FOR_BUILD): %.c
5 kx $(CC_FOR_BUILD) $< -lm -o $@
5 kx
5 kx # Explicit dependency.
5 kx eccdata$(EXEEXT_FOR_BUILD): mini-gmp.c mini-gmp.h
5 kx
5 kx # desCore rules
5 kx # It seems using $(srcdir)/ doesn't work with GNU make 3.79.1
5 kx # des_headers = $(srcdir)/rotors.h $(srcdir)/keymap.h
5 kx des_headers = rotors.h keymap.h
5 kx
5 kx # Generate DES headers.
5 kx $(des_headers): desdata.stamp
5 kx f="$(srcdir)/`basename $@`"; \
5 kx ./desdata$(EXEEXT_FOR_BUILD) $(@F) > $${f}T; \
5 kx test -s $${f}T && mv -f $${f}T $$f
5 kx
5 kx desdata.stamp: desdata.c
5 kx $(MAKE) desdata$(EXEEXT_FOR_BUILD) && echo stamp > desdata.stamp
5 kx
5 kx des.$(OBJEXT): des.c des.h $(des_headers)
5 kx
5 kx # Generate ECC files, with roughly 16 KB of tables per curve.
5 kx
5 kx # Some reasonable choices for 192:
5 kx # k = 8, c = 6, S = 256, T = 40 ( 32 A + 8 D) 12 KB
5 kx # k = 14, c = 7, S = 256, T = 42 ( 28 A + 14 D) 12 KB
5 kx # k = 11, c = 6, S = 192, T = 44 ( 33 A + 11 D) 9 KB
5 kx # k = 16, c = 6, S = 128, T = 48 ( 32 A + 16 D) 6 KB
5 kx ecc-secp192r1.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) secp192r1 8 6 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx # Some reasonable choices for 224:
5 kx # k = 16, c = 7, S = 256, T = 48 ( 32 A + 16 D) ~16 KB
5 kx # k = 10, c = 6, S = 256, T = 50 ( 40 A + 10 D) ~16 KB
5 kx # k = 13, c = 6, S = 192, T = 52 ( 39 A + 13 D) ~12 KB
5 kx # k = 9, c = 5, S = 160, T = 54 ( 45 A + 9 D) ~10 KB
5 kx ecc-secp224r1.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) secp224r1 16 7 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx # Some reasonable choices for 256:
5 kx # k = 9, c = 6, S = 320, T = 54 ( 45 A + 9 D) 20 KB
5 kx # k = 11, c = 6, S = 256, T = 55 ( 44 A + 11 D) 16 KB
5 kx # k = 19, c = 7, S = 256, T = 57 ( 38 A + 19 D) 16 KB
5 kx # k = 15, c = 6, S = 192, T = 60 ( 45 A + 15 D) 12 KB
5 kx ecc-secp256r1.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) secp256r1 11 6 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx # Some reasonable choices for 384:
5 kx # k = 16, c = 6, S = 256, T = 80 ( 64 A + 16 D) 24 KB
5 kx # k = 28, c = 7, S = 256, T = 84 ( 56 A + 28 D) 24 KB
5 kx # k = 11, c = 5, S = 224, T = 88 ( 77 A + 11 D) 21 KB
5 kx # k = 22, c = 6, S = 192, T = 88 ( 66 A + 22 D) 18 KB
5 kx # k = 13, c = 5, S = 192, T = 91 ( 78 A + 13 D) 18 KB
5 kx # k = 16, c = 5, S = 160, T = 96 ( 80 A + 16 D) 15 KB
5 kx # k = 32, c = 6, S = 128, T = 96 ( 64 A + 32 D) 12 KB
5 kx ecc-secp384r1.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) secp384r1 32 6 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx # Some reasonable choices for 521:
5 kx # k = 29, c = 6, S = 192, T = 116 ( 87 A + 29 D) ~27 KB
5 kx # k = 21, c = 5, S = 160, T = 126 (105 A + 21 D) ~23 KB
5 kx # k = 44, c = 6, S = 128, T = 132 ( 88 A + 44 D) ~18 KB
5 kx # k = 35, c = 5, S = 96, T = 140 (105 A + 35 D) ~14 KB
5 kx ecc-secp521r1.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) secp521r1 44 6 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx # Parameter choices mostly the same as for ecc-secp256r1.h.
5 kx ecc-curve25519.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) curve25519 11 6 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx ecc-curve448.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) curve448 38 6 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx # Some reasonable choices for 256:
5 kx # k = 9, c = 6, S = 320, T = 54 ( 45 A + 9 D) 20 KB
5 kx # k = 11, c = 6, S = 256, T = 55 ( 44 A + 11 D) 16 KB
5 kx # k = 19, c = 7, S = 256, T = 57 ( 38 A + 19 D) 16 KB
5 kx # k = 15, c = 6, S = 192, T = 60 ( 45 A + 15 D) 12 KB
5 kx ecc-gost-gc256b.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) gost_gc256b 11 6 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx # Some reasonable choices for 512:
5 kx # k = 22, c = 6, S = 256, T = 110 ( 88 A + 22 D) 32 KB
5 kx # k = 29, c = 6, S = 192, T = 116 ( 87 A + 29 D) 24 KB
5 kx # k = 21, c = 5, S = 160, T = 126 (105 A + 21 D) 20 KB
5 kx # k = 43, c = 6, S = 128, T = 129 ( 86 A + 43 D) 16 KB
5 kx # k = 35, c = 5, S = 96, T = 140 (105 A + 35 D) 12 KB
5 kx ecc-gost-gc512a.h: eccdata.stamp
5 kx ./eccdata$(EXEEXT_FOR_BUILD) gost_gc512a 43 6 $(NUMB_BITS) > $@T && mv $@T $@
5 kx
5 kx eccdata.stamp: eccdata.c
5 kx $(MAKE) eccdata$(EXEEXT_FOR_BUILD) && echo stamp > eccdata.stamp
5 kx
5 kx ecc-curve25519.$(OBJEXT): ecc-curve25519.h
5 kx ecc-curve448.$(OBJEXT): ecc-curve448.h
5 kx ecc-gost-gc256b.$(OBJEXT): ecc-gost-gc256b.h
5 kx ecc-gost-gc512a.$(OBJEXT): ecc-gost-gc512a.h
5 kx ecc-secp192r1.$(OBJEXT): ecc-secp192r1.h
5 kx ecc-secp224r1.$(OBJEXT): ecc-secp224r1.h
5 kx ecc-secp256r1.$(OBJEXT): ecc-secp256r1.h
5 kx ecc-secp384r1.$(OBJEXT): ecc-secp384r1.h
5 kx ecc-secp521r1.$(OBJEXT): ecc-secp521r1.h
5 kx
5 kx # Texinfo rules
5 kx %.info: %.texinfo
5 kx cd $(srcdir) && $(MAKEINFO) --output $@ `basename "$<"`
5 kx
5 kx %.html: %.texinfo
5 kx cd $(srcdir) && $(MAKEINFO) --html --no-split \
5 kx --output $@T `basename "$<"` \
5 kx && test -s $@T && mv -f $@T $@
5 kx
5 kx %.dvi: %.texinfo
5 kx cd $(srcdir) && texi2dvi -b `basename "$<"`
5 kx
5 kx %.ps: %.dvi
5 kx cd $(srcdir) && dvips -Ppdf -G0 -o `basename "$<" .dvi`.ps `basename "$<"`
5 kx
5 kx # Avoid rebuilding .dvi and .ps files when the .texinfo source is unchanged.
5 kx PS2PDFFLAGS=-dCompatibilityLevel=1.3 -dMAxSubsetPct=100 -dSubsetFonts=true -dEmbedAllFonts=true
5 kx %.pdf: %.texinfo
5 kx $(MAKE) `basename "$<" .texinfo`.ps
5 kx cd $(srcdir) && ps2pdf $(PS2PDFFLAGS) `basename "$<" .texinfo`.ps
5 kx
5 kx # Configure-related rules, mostly copied from the autoconf manual. No
5 kx # $(srcdir) prefixes on the targets, though.
5 kx
5 kx configure: configure.ac aclocal.m4
5 kx cd $(srcdir) && $(AUTOCONF)
5 kx
5 kx # autoheader might not change config.h.in, so touch a stamp file.
5 kx config.h.in: stamp-h.in
5 kx stamp-h.in: configure.ac aclocal.m4
5 kx cd $(srcdir) && $(AUTOHEADER)
5 kx echo timestamp > $(srcdir)/stamp-h.in
5 kx
5 kx config.status: configure
5 kx ./config.status --recheck
5 kx
5 kx config.h: stamp-h
5 kx stamp-h: config.h.in config.status
5 kx ./config.status config.h
5 kx echo timestamp > stamp-h
5 kx
5 kx Makefile: Makefile.in config.status
5 kx ./config.status $@
5 kx
5 kx config.make: config.make.in config.status
5 kx ./config.status $@
5 kx
5 kx config.m4: config.m4.in config.status
5 kx ./config.status $@
5 kx
5 kx nettle.pc: nettle.pc.in config.status
5 kx ./config.status $@
5 kx
5 kx hogweed.pc: hogweed.pc.in config.status
5 kx ./config.status $@
5 kx
5 kx version.h: version.h.in config.status
5 kx ./config.status $@
5 kx
5 kx # Installation
5 kx install-doc: @IF_DOCUMENTATION@ install-info
5 kx install-here: install-doc install-headers install-static install-pkgconfig \
5 kx @IF_SHARED@ install-shared-nettle @IF_HOGWEED@ install-shared-hogweed
5 kx
5 kx install-static: $(LIBTARGETS)
5 kx $(MKDIR_P) $(DESTDIR)$(libdir)
5 kx for f in $(LIBTARGETS); do \
5 kx $(INSTALL_DATA) $$f $(DESTDIR)$(libdir) ; \
5 kx done
5 kx
5 kx install-dll-nettle:
5 kx $(MKDIR_P) $(DESTDIR)$(bindir)
5 kx $(INSTALL_DATA) $(LIBNETTLE_FORLINK) $(DESTDIR)$(bindir)/$(LIBNETTLE_FORLINK)
5 kx
5 kx install-shared-nettle: $(LIBNETTLE_FORLINK) @IF_DLL@ install-dll-nettle
5 kx $(MKDIR_P) $(DESTDIR)$(libdir)
5 kx $(INSTALL_DATA) $(LIBNETTLE_FILE_SRC) $(DESTDIR)$(libdir)/$(LIBNETTLE_FILE)
5 kx [ -z "$(LIBNETTLE_SONAME)" ] \
5 kx || (cd $(DESTDIR)$(libdir) \
5 kx && rm -f $(LIBNETTLE_SONAME) $(LIBNETTLE_FORLINK) \
5 kx && $(LN_S) $(LIBNETTLE_FILE) $(LIBNETTLE_SONAME) \
5 kx && $(LN_S) $(LIBNETTLE_FILE) $(LIBNETTLE_FORLINK))
5 kx
5 kx install-dll-hogweed:
5 kx $(MKDIR_P) $(DESTDIR)$(bindir)
5 kx $(INSTALL_DATA) $(LIBHOGWEED_FORLINK) $(DESTDIR)$(bindir)/$(LIBHOGWEED_FORLINK)
5 kx
5 kx install-shared-hogweed: $(LIBHOGWEED_FORLINK) @IF_DLL@ install-dll-hogweed
5 kx $(MKDIR_P) $(DESTDIR)$(libdir)
5 kx $(INSTALL_DATA) $(LIBHOGWEED_FILE_SRC) $(DESTDIR)$(libdir)/$(LIBHOGWEED_FILE)
5 kx [ -z "$(LIBHOGWEED_SONAME)" ] \
5 kx || (cd $(DESTDIR)$(libdir) \
5 kx && rm -f $(LIBHOGWEED_SONAME) $(LIBHOGWEED_FORLINK) \
5 kx && $(LN_S) $(LIBHOGWEED_FILE) $(LIBHOGWEED_SONAME) \
5 kx && $(LN_S) $(LIBHOGWEED_FILE) $(LIBHOGWEED_FORLINK))
5 kx
5 kx # I'd like to use makes VPATH search to locate the files to be
5 kx # installed. But it seems most make programs don't set $<, $^, $? and
5 kx # friends for ordinary explicit rules.
5 kx
5 kx install-info: nettle.info
5 kx $(MKDIR_P) $(DESTDIR)$(infodir)
5 kx f=nettle.info ; \
5 kx [ -f $$f ] || f="$(srcdir)/$$f" ; \
5 kx $(INSTALL_DATA) "$$f" $(DESTDIR)$(infodir) ; \
5 kx if (install-info --version && \
5 kx install-info --version 2>&1 | sed 1q | grep -i -v debian) >/dev/null 2>&1; then \
5 kx install-info --info-dir="$(DESTDIR)$(infodir)" "$$f" ; \
5 kx else : ; fi
5 kx
5 kx # NOTE: I'd like to use $^, but that's a GNU extension. $? should be
5 kx # more portable, and equivalent for phony targets.
5 kx install-headers: $(INSTALL_HEADERS)
5 kx $(MKDIR_P) $(DESTDIR)$(includedir)/nettle
5 kx for f in $(INSTALL_HEADERS) ; do \
5 kx if [ -f "$$f" ] ; then \
5 kx $(INSTALL_DATA) "$$f" $(DESTDIR)$(includedir)/nettle ; \
5 kx else \
5 kx $(INSTALL_DATA) "$(srcdir)/$$f" $(DESTDIR)$(includedir)/nettle ; \
5 kx fi ; done
5 kx
5 kx install-pkgconfig: $(PKGCONFIG_FILES)
5 kx $(MKDIR_P) $(DESTDIR)$(pkgconfigdir)
5 kx for f in $(PKGCONFIG_FILES) ; do \
5 kx $(INSTALL_DATA) "$$f" $(DESTDIR)$(pkgconfigdir) ; \
5 kx done
5 kx
5 kx # Uninstall
5 kx uninstall-here: uninstall-info uninstall-headers uninstall-static \
5 kx uninstall-pkgconfig @IF_SHARED@ uninstall-shared
5 kx
5 kx uninstall-static:
5 kx for f in $(LIBTARGETS) ; do \
5 kx rm -f $(DESTDIR)$(libdir)/$$f ; \
5 kx done
5 kx
5 kx uninstall-headers:
5 kx for f in $(INSTALL_HEADERS) ; do \
5 kx rm -f $(DESTDIR)$(includedir)/nettle/$$f ; \
5 kx done
5 kx
5 kx uninstall-info:
5 kx if (install-info --version && \
5 kx install-info --version 2>&1 | sed 1q | grep -i -v debian) >/dev/null 2>&1; then \
5 kx install-info --info-dir="$(DESTDIR)$(infodir)" --remove "$(DESTDIR)$(infodir)"/nettle.info ; \
5 kx else : ; fi
5 kx -rm -f $(DESTDIR)$(infodir)/nettle.info
5 kx
5 kx # FIXME: Leaves the links around
5 kx uninstall-shared: uninstall-shared-nettle @IF_HOGWEED@ uninstall-shared-hogweed
5 kx
5 kx uninstall-dll-nettle:
5 kx rm -f $(DESTDIR)$(bindir)/$(LIBNETTLE_FORLINK)
5 kx
5 kx uninstall-shared-nettle: @IF_DLL@ uninstall-dll-nettle
5 kx rm -f $(DESTDIR)$(libdir)/$(LIBNETTLE_FILE)
5 kx [ -z "$(LIBNETTLE_SONAME)" ] \
5 kx || rm -f $(LIBNETTLE_SONAME) $(LIBNETTLE_FORLINK)
5 kx
5 kx uninstall-dll-hogweed:
5 kx rm -f $(DESTDIR)$(bindir)/$(LIBHOGWEED_FORLINK)
5 kx
5 kx uninstall-shared-hogweed: @IF_DLL@ uninstall-dll-hogweed
5 kx rm -f $(DESTDIR)$(libdir)/$(LIBHOGWEED_FILE)
5 kx [ -z "$(LIBHOGWEED_SONAME)" ] \
5 kx || rm -f $(LIBHOGWEED_SONAME) $(LIBHOGWEED_FORLINK)
5 kx
5 kx uninstall-pkgconfig:
5 kx for f in $(PKGCONFIG_FILES) ; do \
5 kx rm -f $(DESTDIR)$(pkgconfigdir)/$$f ; \
5 kx done
5 kx
5 kx # Distribution
5 kx distdir = $(PACKAGE_NAME)-$(PACKAGE_VERSION)
5 kx top_distdir = $(distdir)
5 kx
5 kx # NOTE: We should handle both absolute and relative $destdir.
5 kx
5 kx distdir: $(DISTFILES)
5 kx rm -rf "$(distdir)"
5 kx mkdir "$(distdir)"
5 kx set -e; for f in $(DISTFILES) ; do \
5 kx if [ -f "$$f" ] ; then cp "$$f" "$(distdir)" ; \
5 kx else cp "$(srcdir)/$$f" "$(distdir)" ; \
5 kx fi ; \
5 kx done
5 kx set -e; for d in sparc32 sparc64 x86 \
5 kx x86_64 x86_64/aesni x86_64/sha_ni x86_64/fat \
5 kx arm arm/neon arm/v6 arm/fat \
5 kx powerpc64 powerpc64/p7 powerpc64/p8 powerpc64/fat ; do \
5 kx mkdir "$(distdir)/$$d" ; \
5 kx find "$(srcdir)/$$d" -maxdepth 1 '(' -name '*.asm' -o -name '*.m4' -o -name README ')' \
5 kx -exec cp '{}' "$(distdir)/$$d" ';' ; \
5 kx done
5 kx set -e; for d in $(SUBDIRS); do \
5 kx sd="$(distdir)/$$d" ; \
5 kx mkdir "$$sd" && $(MAKE) -C $$d distdir="`cd $$sd && pwd`" $@ ; \
5 kx done
5 kx
5 kx dist: distdir
5 kx tar cf - $(distdir) | gzip -c >$(distdir).tar.gz
5 kx rm -rf $(distdir)
5 kx
5 kx rm_distcheck = test ! -d distcheck-tmp \
5 kx || { find distcheck-tmp -type d ! -perm -200 -exec chmod u+w {} ';' \
5 kx && rm -fr distcheck-tmp; };
5 kx
5 kx distcheck: dist
5 kx $(rm_distcheck)
5 kx mkdir distcheck-tmp
5 kx gzip -d < $(distdir).tar.gz \
5 kx | { cd distcheck-tmp && tar xf - && chmod -R a-w $(distdir) ; }
5 kx mkdir distcheck-tmp/build
5 kx mkdir distcheck-tmp/install
5 kx cd distcheck-tmp/build && ../$(distdir)/configure --prefix="`cd ../install && pwd`"
5 kx cd distcheck-tmp/build && $(MAKE)
5 kx cd distcheck-tmp/build && $(MAKE) check
5 kx cd distcheck-tmp/build && $(MAKE) install
5 kx cd distcheck-tmp/build && $(MAKE) uninstall
5 kx cd distcheck-tmp && find install -type f -print > leftover-install-files
5 kx @test `cat distcheck-tmp/leftover-install-files | wc -l` -le 1 \
5 kx || { echo "ERROR: files left after uninstall:" ; \
5 kx cat distcheck-tmp/leftover-install-files ; \
5 kx exit 1; }
5 kx chmod -R a-w distcheck-tmp/install
5 kx mkdir distcheck-tmp/destdir
5 kx destdir="`cd distcheck-tmp/destdir && pwd`" \
5 kx && cd distcheck-tmp/build \
5 kx && $(MAKE) install DESTDIR="$$destdir" \
5 kx && $(MAKE) uninstall DESTDIR="$$destdir"
5 kx cd distcheck-tmp && find destdir -type f -print > leftover-destdir-files
5 kx @test `cat distcheck-tmp/leftover-destdir-files | wc -l` -le 1 \
5 kx || { echo "ERROR: destdir files left after uninstall:" ; \
5 kx cat distcheck-tmp/leftover-destdir-files ; \
5 kx exit 1; }
5 kx cd distcheck-tmp/build && $(MAKE) dist
5 kx cd distcheck-tmp/build && rm *.gz
5 kx cd distcheck-tmp/build && $(MAKE) distclean
5 kx cd distcheck-tmp && find build -type f -print > leftover-build-files
5 kx @test `cat distcheck-tmp/leftover-build-files | wc -l` -eq 0 \
5 kx || { echo "ERROR: files left in build directory after distclean:" ; \
5 kx cat distcheck-tmp/leftover-build-files ; \
5 kx exit 1; }
5 kx $(rm_distcheck)
5 kx
5 kx clean-here:
5 kx -rm -f $(TARGETS) *.$(OBJEXT) *.$(OBJEXT).d *.s *.so *.dll *.a \
5 kx ecc-curve25519.h ecc-curve448.h \
5 kx ecc-gost-gc256b.h ecc-gost-gc512a.h \
5 kx ecc-secp192r1.h ecc-secp224r1.h ecc-secp256r1.h \
5 kx ecc-secp384r1.h ecc-secp521r1.h \
5 kx aesdata$(EXEEXT_FOR_BUILD) \
5 kx desdata$(EXEEXT_FOR_BUILD) \
5 kx twofishdata$(EXEEXT_FOR_BUILD) \
5 kx shadata$(EXEEXT_FOR_BUILD) \
5 kx gcmdata$(EXEEXT_FOR_BUILD) \
5 kx eccdata$(EXEEXT_FOR_BUILD) eccdata.stamp
5 kx -rm -rf .lib libnettle.stamp libhogweed.stamp
5 kx
5 kx distclean-here: clean-here
5 kx -rm -f config.h stamp-h config.log config.status machine.m4 \
5 kx config.make config.m4 Makefile version.h \
5 kx nettle.pc hogweed.pc libnettle.map libhogweed.map \
5 kx *.asm *.d
5 kx
5 kx maintainer-clean-here:
5 kx -rm -f $(DOCTARGETS) *.dvi *.ps
5 kx
5 kx tags-here:
5 kx etags -o $(srcdir)/TAGS $(srcdir)/*.c $(srcdir)/*.h
5 kx
5 kx DEP_FILES = $(SOURCES:.c=.$(OBJEXT).d)
5 kx -include $(DEP_FILES)