New ecc_mod_* functions, replacing ecc_modp_* and ecc_modq_*.
[gd/nettle] / Makefile.in
1 # Nettle Makefile
2
3 @SET_MAKE@
4
5 srcdir = @srcdir@
6 VPATH = @srcdir@
7
8 INSTALL = @INSTALL@
9 INSTALL_DATA = @INSTALL_DATA@
10 INSTALL_PROGRAM = @INSTALL_PROGRAM@
11 INSTALL_SCRIPT = @INSTALL_SCRIPT@
12 INSTALL_STRIP_PROGRAM = $(INSTALL_PROGRAM) -s
13 MKDIR_P = @MKDIR_P@
14
15 OPT_ASM_NETTLE_SOURCES = @OPT_ASM_NETTLE_SOURCES@
16 OPT_ASM_HOGWEED_SOURCES = @OPT_ASM_HOGWEED_SOURCES@
17
18 OPT_HOGWEED_SOURCES = @IF_MINI_GMP@ mini-gmp.c
19
20 SUBDIRS = tools testsuite examples
21
22 include config.make
23
24 # $(srcdir) is needed for includes in bignum.h.
25 PRE_CPPFLAGS = -I. -I$(srcdir)
26 EXTRA_CFLAGS = $(CCPIC)
27
28 # FIXME: Add configuration of LIBEXT?
29 LIBTARGETS = @IF_STATIC@ libnettle.a @IF_HOGWEED@ libhogweed.a
30 SHLIBTARGETS = @IF_SHARED@ $(LIBNETTLE_FORLINK) @IF_HOGWEED@ $(LIBHOGWEED_FORLINK)
31
32 getopt_SOURCES = getopt.c getopt1.c
33 getopt_TARGETS = $(getopt_SOURCES:.c=.$(OBJEXT))
34
35 internal_SOURCES = nettle-internal.c
36 internal_TARGETS = $(internal_SOURCES:.c=.$(OBJEXT))
37
38 TARGETS = aesdata$(EXEEXT_FOR_BUILD) desdata$(EXEEXT_FOR_BUILD) \
39           twofishdata$(EXEEXT_FOR_BUILD) shadata$(EXEEXT_FOR_BUILD) \
40           gcmdata$(EXEEXT_FOR_BUILD) \
41           $(getopt_TARGETS) $(internal_TARGETS) \
42           $(LIBTARGETS) $(SHLIBTARGETS)
43 IMPLICIT_TARGETS = @IF_DLL@ $(LIBNETTLE_FILE) $(LIBHOGWEED_FILE)
44
45 DOCTARGETS = @IF_DOCUMENTATION@ nettle.info nettle.html nettle.pdf
46
47 PKGCONFIG_FILES = nettle.pc @IF_HOGWEED@ hogweed.pc
48 pkgconfigdir = $(libdir)/pkgconfig
49
50 all check install uninstall:
51         $(MAKE) $@-here
52         set -e; for d in $(SUBDIRS); do \
53           echo "Making $@ in $$d" ; (cd $$d && $(MAKE) $@); done
54
55 clean distclean mostlyclean maintainer-clean tags:
56         set -e; for d in $(SUBDIRS); do \
57           echo "Making $@ in $$d" ; (cd $$d && $(MAKE) $@); done
58         $(MAKE) $@-here
59
60 check-here:
61         true
62
63 # FIXME: Remove. These targets aren't supported, but they are expected by the
64 # automake generated Makefiles in the lsh build.
65 dvi installcheck uninstallcheck:
66         true
67
68 all-here: $(TARGETS) $(DOCTARGETS)
69
70 nettle_SOURCES = aes-decrypt-internal.c aes-decrypt.c \
71                  aes-encrypt-internal.c aes-encrypt.c aes-encrypt-table.c \
72                  aes-invert-internal.c aes-set-key-internal.c \
73                  aes-set-encrypt-key.c aes-set-decrypt-key.c \
74                  aes128-set-encrypt-key.c aes128-set-decrypt-key.c \
75                  aes128-meta.c \
76                  aes192-set-encrypt-key.c aes192-set-decrypt-key.c \
77                  aes192-meta.c \
78                  aes256-set-encrypt-key.c aes256-set-decrypt-key.c \
79                  aes256-meta.c \
80                  arcfour.c arcfour-crypt.c \
81                  arctwo.c arctwo-meta.c blowfish.c \
82                  base16-encode.c base16-decode.c base16-meta.c \
83                  base64-encode.c base64-decode.c base64-meta.c \
84                  buffer.c buffer-init.c \
85                  camellia-crypt-internal.c camellia-table.c \
86                  camellia-absorb.c camellia-invert-key.c \
87                  camellia128-set-encrypt-key.c camellia128-crypt.c \
88                  camellia128-set-decrypt-key.c \
89                  camellia128-meta.c \
90                  camellia192-meta.c \
91                  camellia256-set-encrypt-key.c camellia256-crypt.c \
92                  camellia256-set-decrypt-key.c \
93                  camellia256-meta.c \
94                  cast128.c cast128-meta.c cbc.c \
95                  ccm.c ccm-aes128.c ccm-aes192.c ccm-aes256.c \
96                  chacha-crypt.c chacha-core-internal.c \
97                  chacha-poly1305.c chacha-poly1305-meta.c \
98                  chacha-set-key.c chacha-set-nonce.c \
99                  ctr.c des.c des3.c des-compat.c \
100                  eax.c eax-aes128.c eax-aes128-meta.c \
101                  gcm.c gcm-aes.c \
102                  gcm-aes128.c gcm-aes128-meta.c \
103                  gcm-aes192.c gcm-aes192-meta.c \
104                  gcm-aes256.c gcm-aes256-meta.c \
105                  gcm-camellia128.c gcm-camellia128-meta.c \
106                  gcm-camellia256.c gcm-camellia256-meta.c \
107                  gosthash94.c gosthash94-meta.c \
108                  hmac.c hmac-md5.c hmac-ripemd160.c hmac-sha1.c \
109                  hmac-sha224.c hmac-sha256.c hmac-sha384.c hmac-sha512.c \
110                  knuth-lfib.c \
111                  md2.c md2-meta.c md4.c md4-meta.c \
112                  md5.c md5-compress.c md5-compat.c md5-meta.c \
113                  memxor.c \
114                  nettle-meta-aeads.c nettle-meta-armors.c \
115                  nettle-meta-ciphers.c nettle-meta-hashes.c \
116                  pbkdf2.c pbkdf2-hmac-sha1.c pbkdf2-hmac-sha256.c \
117                  poly1305-aes.c poly1305-internal.c \
118                  realloc.c \
119                  ripemd160.c ripemd160-compress.c ripemd160-meta.c \
120                  salsa20-core-internal.c \
121                  salsa20-crypt.c salsa20r12-crypt.c salsa20-set-key.c \
122                  salsa20-set-nonce.c \
123                  salsa20-128-set-key.c salsa20-256-set-key.c \
124                  sha1.c sha1-compress.c sha1-meta.c \
125                  sha256.c sha256-compress.c sha224-meta.c sha256-meta.c \
126                  sha512.c sha512-compress.c sha384-meta.c sha512-meta.c \
127                  sha512-224-meta.c sha512-256-meta.c \
128                  sha3.c sha3-permute.c \
129                  sha3-224.c sha3-224-meta.c sha3-256.c sha3-256-meta.c \
130                  sha3-384.c sha3-384-meta.c sha3-512.c sha3-512-meta.c\
131                  serpent-set-key.c serpent-encrypt.c serpent-decrypt.c \
132                  serpent-meta.c \
133                  twofish.c twofish-meta.c \
134                  umac-nh.c umac-nh-n.c umac-l2.c umac-l3.c \
135                  umac-poly64.c umac-poly128.c umac-set-key.c \
136                  umac32.c umac64.c umac96.c umac128.c \
137                  write-be32.c write-le32.c write-le64.c \
138                  yarrow256.c yarrow_key_event.c
139
140 hogweed_SOURCES = sexp.c sexp-format.c \
141                   sexp-transport.c sexp-transport-format.c \
142                   bignum.c bignum-random.c bignum-random-prime.c \
143                   sexp2bignum.c \
144                   pkcs1.c pkcs1-encrypt.c pkcs1-decrypt.c \
145                   pkcs1-rsa-digest.c pkcs1-rsa-md5.c pkcs1-rsa-sha1.c \
146                   pkcs1-rsa-sha256.c pkcs1-rsa-sha512.c \
147                   rsa.c rsa-sign.c rsa-verify.c \
148                   rsa-pkcs1-sign.c rsa-pkcs1-sign-tr.c rsa-pkcs1-verify.c \
149                   rsa-md5-sign.c rsa-md5-verify.c \
150                   rsa-sha1-sign.c rsa-sha1-verify.c \
151                   rsa-sha256-sign.c rsa-sha256-verify.c \
152                   rsa-sha512-sign.c rsa-sha512-verify.c \
153                   rsa-encrypt.c rsa-decrypt.c rsa-decrypt-tr.c \
154                   rsa-keygen.c rsa-blind.c \
155                   rsa2sexp.c sexp2rsa.c \
156                   dsa.c dsa-compat.c dsa-compat-keygen.c dsa-gen-params.c \
157                   dsa-sign.c dsa-verify.c dsa-keygen.c dsa-hash.c \
158                   dsa-sha1-sign.c dsa-sha1-verify.c \
159                   dsa-sha256-sign.c dsa-sha256-verify.c  \
160                   dsa2sexp.c sexp2dsa.c \
161                   pgp-encode.c rsa2openpgp.c \
162                   der-iterator.c der2rsa.c der2dsa.c \
163                   sec-add-1.c sec-sub-1.c sec-tabselect.c \
164                   gmp-glue.c cnd-copy.c \
165                   ecc-mod.c ecc-mod-inv.c \
166                   ecc-mod-arith.c ecc-pp1-redc.c ecc-pm1-redc.c \
167                   ecc-192.c ecc-224.c ecc-256.c ecc-384.c ecc-521.c \
168                   ecc-25519.c \
169                   ecc-size.c ecc-j-to-a.c ecc-a-to-j.c \
170                   ecc-dup-jj.c ecc-add-jja.c ecc-add-jjj.c \
171                   ecc-eh-to-a.c \
172                   ecc-dup-eh.c ecc-add-eh.c ecc-add-ehh.c \
173                   ecc-mul-g-eh.c ecc-mul-a-eh.c \
174                   ecc-mul-g.c ecc-mul-a.c ecc-hash.c ecc-random.c \
175                   ecc-point.c ecc-scalar.c ecc-point-mul.c ecc-point-mul-g.c \
176                   ecc-ecdsa-sign.c ecdsa-sign.c \
177                   ecc-ecdsa-verify.c ecdsa-verify.c ecdsa-keygen.c \
178                   curve25519-mul-g.c curve25519-mul.c curve25519-eh-to-x.c \
179                   $(OPT_HOGWEED_SOURCES)
180
181 HEADERS = aes.h arcfour.h arctwo.h asn1.h blowfish.h \
182           base16.h base64.h buffer.h camellia.h cast128.h \
183           cbc.h ccm.h chacha.h chacha-poly1305.h ctr.h \
184           curve25519.h des.h des-compat.h dsa.h dsa-compat.h eax.h \
185           ecc-curve.h ecc.h ecdsa.h \
186           gcm.h gosthash94.h hmac.h \
187           knuth-lfib.h \
188           macros.h \
189           md2.h md4.h \
190           md5.h md5-compat.h \
191           memxor.h \
192           nettle-meta.h nettle-types.h \
193           pbkdf2.h \
194           pgp.h pkcs1.h realloc.h ripemd160.h rsa.h \
195           salsa20.h sexp.h \
196           serpent.h sha.h sha1.h sha2.h sha3.h twofish.h \
197           umac.h yarrow.h poly1305.h
198
199 INSTALL_HEADERS = $(HEADERS) nettle-stdint.h bignum.h @IF_MINI_GMP@ mini-gmp.h
200
201 SOURCES = $(nettle_SOURCES) $(hogweed_SOURCES) \
202           $(getopt_SOURCES) $(internal_SOURCES) \
203           aesdata.c desdata.c twofishdata.c shadata.c gcmdata.c eccdata.c
204
205 DISTFILES = $(SOURCES) $(HEADERS) getopt.h getopt_int.h \
206         .bootstrap run-tests \
207         aclocal.m4 configure.ac \
208         configure stamp-h.in bignum.h.in \
209         config.guess config.sub install-sh texinfo.tex \
210         config.h.in config.m4.in config.make.in Makefile.in \
211         README AUTHORS COPYING.LESSERv3 COPYINGv2 COPYINGv3 \
212         INSTALL NEWS TODO ChangeLog \
213         nettle.pc.in hogweed.pc.in \
214         $(des_headers) descore.README \
215         aes-internal.h camellia-internal.h serpent-internal.h \
216         cast128_sboxes.h desinfo.h desCode.h \
217         nettle-internal.h nettle-write.h \
218         gmp-glue.h ecc-internal.h \
219         mini-gmp.h mini-gmp.c asm.m4 \
220         nettle.texinfo nettle.info nettle.html nettle.pdf sha-example.c
221
222 # Rules building static libraries
223 nettle_OBJS = $(nettle_SOURCES:.c=.$(OBJEXT)) $(OPT_ASM_NETTLE_SOURCES:.asm=.$(OBJEXT))
224
225 hogweed_OBJS = $(hogweed_SOURCES:.c=.$(OBJEXT)) $(OPT_ASM_HOGWEED_SOURCES:.asm=.$(OBJEXT))
226
227 libnettle.a: $(nettle_OBJS)
228         -rm -f $@
229         $(AR) $(ARFLAGS) $@ $(nettle_OBJS)
230         $(RANLIB) $@
231         echo nettle > libnettle.stamp
232
233 libhogweed.a: $(hogweed_OBJS)
234         -rm -f $@
235         $(AR) $(ARFLAGS) $@ $(hogweed_OBJS)
236         $(RANLIB) $@
237         echo hogweed > libhogweed.stamp
238
239 .c.$(OBJEXT):
240         $(COMPILE) -c $< \
241         && $(DEP_PROCESS)
242
243 # Rules building shared libraries.
244 $(LIBNETTLE_FORLINK): $(nettle_OBJS)
245         $(LIBNETTLE_LINK) $(nettle_OBJS) -o $@ $(LIBNETTLE_LIBS)
246         -mkdir .lib 2>/dev/null
247         (cd .lib \
248           && rm -f $(LIBNETTLE_FORLINK) \
249           && $(LN_S) ../$(LIBNETTLE_FORLINK) $(LIBNETTLE_FORLINK) \
250           && [ -z "$(LIBNETTLE_SONAME)" ] \
251           || { rm -f $(LIBNETTLE_SONAME) \
252                && $(LN_S) $(LIBNETTLE_FORLINK) $(LIBNETTLE_SONAME) ; } )
253         echo nettle > libnettle.stamp
254
255 $(LIBHOGWEED_FORLINK): $(hogweed_OBJS) $(LIBNETTLE_FORLINK)
256         $(LIBHOGWEED_LINK) $(hogweed_OBJS) -o $@ $(LIBHOGWEED_LIBS)
257         -mkdir .lib 2>/dev/null
258         (cd .lib \
259           && rm -f $(LIBHOGWEED_FORLINK) \
260           && $(LN_S) ../$(LIBHOGWEED_FORLINK) $(LIBHOGWEED_FORLINK) \
261           && [ -z "$(LIBHOGWEED_SONAME)" ] \
262           || { rm -f $(LIBHOGWEED_SONAME) \
263                && $(LN_S) $(LIBHOGWEED_FORLINK) $(LIBHOGWEED_SONAME) ; } )
264         echo hogweed > libhogweed.stamp
265
266 # For Solaris and BSD make, we have to use an explicit rule for each
267 # executable. Avoid object file targets to make it easy to run the
268 # right compiler.
269 aesdata$(EXEEXT_FOR_BUILD): aesdata.c
270         $(CC_FOR_BUILD) `test -f aesdata.c || echo '$(srcdir)/'`aesdata.c \
271         -o aesdata$(EXEEXT_FOR_BUILD)
272
273 desdata$(EXEEXT_FOR_BUILD): desdata.c
274         $(CC_FOR_BUILD) `test -f desdata.c || echo '$(srcdir)/'`desdata.c \
275         -o desdata$(EXEEXT_FOR_BUILD)
276
277 twofishdata$(EXEEXT_FOR_BUILD): twofishdata.c
278         $(CC_FOR_BUILD) `test -f twofishdata.c || echo '$(srcdir)/'`twofishdata.c \
279         -o twofishdata$(EXEEXT_FOR_BUILD)
280
281 shadata$(EXEEXT_FOR_BUILD): shadata.c
282         $(CC_FOR_BUILD) `test -f shadata.c || echo '$(srcdir)/'`shadata.c -lm \
283         -o shadata$(EXEEXT_FOR_BUILD)
284
285 gcmdata$(EXEEXT_FOR_BUILD): gcmdata.c
286         $(CC_FOR_BUILD) `test -f gcmdata.c || echo '$(srcdir)/'`gcmdata.c \
287         -o gcmdata$(EXEEXT_FOR_BUILD)
288
289 eccdata$(EXEEXT_FOR_BUILD): eccdata.c mini-gmp.c mini-gmp.h
290         $(CC_FOR_BUILD) `test -f eccdata.c || echo '$(srcdir)/'`eccdata.c \
291         -o eccdata$(EXEEXT_FOR_BUILD)
292
293 # desCore rules
294 # It seems using $(srcdir)/ doesn't work with GNU make 3.79.1
295 # des_headers = $(srcdir)/rotors.h $(srcdir)/keymap.h 
296 des_headers = rotors.h keymap.h 
297
298 # Generate DES headers.
299 $(des_headers): desdata.c
300         $(MAKE) desdata$(EXEEXT_FOR_BUILD)
301         f="$(srcdir)/`basename $@`"; \
302           ./desdata$(EXEEXT_FOR_BUILD) $(@F) > $${f}T; \
303           test -s $${f}T && mv -f $${f}T $$f
304
305 des.$(OBJEXT): des.c des.h $(des_headers)
306
307 # Generate ECC files.
308 # Some possible choices for 192:
309 #       k = 15, c = 4,  64 entries,  ~3 KB
310 #       k = 20, c = 6, 128 entries,  ~6 KB
311 #       k = 10, c = 6, 256 entries, ~12 KB
312 #       k =  7, c = 6, 320 entries, ~15 KB
313 #       k =  9, c = 7, 512 entries, ~24 KB
314 ecc-192.h: eccdata.stamp
315         ./eccdata$(EXEEXT_FOR_BUILD) 192 7 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
316 # Some possible choices for 224:
317 #       k = 18, c = 4,  64 entries,  ~4 KB
318 #       k = 24, c = 6, 128 entries,  ~8 KB
319 #       k = 12, c = 6, 256 entries, ~16 KB
320 #       k =  8, c = 6, 320 entries, ~20 KB
321 #       k = 10, c = 7, 512 entries, ~32 KB
322 ecc-224.h: eccdata.stamp
323         ./eccdata$(EXEEXT_FOR_BUILD) 224 12 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
324 # Some possible choices for 256:
325 #       k = 20, c = 4,  64 entries,  ~4 KB
326 #       k = 27, c = 6, 128 entries,  ~8 KB
327 #       k = 14, c = 6, 256 entries, ~16 KB
328 #       k =  9, c = 6, 320 entries, ~20 KB
329 #       k = 12, c = 7, 512 entries, ~32 KB
330 ecc-256.h: eccdata.stamp
331         ./eccdata$(EXEEXT_FOR_BUILD) 256 14 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
332 # Some possible choices for 384:
333 #       k = 31, c = 4,  64 entries,  ~6 KB
334 #       k = 41, c = 6, 128 entries, ~12 KB
335 #       k = 20, c = 6, 256 entries, ~24 KB
336 #       k = 14, c = 6, 320 entries, ~30 KB
337 #       k = 18, c = 7, 512 entries, ~48 KB
338 ecc-384.h: eccdata.stamp
339         ./eccdata$(EXEEXT_FOR_BUILD) 384 41 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
340 # Some possible choices for 521:
341 #       k = 42, c = 4,  64 entries,  ~9 KB
342 #       k = 56, c = 6, 128 entries, ~18 KB
343 #       k = 28, c = 6, 256 entries, ~35 KB
344 #       k = 19, c = 6, 320 entries, ~44 KB
345 #       k = 24, c = 7, 512 entries, ~70 KB
346 ecc-521.h: eccdata.stamp
347         ./eccdata$(EXEEXT_FOR_BUILD) 521 56 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
348
349 ecc-25519.h: eccdata.stamp
350         ./eccdata$(EXEEXT_FOR_BUILD) 255 14 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
351
352 eccdata.stamp: eccdata.c
353         $(MAKE) eccdata$(EXEEXT_FOR_BUILD)
354         echo stamp > eccdata.stamp
355
356 ecc-192.$(OBJEXT): ecc-192.h
357 ecc-224.$(OBJEXT): ecc-224.h
358 ecc-256.$(OBJEXT): ecc-256.h
359 ecc-384.$(OBJEXT): ecc-384.h
360 ecc-521.$(OBJEXT): ecc-521.h
361 ecc-25519.$(OBJEXT): ecc-25519.h
362
363 .asm.$(OBJEXT): $(srcdir)/asm.m4 machine.m4 config.m4
364         $(M4) $(srcdir)/asm.m4 machine.m4 config.m4 $< >$*.s
365         $(COMPILE) -c $*.s
366         @echo "$@ : $< $(srcdir)/asm.m4 machine.m4 config.m4" >$@.d 
367
368 # Texinfo rules
369 .texinfo.info:
370         cd $(srcdir) && $(MAKEINFO) --output $@ `basename "$<"`
371
372 .texinfo.html:
373         cd $(srcdir) && $(MAKEINFO) --html --no-split \
374           --output $@T `basename "$<"` \
375           && test -s $@T && mv -f $@T $@
376
377 .texinfo.dvi:
378         cd $(srcdir) && texi2dvi -b `basename "$<"`
379
380 .dvi.ps:
381         cd $(srcdir) && dvips -Ppdf -G0 -o `basename "$<" .dvi`.ps `basename "$<"`
382
383 # Avoid rebuilding .dvi and .ps files when the .texinfo source is unchanged.
384 PS2PDFFLAGS=-dCompatibilityLevel=1.3 -dMAxSubsetPct=100 -dSubsetFonts=true -dEmbedAllFonts=true
385 .texinfo.pdf:
386         $(MAKE) `basename "$<" .texinfo`.ps
387         cd $(srcdir) && ps2pdf $(PS2PDFFLAGS) `basename "$<" .texinfo`.ps
388
389 # Configure-related rules, mostly copied from the autoconf manual. No
390 # $(srcdir) prefixes on the targets, though.
391
392 configure: configure.ac aclocal.m4
393         cd $(srcdir) && $(AUTOCONF)
394
395 # autoheader might not change config.h.in, so touch a stamp file.
396 config.h.in: stamp-h.in
397 stamp-h.in: configure.ac aclocal.m4
398         cd $(srcdir) && $(AUTOHEADER)
399         echo timestamp > $(srcdir)/stamp-h.in
400
401 config.status: configure
402         ./config.status --recheck
403
404 config.h: stamp-h
405 stamp-h: config.h.in config.status
406         ./config.status config.h
407         echo timestamp > stamp-h
408
409 bignum.h: bignum.h.in config.status
410         ./config.status $@
411
412 Makefile: Makefile.in config.status
413         ./config.status $@
414
415 config.make: config.make.in config.status
416         ./config.status $@
417
418 config.m4: config.m4.in config.status
419         ./config.status $@
420
421 nettle.pc: nettle.pc.in config.status
422         ./config.status $@
423
424 hogweed.pc: hogweed.pc.in config.status
425         ./config.status $@
426
427 # Installation
428 install-doc: @IF_DOCUMENTATION@ install-info
429 install-here: install-doc install-headers install-static install-pkgconfig \
430         @IF_SHARED@ install-shared-nettle @IF_HOGWEED@ install-shared-hogweed
431
432 install-static: $(LIBTARGETS)
433         $(MKDIR_P) $(DESTDIR)$(libdir)
434         for f in $(LIBTARGETS); do \
435           $(INSTALL_DATA) $$f $(DESTDIR)$(libdir) ; \
436         done
437
438 install-dll-nettle:
439         $(MKDIR_P) $(DESTDIR)$(bindir)
440         $(INSTALL_DATA) $(LIBNETTLE_FORLINK) $(DESTDIR)$(bindir)/$(LIBNETTLE_FORLINK)
441
442 install-shared-nettle: $(LIBNETTLE_FORLINK) @IF_DLL@ install-dll-nettle
443         $(MKDIR_P) $(DESTDIR)$(libdir)
444         $(INSTALL_DATA) $(LIBNETTLE_FILE_SRC) $(DESTDIR)$(libdir)/$(LIBNETTLE_FILE)
445         [ -z "$(LIBNETTLE_SONAME)" ] \
446                 || (cd $(DESTDIR)$(libdir) \
447                 && rm -f $(LIBNETTLE_SONAME) $(LIBNETTLE_FORLINK) \
448                 && $(LN_S) $(LIBNETTLE_FILE) $(LIBNETTLE_SONAME) \
449                 && $(LN_S) $(LIBNETTLE_FILE) $(LIBNETTLE_FORLINK))
450
451 install-dll-hogweed:
452         $(MKDIR_P) $(DESTDIR)$(bindir)
453         $(INSTALL_DATA) $(LIBHOGWEED_FORLINK) $(DESTDIR)$(bindir)/$(LIBHOGWEED_FORLINK)
454
455 install-shared-hogweed: $(LIBHOGWEED_FORLINK) @IF_DLL@ install-dll-hogweed
456         $(MKDIR_P) $(DESTDIR)$(libdir)
457         $(INSTALL_DATA) $(LIBHOGWEED_FILE_SRC) $(DESTDIR)$(libdir)/$(LIBHOGWEED_FILE)
458         [ -z "$(LIBHOGWEED_SONAME)" ] \
459                 || (cd $(DESTDIR)$(libdir) \
460                 && rm -f $(LIBHOGWEED_SONAME) $(LIBHOGWEED_FORLINK) \
461                 && $(LN_S) $(LIBHOGWEED_FILE) $(LIBHOGWEED_SONAME) \
462                 && $(LN_S) $(LIBHOGWEED_FILE) $(LIBHOGWEED_FORLINK))
463
464 # I'd like to use makes VPATH search to locate the files to be
465 # installed. But it seems most make programs don't set $<, $^, $? and
466 # friends for ordinary explicit rules.
467
468 install-info: nettle.info
469         $(MKDIR_P) $(DESTDIR)$(infodir)
470         f=nettle.info ; \
471         [ -f $$f ] || f="$(srcdir)/$$f" ; \
472         $(INSTALL_DATA) "$$f" $(DESTDIR)$(infodir) ; \
473         if (install-info --version && \
474             install-info --version 2>&1 | sed 1q | grep -i -v debian) >/dev/null 2>&1; then \
475           install-info --info-dir="$(DESTDIR)$(infodir)" "$$f" ; \
476         else : ; fi
477
478 # NOTE: I'd like to use $^, but that's a GNU extension. $? should be
479 # more portable, and equivalent for phony targets.
480 install-headers: $(INSTALL_HEADERS)
481         $(MKDIR_P) $(DESTDIR)$(includedir)/nettle
482         for f in $(INSTALL_HEADERS) ; do \
483           if [ -f "$$f" ] ; then \
484             $(INSTALL_DATA) "$$f" $(DESTDIR)$(includedir)/nettle ; \
485           else \
486             $(INSTALL_DATA) "$(srcdir)/$$f" $(DESTDIR)$(includedir)/nettle ; \
487           fi ; done
488
489 install-pkgconfig: $(PKGCONFIG_FILES)
490         $(MKDIR_P) $(DESTDIR)$(pkgconfigdir)
491         for f in $(PKGCONFIG_FILES) ; do \
492           $(INSTALL_DATA) "$$f" $(DESTDIR)$(pkgconfigdir) ; \
493         done
494
495 # Uninstall
496 uninstall-here: uninstall-info uninstall-headers uninstall-static \
497                 uninstall-pkgconfig @IF_SHARED@ uninstall-shared
498
499 uninstall-static:
500         for f in $(LIBTARGETS) ; do \
501           rm -f $(DESTDIR)$(libdir)/$$f ; \
502         done
503
504 uninstall-headers:
505         for f in $(INSTALL_HEADERS) ; do \
506           rm -f $(DESTDIR)$(includedir)/nettle/$$f ; \
507         done
508
509 uninstall-info:
510         if (install-info --version && \
511             install-info --version 2>&1 | sed 1q | grep -i -v debian) >/dev/null 2>&1; then \
512           install-info --info-dir="$(DESTDIR)$(infodir)" --remove "$(DESTDIR)$(infodir)"/nettle.info ; \
513         else : ; fi
514         -rm -f $(DESTDIR)$(infodir)/nettle.info
515
516 # FIXME: Leaves the links around
517 uninstall-shared: uninstall-shared-nettle @IF_HOGWEED@ uninstall-shared-hogweed
518
519 uninstall-dll-nettle:
520         rm -f $(DESTDIR)$(bindir)/$(LIBNETTLE_FORLINK)
521
522 uninstall-shared-nettle: @IF_DLL@ uninstall-dll-nettle
523         rm -f $(DESTDIR)$(libdir)/$(LIBNETTLE_FILE)
524         [ -z "$(LIBNETTLE_SONAME)" ] \
525                 || rm -f $(LIBNETTLE_SONAME) $(LIBNETTLE_FORLINK)
526
527 uninstall-dll-hogweed:
528         rm -f $(DESTDIR)$(bindir)/$(LIBHOGWEED_FORLINK)
529
530 uninstall-shared-hogweed: @IF_DLL@ uninstall-dll-hogweed
531         rm -f $(DESTDIR)$(libdir)/$(LIBHOGWEED_FILE)
532         [ -z "$(LIBHOGWEED_SONAME)" ] \
533                 || rm -f $(LIBHOGWEED_SONAME) $(LIBHOGWEED_FORLINK)
534
535 uninstall-pkgconfig:
536         for f in $(PKGCONFIG_FILES) ; do \
537           rm -f $(DESTDIR)$(pkgconfigdir)/$$f ; \
538         done
539
540 # Distribution
541 distdir = $(PACKAGE_NAME)-$(PACKAGE_VERSION)
542 top_distdir = $(distdir)
543
544 # NOTE: We should handle both absolute and relative $destdir.
545
546 distdir: $(DISTFILES)
547         rm -rf "$(distdir)"
548         mkdir "$(distdir)"
549         set -e; for f in $(DISTFILES) ; do \
550           if [ -f "$$f" ] ; then cp "$$f" "$(distdir)" ; \
551           else cp "$(srcdir)/$$f" "$(distdir)" ; \
552           fi ; \
553         done
554         set -e; for d in sparc32 sparc64 x86 x86_64 arm arm/neon arm/v6 ; do \
555           mkdir "$(distdir)/$$d" ; \
556           find "$(srcdir)/$$d" -maxdepth 1 '(' -name '*.asm' -o -name '*.m4' ')' \
557             -exec cp '{}' "$(distdir)/$$d" ';' ; \
558         done
559         set -e; for d in $(SUBDIRS); do \
560           sd="$(distdir)/$$d" ; \
561           mkdir "$$sd" && $(MAKE) -C $$d distdir="`cd $$sd && pwd`" $@ ; \
562         done
563
564 dist: distdir
565         tar cf - $(distdir) | gzip -c >$(distdir).tar.gz        
566         rm -rf $(distdir)
567
568 rm_distcheck = test ! -d distcheck-tmp \
569             || { find distcheck-tmp -type d ! -perm -200 -exec chmod u+w {} ';' \
570                  && rm -fr distcheck-tmp; }; 
571
572 distcheck: dist
573         $(rm_distcheck)
574         mkdir distcheck-tmp
575         gzip -d < $(distdir).tar.gz \
576           | { cd distcheck-tmp && tar xf - && chmod -R a-w $(distdir) ; }
577         mkdir distcheck-tmp/build
578         mkdir distcheck-tmp/install
579         cd distcheck-tmp/build && ../$(distdir)/configure --prefix="`cd ../install && pwd`"
580         cd distcheck-tmp/build && $(MAKE)
581         cd distcheck-tmp/build && $(MAKE) check
582         cd distcheck-tmp/build && $(MAKE) install
583         cd distcheck-tmp/build && $(MAKE) uninstall
584         cd distcheck-tmp && find install -type f -print > leftover-install-files
585         @test `cat distcheck-tmp/leftover-install-files | wc -l` -le 1  \
586           || { echo "ERROR: files left after uninstall:" ; \
587                cat distcheck-tmp/leftover-install-files ; \
588                exit 1; }
589         chmod -R a-w distcheck-tmp/install
590         mkdir distcheck-tmp/destdir
591         destdir="`cd distcheck-tmp/destdir && pwd`" \
592           && cd distcheck-tmp/build \
593           && $(MAKE) install DESTDIR="$$destdir" \
594           && $(MAKE) uninstall DESTDIR="$$destdir"
595         cd distcheck-tmp && find destdir -type f -print > leftover-destdir-files
596         @test `cat distcheck-tmp/leftover-destdir-files | wc -l` -le 1  \
597           || { echo "ERROR: destdir files left after uninstall:" ; \
598                cat distcheck-tmp/leftover-destdir-files ; \
599                exit 1; }        
600         cd distcheck-tmp/build && $(MAKE) dist
601         cd distcheck-tmp/build && rm *.gz
602         cd distcheck-tmp/build && $(MAKE) distclean
603         cd distcheck-tmp && find build -type f -print > leftover-build-files
604         @test `cat distcheck-tmp/leftover-build-files | wc -l` -eq 0  \
605           || { echo "ERROR: files left in build directory after distclean:" ; \
606                cat distcheck-tmp/leftover-build-files ; \
607                exit 1; }
608         $(rm_distcheck)
609
610 clean-here:
611         -rm -f $(TARGETS) $(IMPLICIT_TARGETS) *.$(OBJEXT) *.s \
612                 ecc-192.h ecc-224.h ecc-256.h ecc-384.h ecc-521.h ecc-25519.h \
613                 eccdata$(EXEEXT_FOR_BUILD) eccdata.stamp
614         -rm -rf .lib libnettle.stamp libhogweed.stamp
615
616 distclean-here: clean-here
617         -rm -f config.h stamp-h config.log config.status machine.m4 \
618         config.make config.m4 Makefile nettle-stdint.h bignum.h \
619         nettle.pc hogweed.pc \
620         *.asm *.d
621
622 maintainer-clean-here:
623         -rm -f $(DOCTARGETS) *.dvi *.ps
624
625 tags-here:      
626         etags -o $(srcdir)/TAGS $(srcdir)/*.c $(srcdir)/*.h
627
628 DEP_FILES = $(SOURCES:.c=.$(OBJEXT).d)
629 @DEP_INCLUDE@ $(DEP_FILES)