Add ARMv8/AArch32 Crypto Extension implemenation of SHA-256
[libgcrypt.git] / cipher / Makefile.am
1 # Makefile for cipher modules
2 # Copyright (C) 1998, 1999, 2000, 2001, 2002,
3 #               2003, 2009 Free Software Foundation, Inc.
4 #
5 # This file is part of Libgcrypt.
6 #
7 # Libgcrypt is free software; you can redistribute it and/or modify
8 # it under the terms of the GNU Lesser General Public License as
9 # published by the Free Software Foundation; either version 2.1 of
10 # the License, or (at your option) any later version.
11 #
12 # Libgcrypt is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 # GNU Lesser General Public License for more details.
16 #
17 # You should have received a copy of the GNU Lesser General Public
18 # License along with this program; if not, see <http://www.gnu.org/licenses/>.
19
20 # Process this file with automake to produce Makefile.in
21
22 # Need to include ../src in addition to top_srcdir because gcrypt.h is
23 # a built header.
24 AM_CPPFLAGS = -I../src -I$(top_srcdir)/src
25 AM_CFLAGS = $(GPG_ERROR_CFLAGS)
26
27 AM_CCASFLAGS = $(NOEXECSTACK_FLAGS)
28
29 EXTRA_DIST = gost-s-box.c
30
31 CLEANFILES = gost-s-box
32 DISTCLEANFILES = gost-sb.h
33
34 noinst_LTLIBRARIES = libcipher.la
35
36 GCRYPT_MODULES = @GCRYPT_CIPHERS@ @GCRYPT_PUBKEY_CIPHERS@ \
37                  @GCRYPT_DIGESTS@ @GCRYPT_KDFS@
38
39 libcipher_la_DEPENDENCIES = $(GCRYPT_MODULES)
40 libcipher_la_LIBADD = $(GCRYPT_MODULES)
41
42 libcipher_la_SOURCES = \
43 cipher.c cipher-internal.h \
44 cipher-cbc.c cipher-cfb.c cipher-ofb.c cipher-ctr.c cipher-aeswrap.c \
45 cipher-ccm.c cipher-cmac.c cipher-gcm.c cipher-gcm-intel-pclmul.c \
46 cipher-poly1305.c cipher-ocb.c \
47 cipher-selftest.c cipher-selftest.h \
48 pubkey.c pubkey-internal.h pubkey-util.c \
49 md.c \
50 mac.c mac-internal.h \
51 mac-hmac.c mac-cmac.c mac-gmac.c mac-poly1305.c \
52 poly1305.c poly1305-internal.h \
53 kdf.c kdf-internal.h \
54 hmac-tests.c \
55 bithelp.h  \
56 bufhelp.h  \
57 primegen.c  \
58 hash-common.c hash-common.h \
59 dsa-common.c rsa-common.c \
60 sha1.h
61
62 EXTRA_libcipher_la_SOURCES = \
63 arcfour.c arcfour-amd64.S \
64 blowfish.c blowfish-amd64.S blowfish-arm.S \
65 cast5.c cast5-amd64.S cast5-arm.S \
66 chacha20.c chacha20-sse2-amd64.S chacha20-ssse3-amd64.S chacha20-avx2-amd64.S \
67   chacha20-armv7-neon.S \
68 crc.c \
69   crc-intel-pclmul.c \
70 des.c des-amd64.S \
71 dsa.c \
72 elgamal.c \
73 ecc.c ecc-curves.c ecc-misc.c ecc-common.h \
74 ecc-ecdsa.c ecc-eddsa.c ecc-gost.c \
75 idea.c \
76 gost28147.c gost.h \
77 gostr3411-94.c \
78 md4.c \
79 md5.c \
80 poly1305-sse2-amd64.S poly1305-avx2-amd64.S poly1305-armv7-neon.S \
81 rijndael.c rijndael-internal.h rijndael-tables.h rijndael-aesni.c \
82   rijndael-padlock.c rijndael-amd64.S rijndael-arm.S rijndael-ssse3-amd64.c \
83 rmd160.c \
84 rsa.c \
85 salsa20.c salsa20-amd64.S salsa20-armv7-neon.S \
86 scrypt.c \
87 seed.c \
88 serpent.c serpent-sse2-amd64.S serpent-avx2-amd64.S serpent-armv7-neon.S \
89 sha1.c sha1-ssse3-amd64.S sha1-avx-amd64.S sha1-avx-bmi2-amd64.S \
90   sha1-armv7-neon.S sha1-armv8-aarch32-ce.S \
91 sha256.c sha256-ssse3-amd64.S sha256-avx-amd64.S sha256-avx2-bmi2-amd64.S \
92   sha256-armv8-aarch32-ce.S \
93 sha512.c sha512-ssse3-amd64.S sha512-avx-amd64.S sha512-avx2-bmi2-amd64.S \
94   sha512-armv7-neon.S sha512-arm.S \
95 keccak.c keccak_permute_32.h keccak_permute_64.h keccak-armv7-neon.S \
96 stribog.c \
97 tiger.c \
98 whirlpool.c whirlpool-sse2-amd64.S \
99 twofish.c twofish-amd64.S twofish-arm.S \
100 rfc2268.c \
101 camellia.c camellia.h camellia-glue.c camellia-aesni-avx-amd64.S \
102   camellia-aesni-avx2-amd64.S camellia-arm.S
103
104 gost28147.lo: gost-sb.h
105 gost-sb.h: gost-s-box
106         ./gost-s-box $@
107
108 gost-s-box: gost-s-box.c
109         $(CC_FOR_BUILD) -o $@ $(srcdir)/gost-s-box.c
110
111
112 if ENABLE_O_FLAG_MUNGING
113 o_flag_munging = sed -e 's/-O\([2-9s][2-9s]*\)/-O1/' -e 's/-Ofast/-O1/g'
114 else
115 o_flag_munging = cat
116 endif
117
118
119 # We need to lower the optimization for this module.
120 tiger.o: $(srcdir)/tiger.c
121         `echo $(COMPILE) -c $(srcdir)/tiger.c | $(o_flag_munging) `
122
123 tiger.lo: $(srcdir)/tiger.c
124         `echo $(LTCOMPILE) -c $(srcdir)/tiger.c | $(o_flag_munging) `