Abandon the `m4'-based build system. And there was great rejoicing.
[u/mdw/catacomb] / Makefile.am
CommitLineData
7db733d4
MW
1### -*-makefile-*-
2###
3### Build script for Catacomb
4###
5### (c) 2013 Straylight/Edgeware
6###
7
8###----- Licensing notice ---------------------------------------------------
9###
10### This file is part of Catacomb.
11###
12### Catacomb is free software; you can redistribute it and/or modify
13### it under the terms of the GNU Library General Public License as
14### published by the Free Software Foundation; either version 2 of the
15### License, or (at your option) any later version.
16###
17### Catacomb is distributed in the hope that it will be useful,
18### but WITHOUT ANY WARRANTY; without even the implied warranty of
19### MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20### GNU Library General Public License for more details.
21###
22### You should have received a copy of the GNU Library General Public
23### License along with Catacomb; if not, write to the Free
24### Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
25### MA 02111-1307, USA.
26
27###--------------------------------------------------------------------------
28### Miscellaneous useful definitions.
29
30## Some convenient abbreviations for file suffixes.
31e = $(EXEEXT)
32o = $(OBJEXT)
33t = t$e
34
35## Installation directories.
36archincludedir = $(pkglibdir)/include
37
38###--------------------------------------------------------------------------
39### Initial values of common variables.
40
41SUBDIRS =
42
43EXTRA_DIST =
44CLEANFILES =
45DISTCLEANFILES =
46MAINTAINERCLEANFILES =
47SUFFIXES =
48TESTS =
49BUILT_SOURCES =
50
51bin_PROGRAMS =
52noinst_PROGRAMS =
53lib_LTLIBRARIES =
54noinst_LTLIBRARIES =
55pkginclude_HEADERS =
56nodist_pkginclude_HEADERS =
57archinclude_HEADERS =
58nodist_archinclude_HEADERS =
59dist_man_MANS =
60
61###--------------------------------------------------------------------------
62### Standard configuration substitutions.
63
64## Substitute tags in files.
65confsubst = $(top_srcdir)/confsubst
66EXTRA_DIST += confsubst
67
68SUBSTITUTIONS = \
69 prefix=$(prefix) exec_prefix=$(exec_prefix) \
70 libdir=$(libdir) includedir=$(includedir) \
71 PACKAGE=$(PACKAGE) VERSION=$(VERSION)
72
73V_SUBST = $(V_SUBST_$(V))
74V_SUBST_ = $(V_SUBST_$(AM_DEFAULT_VERBOSITY))
75V_SUBST_0 = @echo " SUBST $@";
76SUBST = $(V_SUBST)$(confsubst)
77
78###--------------------------------------------------------------------------
79### The main library.
80
81lib_LTLIBRARIES += libcatacomb.la
82libcatacomb_la_LIBADD = $(CATACOMB_LIBS)
83libcatacomb_la_LDFLAGS = -version-info $(LIBTOOL_VERSION_INFO)
84libcatacomb_la_SOURCES =
85nodist_libcatacomb_la_SOURCES =
86
87###--------------------------------------------------------------------------
88### Basic utilities.
89
90## The locked-memory arena.
91pkginclude_HEADERS += arena.h
92libcatacomb_la_SOURCES += arena.c
93
94## Constant-type operations.
95pkginclude_HEADERS += ct.h
96libcatacomb_la_SOURCES += ct.c
97
98## Acceptable key-size descriptions.
99pkginclude_HEADERS += keysz.h
100libcatacomb_la_SOURCES += keysz.c keysz-conv.c
101
102## System-level memory locking.
103pkginclude_HEADERS += lmem.h
104libcatacomb_la_SOURCES += lmem.c
105
106## Clearing secrets from memory.
107pkginclude_HEADERS += paranoia.h
108
109###--------------------------------------------------------------------------
110### Main multiprecision integer library.
111
112## This library is unfortunately intertwined with some of the code generation
113## programs, so we must be rather careful. The important bits of the maths
114## library needed by these programs is separated out into `libmpbase'. There
115## is work going on to fix this unpleasant situation by generating the
116## relevant files from Python scripts rather than C programs, using
117## information gathered by `configure'.
118noinst_LTLIBRARIES += libmpbase.la
119libcatacomb_la_LIBADD += libmpbase.la
120libmpbase_la_SOURCES =
121$(libmpbase_la_OBJECTS): mptypes.h
122
123## Additional buffer I/O functions for mathematical objects.
124pkginclude_HEADERS += buf.h
125libcatacomb_la_SOURCES += buf.c
126
127## Infrastructure for fast exponentiation.
128pkginclude_HEADERS += exp.h
129libcatacomb_la_SOURCES += exp.c
130
131## Main user-visible multiprecision arithmetic.
132pkginclude_HEADERS += mp.h
133libmpbase_la_SOURCES += mp-arith.c
134TESTS += mp-arith.$t
135libmpbase_la_SOURCES += mp-const.c
136libcatacomb_la_SOURCES += mp-exp.c mp-exp.h
137libcatacomb_la_SOURCES += mp-gcd.c
138TESTS += mp-gcd.$t
139libmpbase_la_SOURCES += mp-io.c
140libcatacomb_la_SOURCES += mp-jacobi.c
141TESTS += mp-jacobi.$t
142libmpbase_la_SOURCES += mp-mem.c
143libmpbase_la_SOURCES += mp-misc.c
144libcatacomb_la_SOURCES += mp-modexp.c
145TESTS += mp-modexp.$t
146libcatacomb_la_SOURCES += mp-modsqrt.c
147TESTS += mp-modsqrt.$t
148libcatacomb_la_SOURCES += mp-sqrt.c
149TESTS += mp-sqrt.$t
150libcatacomb_la_SOURCES += mp-test.c
151EXTRA_DIST += tests/mp
152
153## Computing Fibonacci numbers.
154pkginclude_HEADERS += mp-fibonacci.h
155libcatacomb_la_SOURCES += mp-fibonacci.c
156TESTS += mp-fibonacci.$t
157
158## Special memory allocation for multiprecision integers.
159pkginclude_HEADERS += mparena.h
160libmpbase_la_SOURCES += mparena.c
161
162## Barrett reduction, an efficient method for modular reduction.
163pkginclude_HEADERS += mpbarrett.h
164libcatacomb_la_SOURCES += mpbarrett.c
165TESTS += mpbarrett.$t
166libcatacomb_la_SOURCES += mpbarrett-exp.c mpbarrett-mexp.c mpbarrett-exp.h
167TESTS += mpbarrett-exp.$t mpbarrett-mexp.$t
168EXTRA_DIST += tests/mpbarrett
169
170## Solving congruences using the Chinese Remainder Theorem.
171pkginclude_HEADERS += mpcrt.h
172libcatacomb_la_SOURCES += mpcrt.c
173TESTS += mpcrt.$t
174EXTRA_DIST += tests/mpcrt
175
176## Conversions between machine-native and multiprecision integers.
177pkginclude_HEADERS += mpint.h
178libcatacomb_la_SOURCES += mpint.c
179TESTS += mpint.$t
180EXTRA_DIST += tests/mpint
181
182## Table of upper and lower limits of various types of machine integers, as
183## multiprecision integers.
184nodist_archinclude_HEADERS += mplimits.h
185nodist_libcatacomb_la_SOURCES += mplimits.c
186CLEANFILES += mplimits.h mplimits.c
187noinst_PROGRAMS += genlimits
188genlimits_LDADD = libmpbase.la
189mplimits.c: genlimits$e
190 $(AM_V_GEN)./genlimits c >mplimits.c.new && \
191 mv mplimits.c.new mplimits.c
192mplimits.h: genlimits$e
193 $(AM_V_GEN)./genlimits h >mplimits.h.new && \
194 mv mplimits.h.new mplimits.h
195$(genlimits_OBJECTS): mptypes.h
196mplimits.lo: mplimits.h
197
198## Montgomery reduction, a clever method for modular arithmetic.
199pkginclude_HEADERS += mpmont.h
200libcatacomb_la_SOURCES += mpmont.c
201TESTS += mpmont.$t
202libcatacomb_la_SOURCES += mpmont-exp.c mpmont-mexp.c mpmont-exp.h
203TESTS += mpmont-exp.$t mpmont-mexp.$t
204EXTRA_DIST += tests/mpmont
205
206## Efficient multiplication of many small numbers.
207pkginclude_HEADERS += mpmul.h
208libcatacomb_la_SOURCES += mpmul.c
209TESTS += mpmul.$t
210
211## Generating random numbers.
212pkginclude_HEADERS += mprand.h
213libcatacomb_la_SOURCES += mprand.c
214
215## Efficient reduction modulo numbers with conveninent binary
216## representations.
217pkginclude_HEADERS += mpreduce.h
218libcatacomb_la_SOURCES += mpreduce.c mpreduce-exp.h
219TESTS += mpreduce.$t
220EXTRA_DIST += tests/mpreduce
221
222## Iteratiion over the bianry representation of multiprecision integers.
223pkginclude_HEADERS += mpscan.h
224libmpbase_la_SOURCES += mpscan.c
225
226## Conversion between multiprecision integers and their textual
227## representations.
228pkginclude_HEADERS += mptext.h
229libmpbase_la_SOURCES += mptext.c
230TESTS += mptext.$t
231libcatacomb_la_SOURCES += mptext-dstr.c
232libcatacomb_la_SOURCES += mptext-file.c
233libcatacomb_la_SOURCES += mptext-len.c
234libmpbase_la_SOURCES += mptext-string.c
235EXTRA_DIST += tests/mptext
236
237## Basic types used in the representation of multiprecision integers.
238nodist_archinclude_HEADERS += mptypes.h
239BUILT_SOURCES += mptypes.h
240CLEANFILES += mptypes.h
241noinst_PROGRAMS += mptypes
242mptypes.h: mptypes$e
243 $(AM_V_GEN)./mptypes >mptypes.h.new && mv mptypes.h.new mptypes.h
244
245## Low-level multiprecision arithmetic.
246pkginclude_HEADERS += mpx.h bitops.h mpw.h
247libmpbase_la_SOURCES += mpx.c
248TESTS += mpx.$t
249libmpbase_la_SOURCES += karatsuba.h mpx-kmul.c mpx-ksqr.c
250TESTS += mpx-kmul.$t mpx-ksqr.$t
251noinst_PROGRAMS += bittest
252TESTS += bittest
253EXTRA_DIST += tests/mpx
254
255## A quick-and-dirty parser, used for parsing descriptions of groups, fields,
256## etc.
257pkginclude_HEADERS += rho.h
258libcatacomb_la_SOURCES += rho.c
259TESTS += rho.$t
260
261## Pollard's `rho' algorithm for determining discrete logarithms.
262pkginclude_HEADERS += qdparse.h
263libcatacomb_la_SOURCES += qdparse.c
264
265###--------------------------------------------------------------------------
266### Prime number checking, searching, and related jobs.
267
268## Generating Lim--Lee groups, i.e., unit groups of finite fields without
269## small subgroups (except for the obvious ones).
270pkginclude_HEADERS += limlee.h
271libcatacomb_la_SOURCES += limlee.c
272
273## A table of small prime numbers.
274nodist_pkginclude_HEADERS += primetab.h
275nodist_libcatacomb_la_SOURCES += primetab.c
276CLEANFILES += primetab.h primetab.c
277BUILT_SOURCES += primetab.h primetab.c
278noinst_PROGRAMS += genprimes
279primetab.h: primetab.c
280primetab.c: genprimes$e
281 $(AM_V_GEN)./genprimes -hprimetab.h -cprimetab.c \
282 -sCATACOMB_PRIMETAB_H \
283 -n256 -t"unsigned short" -iprimetab
284
285## Filtering candidate prime numbers by checking for small factors
286## efficiently.
287pkginclude_HEADERS += pfilt.h
288libcatacomb_la_SOURCES += pfilt.c
289
290## Generating prime numbers (and other kinds of numbers which need searching
291## for).
292pkginclude_HEADERS += pgen.h
293libcatacomb_la_SOURCES += pgen.c
294libcatacomb_la_SOURCES += pgen-gcd.c
295libcatacomb_la_SOURCES += pgen-simul.c
296libcatacomb_la_SOURCES += pgen-stdev.c
297TESTS += pgen.$t
298EXTRA_DIST += tests/pgen
299
300## Finding primitive elements in finite fields.
301pkginclude_HEADERS += prim.h
302libcatacomb_la_SOURCES += prim.c
303
304## Iterating over all prime numbers from a given starting point.
305pkginclude_HEADERS += primeiter.h
306libcatacomb_la_SOURCES += primeiter.c
307TESTS += primeiter.$t
308primeiter.lo: wheel.h
309
310## The Miller--Rabin primality test.
311pkginclude_HEADERS += rabin.h
312libcatacomb_la_SOURCES += rabin.c
313
314## Finding `strong' primes, using Gordon's algorithm. Once upon a time,
315## products of these kinds of numbers were harder to factor.
316pkginclude_HEADERS += strongprime.h
317libcatacomb_la_SOURCES += strongprime.c
318
319## A `wheel', used by the prime iteration machinery.
320nodist_pkginclude_HEADERS += wheel.h
321nodist_libcatacomb_la_SOURCES += wheel.c
322CLEANFILES += wheel.h wheel.c
323noinst_PROGRAMS += genwheel
324wheel.h: wheel.c
325wheel.c: genwheel$e
326 $(AM_V_GEN)./genwheel -hwheel.h -cwheel.c \
327 -sCATACOMB_WHEEL_H \
328 -n5 -t"unsigned char" -iwheel
329
330###--------------------------------------------------------------------------
331### Binary polynomial arithmetic.
332
333## User-visible binary polynomial arithmetic.
334pkginclude_HEADERS += gf.h
335libcatacomb_la_SOURCES += gf-arith.c
336TESTS += gf-arith.$t
337libcatacomb_la_SOURCES += gf-exp.c gf-exp.h
338libcatacomb_la_SOURCES += gf-gcd.c
339TESTS += gf-gcd.$t
340EXTRA_DIST += tests/gf
341
342## Low-level binary polynomial arithmetic.
343pkginclude_HEADERS += gfx.h
344libcatacomb_la_SOURCES += gfx.c
345TESTS += gfx.$t
346libcatacomb_la_SOURCES += gfx-kmul.c
347TESTS += gfx-kmul.$t
348libcatacomb_la_SOURCES += gfx-sqr.c
349gfx-sqr.lo: gfx-sqr-tab.h
350TESTS += gfx-sqr.$t
351CLEANFILES += gfx-sqr-tab.h
352noinst_PROGRAMS += gfx-sqr-mktab
353gfx-sqr-tab.h: gfx-sqr-mktab$e
354 $(AM_V_GEN)./gfx-sqr-mktab >gfx-sqr-tab.h.in && \
355 mv gfx-sqr-tab.h.in gfx-sqr-tab.h
356EXTRA_DIST += tests/gfx
357
358## Conversions between normal and polynomial basis representations for binary
359## fields.
360pkginclude_HEADERS += gfn.h
361libcatacomb_la_SOURCES += gfn.c
362TESTS += gfn.$t
363EXTRA_DIST += tests/gfn
364
365## Efficient reduction modulo sparse polynomials.
366pkginclude_HEADERS += gfreduce.h
367libcatacomb_la_SOURCES += gfreduce.c gfreduce-exp.h
368TESTS += gfreduce.$t
369EXTRA_DIST += tests/gfreduce
370
371###--------------------------------------------------------------------------
372### Abstractions for various kinds of algebraic objects.
373
374## Abstract cyclic groups.
375pkginclude_HEADERS += group.h group-guts.h
376libcatacomb_la_SOURCES += group-dstr.c
377libcatacomb_la_SOURCES += group-exp.c group-exp.h
378libcatacomb_la_SOURCES += group-file.c
379libcatacomb_la_SOURCES += group-parse.c
380libcatacomb_la_SOURCES += group-stdops.c
381libcatacomb_la_SOURCES += group-string.c
382libcatacomb_la_SOURCES += g-bin.c
383libcatacomb_la_SOURCES += g-prime.c
384libcatacomb_la_SOURCES += g-ec.c
385EXTRA_DIST += group-test.c
386TESTS += group-test.$t
387EXTRA_DIST += tests/group
388
389## Abstract finite fields.
390pkginclude_HEADERS += field.h field-guts.h
391libcatacomb_la_SOURCES += field.c
392libcatacomb_la_SOURCES += field-exp.c field-exp.h
393libcatacomb_la_SOURCES += field-parse.c
394libcatacomb_la_SOURCES += f-binpoly.c
395libcatacomb_la_SOURCES += f-niceprime.c
396libcatacomb_la_SOURCES += f-prime.c
397
398## Table of built-in binary fields.
399pkginclude_HEADERS += bintab.h
400libcatacomb_la_SOURCES += bintab.c
401CLEANFILES += bintab.c
402EXTRA_DIST += bintab.in bin-gentab.awk
403bintab.c: bintab.in bin-gentab.awk mpdump$e
404 $(AM_V_GEN)awk -f $(srcdir)/bin-gentab.awk \
405 <$(srcdir)/bintab.in >bintab.c.new && \
406 mv bintab.c.new bintab.c
407
408## Table of built-in prime fields.
409pkginclude_HEADERS += ptab.h
410libcatacomb_la_SOURCES += ptab.c
411CLEANFILES += ptab.c
412EXTRA_DIST += ptab.in p-gentab.awk
413ptab.c: ptab.in p-gentab.awk mpdump$e
414 $(AM_V_GEN)awk -f $(srcdir)/p-gentab.awk \
415 <$(srcdir)/ptab.in >ptab.c.new && \
416 mv ptab.c.new ptab.c
417
418## A utility for building multiprecision integer constants.
419noinst_PROGRAMS += mpdump
420mpdump_LDADD = libmpbase.la
421$(mpdump_OBJECTS): mptypes.h
422
423###--------------------------------------------------------------------------
424### Elliptic curve arithmetic.
425
426## Basic elliptic curve arithmetic.
427pkginclude_HEADERS += ec.h ec-guts.h
428libcatacomb_la_SOURCES += ec.c
429libcatacomb_la_SOURCES += ec-exp.c ec-exp.h
430libcatacomb_la_SOURCES += ec-info.c
431TESTS += ec-info.$t
432libcatacomb_la_SOURCES += ec-bin.c
433TESTS += ec-bin.$t
434libcatacomb_la_SOURCES += ec-prime.c
435TESTS += ec-prime.$t
436EXTRA_DIST += tests/ec
437
438## The standard `raw' encoding (`EC2OSP') of elliptic curve points.
439pkginclude_HEADERS += ec-raw.h
440libcatacomb_la_SOURCES += ec-raw.c
441
442## Test infrastructure for elliptic curves.
443pkginclude_HEADERS += ec-test.h
444libcatacomb_la_SOURCES += ec-test.c
445TESTS += ec-test.$t
446
447## A table of built-in elliptic curves.
448pkginclude_HEADERS += ectab.h
449libcatacomb_la_SOURCES += ectab.c
450CLEANFILES += ectab.c
451EXTRA_DIST += ectab.in ec-gentab.awk
452ectab.c: ectab.in ec-gentab.awk mpdump$e
453 $(AM_V_GEN)awk -f $(srcdir)/ec-gentab.awk \
454 <$(srcdir)/ectab.in >ectab.c.new && \
455 mv ectab.c.new ectab.c
456
457###--------------------------------------------------------------------------
458### Autogenerated lists.
459
460## Fancy template substitutions.
461multigen = python $(srcdir)/multigen
462EXTRA_DIST += multigen
463
464## The heart of this is an enormous cross-product of crypto primitives and
465## the corresponding modes of operation. Rather than write it out longhand,
466## we generate it using `multigen'. Unfortunately, this needs to be done
467## at the Automake level, which causes some interesting bootstrapping
468## problems.
469include modes.am
470
471EXTRA_DIST += modes.am.in modes.am
472MAINTAINERCLEANFILES += $(srcdir)/modes.am
473
474## Generate the lists.
475$(srcdir)/modes.am: modes.am.in
476 $(AM_V_GEN)$(multigen) -g $(srcdir)/modes.am.in $(srcdir)/modes.am \
477 blkc="$(BLKCS)" \
478 blkcmode="$(BLKCMODES)" \
479 blkcciphermode="$(BLKCCIPHERMODES)" \
480 hash="$(HASHES)" \
481 hashmode="$(HASHMODES)" \
482 hashciphermode="$(HASHCIPHERMODES)" \
483 hashmacmode="$(HASHMACMODES)"
484
485## Initialize lists of known classes.
486ALL_CIPHERS = $(CIPHER_MODES)
487ALL_HASHES = $(HASHES)
488ALL_MACS = $(MAC_MODES)
489
490###--------------------------------------------------------------------------
491### Block ciphers.
492
493BLKCS =
494BLKCMODES =
495
496BLKCCIPHERMODES =
497BLKCMODES += $(BLKCCIPHERMODES)
498
499## A tool for translating the AES-contest test vectors into a form our test
500## rigs understand.
501EXTRA_DIST += tests/aes-trans
502
503## Block cipher utility macros, mainly used in mode implementations.
504pkginclude_HEADERS += blkc.h
505
506## Source code and headers for the block ciphers.
507libcatacomb_la_SOURCES += $(BLKC_C)
508pkginclude_HEADERS += $(BLKC_H)
509
510## Schneier's `Blowfish' block cipher.
511BLKCS += blowfish
512blowfish.lo: blowfish-tab.h
513CLEANFILES += blowfish-tab.h
514noinst_PROGRAMS += blowfish-mktab
515blowfish-tab.h: blowfish-mktab$e
516 $(AM_V_GEN)./blowfish-mktab >blowfish-tab.h.new && \
517 mv blowfish-tab.h.new blowfish-tab.h
518
519## Adams and Tavares' `CAST' block ciphers.
520BLKCS += cast128 cast256
521libcatacomb_la_SOURCES += cast-s.c cast-sk.c cast-base.h cast-tab.h
522cast256.$t: tests/cast256
523EXTRA_DIST += tests/cast256.aes
524MAINTAINERCLEANFILES += $(srcdir)/tests/cast256
525tests/cast256: tests/cast256.aes
526 $(AM_V_GEN)$(srcdir)/tests/aes-trans CAST256 \
527 <$(srcdir)/tests/cast256.aes \
528 >$(srcdir)/tests/cast256.new && \
529 mv $(srcdir)/tests/cast256.new $(srcdir)/tests/cast256
530
531## IBM's `DES' block cipher, by Feistel, Coppersmith, and others.
532BLKCS += des des3
533libcatacomb_la_SOURCES += des-base.h des-base.c desx-tab.h
534des-base.lo: des-tab.h
535CLEANFILES += des-tab.h
536noinst_PROGRAMS += des-mktab
537des-tab.h: des-mktab$e
538 $(AM_V_GEN)./des-mktab >des-tab.h.new && \
539 mv des-tab.h.new des-tab.h
540
541## Rivest's `DESX' variant, with pre- and post-whitening.
542BLKCS += desx
543libcatacomb_la_SOURCES += desx-tab.h
544
545## Lai and Massey's IDEA.
546BLKCS += idea
547
548## IBM's `MARS' block cipher.
549BLKCS += mars
550mars.lo: mars-tab.h
551CLEANFILES += mars-tab.h
552noinst_PROGRAMS += mars-mktab
553mars-tab.h: mars-mktab$e
554 $(AM_V_GEN)./mars-mktab >mars-tab.h.new && \
555 mv mars-tab.h.new mars-tab.h
556mars.$t: tests/mars
557EXTRA_DIST += tests/mars.aes
558MAINTAINERCLEANFILES += $(srcdir)/tests/mars
559tests/mars: tests/mars.aes
560 $(AM_V_GEN)$(srcdir)/tests/aes-trans Mars \
561 <$(srcdir)/tests/mars.aes \
562 >$(srcdir)/tests/mars.new && \
563 mv $(srcdir)/tests/mars.new $(srcdir)/tests/mars
564
565## Daemen, Peeters, Van Assche and Rijmen's `Noekeon'.
566BLKCS += noekeon
567
568## Rivest's `RC2' block cipher.
569BLKCS += rc2
570libcatacomb_la_SOURCES += rc2-tab.h
571
572## Rivest's `RC5'.
573BLKCS += rc5
574
575## Daemen and Rijmen's `Rijndael' block cipher, selected as AES.
576BLKCS += rijndael rijndael192 rijndael256
577libcatacomb_la_SOURCES += rijndael-base.h rijndael-base.c
578rijndael-base.lo: rijndael-tab.h
579CLEANFILES += rijndael-tab.h
580noinst_PROGRAMS += rijndael-mktab
581rijndael-tab.h: rijndael-mktab$e
582 $(AM_V_GEN)./rijndael-mktab >rijndael-tab.h.new && \
583 mv rijndael-tab.h.new rijndael-tab.h
584rijndael.$t: tests/rijndael
585EXTRA_DIST += tests/rijndael.aes
586MAINTAINERCLEANFILES += $(srcdir)/tests/rijndael
587tests/rijndael: tests/rijndael.aes
588 $(AM_V_GEN)$(srcdir)/tests/aes-trans Rijndael \
589 <$(srcdir)/tests/rijndael.aes \
590 >$(srcdir)/tests/rijndael.new && \
591 mv $(srcdir)/tests/rijndael.new $(srcdir)/tests/rijndael
592
593## Massey's `SAFER' block ciphers.
594BLKCS += safer safersk
595safer.lo: safer-tab.h
596CLEANFILES += safer-tab.h
597noinst_PROGRAMS += safer-mktab
598safer-tab.h: safer-mktab$e
599 $(AM_V_GEN)./safer-mktab >safer-tab.h.new && \
600 mv safer-tab.h.new safer-tab.h
601
602## Anderson, Biham and Knudsen's `Serpent' block cipher.
603BLKCS += serpent
604libcatacomb_la_SOURCES += serpent-sbox.h
605noinst_PROGRAMS += serpent-check
606TESTS += serpent-check
607serpent.$t: tests/serpent
608EXTRA_DIST += tests/serpent.aes
609MAINTAINERCLEANFILES += $(srcdir)/tests/serpent
610tests/serpent: tests/serpent.aes
611 $(AM_V_GEN)$(srcdir)/tests/aes-trans Serpent -v rev=1 \
612 <$(srcdir)/tests/serpent.aes \
613 >$(srcdir)/tests/serpent.new && \
614 mv $(srcdir)/tests/serpent.new $(srcdir)/tests/serpent
615
616## The National Security Agency's `Skipjack' block cipher. You don't want to
617## use this.
618BLKCS += skipjack
619libcatacomb_la_SOURCES += skipjack-tab.h
620
621## Daemen and Rijmen's `Square' block cipher.
622BLKCS += square
623square.lo: square-tab.h
624CLEANFILES += square-tab.h
625noinst_PROGRAMS += square-mktab
626square-tab.h: square-mktab$e
627 $(AM_V_GEN)./square-mktab >square-tab.h.new && \
628 mv square-tab.h.new square-tab.h
629
630## Wheeler and Needham's `TEA' and `XTEA' block ciphers.
631BLKCS += tea xtea
632
633## Schneier, Kelsey, Whiting, Wagner, Hall and Ferguson's `Twofish' block
634## cipher.
635BLKCS += twofish
636twofish.lo: twofish-tab.h
637CLEANFILES += twofish-tab.h
638noinst_PROGRAMS += twofish-mktab
639twofish-tab.h: twofish-mktab$e
640 $(AM_V_GEN)./twofish-mktab >twofish-tab.h.new && \
641 mv twofish-tab.h.new twofish-tab.h
642twofish.$t: tests/twofish
643EXTRA_DIST += tests/twofish.aes
644MAINTAINERCLEANFILES += $(srcdir)/tests/twofish
645tests/twofish: tests/twofish.aes
646 $(AM_V_GEN)$(srcdir)/tests/aes-trans Twofish \
647 <$(srcdir)/tests/twofish.aes \
648 >$(srcdir)/tests/twofish.new && \
649 mv $(srcdir)/tests/twofish.new $(srcdir)/tests/twofish
650
651## The old NIST modes for DES.
652BLKCCIPHERMODES += cbc cfb ecb ofb
653
654## Counter mode.
655BLKCCIPHERMODES += counter
656
657###--------------------------------------------------------------------------
658### Hash functions.
659
660HASHES =
661HASHMODES =
662
663HASHCIPHERMODES =
664HASHMODES += $(HASHCIPHERMODES)
665
666HASHMACMODES =
667HASHMODES += $(HASHMACMODES)
668
669## Common definitions for hash functions.
670pkginclude_HEADERS += hash.h
671
672## Source code and headers for the hash functions.
673libcatacomb_la_SOURCES += $(HASH_C)
674pkginclude_HEADERS += $(HASH_H)
675
676## Lim and KISA's `HAS-160', recommended for use with KCDSA.
677HASHES += has160
678
679## Rivest's `MD' series of hash functions
680HASHES += md2 md4 md5
681libcatacomb_la_SOURCES += md2-tab.h
682
683## Dobbertin, Bosselaers and Preneel's `RIPEMD' suite.
684HASHES += rmd128 rmd160 rmd256 rmd320
685
686## The National Security Agency's `SHA-1' hash function.
687HASHES += sha
688
689## The National Security Agency's `SHA-2' suite.
690HASHES += sha224 sha256
691HASHES += sha384 sha512
692
693## Anderson and Biham's `Tiger' hash function.
694HASHES += tiger
695libcatacomb_la_SOURCES += tiger-base.h
696tiger.lo: tiger-tab.h
697CLEANFILES += tiger-tab.h
698noinst_PROGRAMS += tiger-mktab
699tiger-tab.h: tiger-mktab$e
700 $(AM_V_GEN)./tiger-mktab >tiger-tab.h.new && \
701 mv tiger-tab.h.new tiger-tab.h
702
703## Barreto and Rijmen's `Whirlpool' hash function.
704HASHES += whirlpool whirlpool256
705whirlpool.lo: whirlpool-tab.h
706CLEANFILES += whirlpool-tab.h
707noinst_PROGRAMS += whirlpool-mktab
708whirlpool-tab.h: whirlpool-mktab$e
709 $(AM_V_GEN)./whirlpool-mktab >whirlpool-tab.h.new && \
710 mv whirlpool-tab.h.new whirlpool-tab.h
711
712## Bellare, Canetti and Krawczyk's `HMAC' mode for message authentication.
713HASHMACMODES += hmac
714
715## MGF1, used in OAEP and PSS.
716HASHCIPHERMODES += mgf
717
718###--------------------------------------------------------------------------
719### Other symmetric primitives.
720
721## The CRC32 algorithm, which is useful, but has no worthwhile security.
722pkginclude_HEADERS += crc32.h
723libcatacomb_la_SOURCES += crc32.c
724ALL_HASHES += crc32=gcrc32
725
726## Rivest's `RC4' stream cipher.
727pkginclude_HEADERS += rc4.h
728libcatacomb_la_SOURCES += rc4.c
729TESTS += rc4.$t
730EXTRA_DIST += tests/rc4
731ALL_CIPHERS += rc4
732
733## Coppersmith and Rogaway's `SEAL' pseudorandom function.
734pkginclude_HEADERS += seal.h
735libcatacomb_la_SOURCES += seal.c
736TESTS += seal.$t
737EXTRA_DIST += tests/seal
738ALL_CIPHERS += seal
739###--------------------------------------------------------------------------
740### Autogenerated mode implementations.
741
742## The master stamp file, indicating that we generated all of the sources.
743CLEANFILES += modes-gen-stamp
744EXTRA_DIST += mode.h.in mode.c.in
745modes-gen-stamp:
746 $(AM_V_at)touch modes-gen-stamp
747 $(AM_V_GEN)$(multigen) -g $(srcdir)/mode.c.in \
748 @base-@mode.c \
749 base="$(BLKCS)" mode="$(BLKCMODES)"
750 $(AM_V_at)$(multigen) -g $(srcdir)/mode.c.in \
751 @base-@mode.c \
752 base="$(HASHES)" mode="$(HASHMODES)"
753 $(AM_V_at)$(multigen) -g $(srcdir)/mode.h.in \
754 @base-@mode.h \
755 base="$(BLKCS)" mode="$(BLKCMODES)"
756 $(AM_V_at)$(multigen) -g $(srcdir)/mode.h.in \
757 @base-@mode.h \
758 base="$(HASHES)" mode="$(HASHMODES)"
759 $(AM_V_at)touch modes-gen-stamp
760
761## The individual mode interfaces and implementations.
762pkginclude_HEADERS += $(MODE_H)
763
764## Generated implementations.
765BUILT_SOURCES += $(GENMODES_C)
766CLEANFILES += $(GENMODES_C)
767nodist_libcatacomb_la_SOURCES += $(GENMODES_C)
768$(GENMODES_C): modes-gen-stamp
769
770## Generated interfaces.
771BUILT_SOURCES += $(GENMODES_H)
772CLEANFILES += $(GENMODES_H)
773nodist_pkginclude_HEADERS += $(GENMODES_H)
774$(GENMODES_H): modes-gen-stamp
775
776###--------------------------------------------------------------------------
777### Tables of classes for encryption, hashing, and message authentication.
778
779## The skeleton for the class tables.
780EXTRA_DIST += gthingtab.c.in
781
782## Table of cipher classes.
783pkginclude_HEADERS += gcipher.h
784CLEANFILES += gciphertab.c
785nodist_libcatacomb_la_SOURCES += gciphertab.c
786gciphertab.c: gthingtab.c.in
787 $(AM_V_GEN)$(multigen) -g $(srcdir)/gthingtab.c.in gciphertab.c \
788 what=gcipher cls=gccipher thing="$(ALL_CIPHERS)"
789
790## Table of hash classes.
791pkginclude_HEADERS += ghash.h ghash-def.h
792CLEANFILES += ghashtab.c
793nodist_libcatacomb_la_SOURCES += ghashtab.c
794ghashtab.c: gthingtab.c.in
795 $(AM_V_GEN)$(multigen) -g $(srcdir)/gthingtab.c.in ghashtab.c \
796 what=ghash cls=gchash thing="$(ALL_HASHES)"
797
798## Table of MAC classes.
799pkginclude_HEADERS += gmac.h
800CLEANFILES += gmactab.c
801nodist_libcatacomb_la_SOURCES += gmactab.c
802gmactab.c: gthingtab.c.in
803 $(AM_V_GEN)$(multigen) -g $(srcdir)/gthingtab.c.in gmactab.c \
804 what=gmac cls=gcmac thing="$(ALL_MACS)"
805
806###--------------------------------------------------------------------------
807### Testing for symmetric crypto things.
808
809## Run the test programs.
810TESTS += $(SYMM_TESTS)
811EXTRA_DIST += $(SYMM_TEST_FILES)
812
813## A piece of sample text for round-trip testing encryption modes.
814EXTRA_DIST += daftstory.h
815
816###--------------------------------------------------------------------------
817### Key management.
818
819## Assistance for elliptic-curve keys.
820pkginclude_HEADERS += ec-keys.h
821libcatacomb_la_SOURCES += ec-fetch.c
822
823## Managing keys and keyring files.
824pkginclude_HEADERS += key.h
825libcatacomb_la_SOURCES += key-attr.c
826libcatacomb_la_SOURCES += key-fetch.c
827libcatacomb_la_SOURCES += key-file.c
828libcatacomb_la_SOURCES += key-io.c
829libcatacomb_la_SOURCES += key-misc.c
830libcatacomb_la_SOURCES += key-moan.c
831
832## Managing key data.
833pkginclude_HEADERS += key-data.h
834libcatacomb_la_SOURCES += key-binary.c
835libcatacomb_la_SOURCES += key-data.c
836libcatacomb_la_SOURCES += key-flags.c
837libcatacomb_la_SOURCES += key-pack.c
838libcatacomb_la_SOURCES += key-pass.c
839libcatacomb_la_SOURCES += key-text.c
840
841## Error reporting.
842pkginclude_HEADERS += key-error.h
843libcatacomb_la_SOURCES += key-error.c
844
845## Reading passphrases.
846pkginclude_HEADERS += passphrase.h
847libcatacomb_la_SOURCES += passphrase.c
848
849## Interfacing with the passphrase pixie.
850pkginclude_HEADERS += pixie.h
851libcatacomb_la_SOURCES += pixie-common.c
852
853###--------------------------------------------------------------------------
854### Secret sharing.
855
856## Efficient sharing over GF(2^8).
857pkginclude_HEADERS += gfshare.h
858libcatacomb_la_SOURCES += gfshare.c
859gfshare.lo: gfshare-tab.h
860CLEANFILES += gfshare-tab.h
861noinst_PROGRAMS += gfshare-mktab
862gfshare-tab.h: gfshare-mktab$e
863 $(AM_V_GEN)./gfshare-mktab >gfshare-tab.h.new && \
864 mv gfshare-tab.h.new gfshare-tab.h
865TESTS += gfshare.$t
866
867## Number-theoretic sharing over GF(p).
868pkginclude_HEADERS += share.h
869libcatacomb_la_SOURCES += share.c
870TESTS += share.$t
871
872###--------------------------------------------------------------------------
873### Public-key cryptography.
874
875## The Blum--Blum--Shub random-bit generator.
876pkginclude_HEADERS += bbs.h
877libcatacomb_la_SOURCES += bbs-fetch.c
878libcatacomb_la_SOURCES += bbs-gen.c
879libcatacomb_la_SOURCES += bbs-jump.c
880TESTS += bbs-jump.$t
881libcatacomb_la_SOURCES += bbs-rand.c
882TESTS += bbs-rand.$t
883EXTRA_DIST += tests/bbs
884
885## Plain Diffie--Hellman, in Schorr groups.
886pkginclude_HEADERS += dh.h
887libcatacomb_la_SOURCES += dh-check.c
888libcatacomb_la_SOURCES += dh-fetch.c
889libcatacomb_la_SOURCES += dh-gen.c
890libcatacomb_la_SOURCES += dh-kcdsa.c
891libcatacomb_la_SOURCES += dh-limlee.c
892libcatacomb_la_SOURCES += dh-param.c
893TESTS += dh-param.$t
894
895## The National Security Agency's Digital Signature Algorithm.
896pkginclude_HEADERS += dsa.h
897libcatacomb_la_SOURCES += dsa-gen.c
898TESTS += dsa-gen.$t
899libcatacomb_la_SOURCES += dsa-misc.c
900libcatacomb_la_SOURCES += dsa-sign.c
901TESTS += dsa-sign.$t
902libcatacomb_la_SOURCES += dsa-verify.c
903TESTS += dsa-verify.$t
904libcatacomb_la_SOURCES += dsa-check.c
905EXTRA_DIST += tests/dsa
906
907## Generalization of DSA to arbitrary cyclic groups.
908pkginclude_HEADERS += gdsa.h
909libcatacomb_la_SOURCES += gdsa.c
910TESTS += gdsa.$t
911EXTRA_DIST += tests/gdsa
912
913## KISA `KCDSA', generalized to arbitrary cyclic groups.
914pkginclude_HEADERS += gkcdsa.h
915libcatacomb_la_SOURCES += gkcdsa.c
916TESTS += gkcdsa.$t
917EXTRA_DIST += tests/gkcdsa
918
919## General key validity checking machinery.
920pkginclude_HEADERS += keycheck.h
921libcatacomb_la_SOURCES += keycheck.c
922libcatacomb_la_SOURCES += keycheck-mp.c
923libcatacomb_la_SOURCES += keycheck-report.c
924
925## The Rivest--Shamir--Adleman trapdoor one-way function.
926pkginclude_HEADERS += rsa.h
927libcatacomb_la_SOURCES += rsa-fetch.c
928libcatacomb_la_SOURCES += rsa-gen.c
929libcatacomb_la_SOURCES += rsa-priv.c
930libcatacomb_la_SOURCES += rsa-pub.c
931libcatacomb_la_SOURCES += rsa-recover.c
932libcatacomb_la_SOURCES += oaep.c
933libcatacomb_la_SOURCES += pkcs1.c
934libcatacomb_la_SOURCES += pss.c
935EXTRA_DIST += rsa-test.c
936TESTS += rsa-test.$t
937EXTRA_DIST += tests/rsa
938
939###--------------------------------------------------------------------------
940### Random number generators.
941
942## The FIPS186 generator used to generate DSA domain parameters.
943pkginclude_HEADERS += dsarand.h
944libcatacomb_la_SOURCES += dsarand.c
945
946## Knuth's lagged-Fibonacci generator.
947pkginclude_HEADERS += fibrand.h
948libcatacomb_la_SOURCES += fibrand.c
949
950## The FIPS 140--2 random number generator tests.
951pkginclude_HEADERS += fipstest.h
952libcatacomb_la_SOURCES += fipstest.c
953
954## Interface for generic random number sources.
955pkginclude_HEADERS += grand.h
956libcatacomb_la_SOURCES += grand.c
957
958## A simple linear-congruential generator.
959pkginclude_HEADERS += lcrand.h
960libcatacomb_la_SOURCES += lcrand.c
961TESTS += lcrand.$t
962EXTRA_DIST += tests/lcrand
963
964## Maurer's universal statistical test.
965pkginclude_HEADERS += maurer.h
966libcatacomb_la_SOURCES += maurer.c
967
968## System-specific noise acquisition.
969pkginclude_HEADERS += noise.h
970libcatacomb_la_SOURCES += noise.c
971
972## Cryptographic laundering for true random data generation.
973pkginclude_HEADERS += rand.h
974libcatacomb_la_SOURCES += rand.c
975
976## The SSL v3 pseudorandom function.
977pkginclude_HEADERS += sslprf.h
978libcatacomb_la_SOURCES += sslprf.c
979TESTS += sslprf.$t
980EXTRA_DIST += tests/sslprf
981
982## The TLS v1 pseudorandom function.
983pkginclude_HEADERS += tlsprf.h
984libcatacomb_la_SOURCES += tlsprf.c
985TESTS += tlsprf.$t
986EXTRA_DIST += tests/tlsprf
987
988###--------------------------------------------------------------------------
989### The `catcrypt' library.
990
991noinst_LTLIBRARIES += libcatcrypt.la
992libcatcrypt_la_SOURCES =
993
994## The main library.
995libcatcrypt_la_SOURCES += cc.h
996libcatcrypt_la_SOURCES += cc-enc.c
997libcatcrypt_la_SOURCES += cc-hash.c
998libcatcrypt_la_SOURCES += cc-kem.c
999libcatcrypt_la_SOURCES += cc-list.c
1000libcatcrypt_la_SOURCES += cc-progress.c
1001libcatcrypt_la_SOURCES += cc-sig.c
1002libcatcrypt_la_SOURCES += cc-subcmd.c
1003
1004## Date parsing.
1005libcatcrypt_la_SOURCES += getdate.h
1006libcatcrypt_la_SOURCES += getdate.y
1007
1008###--------------------------------------------------------------------------
1009### Utility programs.
1010
1011UTILS_LIBS = libcatcrypt.la libcatacomb.la $(LIBS)
1012
1013## Generate and verify datestamped cookies.
1014bin_PROGRAMS += cookie
1015cookie_LDADD = $(UTILS_LIBS)
1016dist_man_MANS += cookie.1
1017
1018## Asymmetric message encryption and decryption with deniable authentication.
1019bin_PROGRAMS += catcrypt
1020catcrypt_LDADD = $(UTILS_LIBS)
1021dist_man_MANS += catcrypt.1
1022
1023## Signing and verifying files.
1024bin_PROGRAMS += catsign
1025catsign_LDADD = $(UTILS_LIBS)
1026dist_man_MANS += catsign.1
1027
1028## Issue and verify signatures on directory trees.
1029bin_PROGRAMS += dsig
1030dsig_LDADD = $(UTILS_LIBS)
1031dist_man_MANS += dsig.1
1032
1033## Compute factorials to arbitrary precision.
1034bin_PROGRAMS += factorial
1035factorial_LDADD = $(UTILS_LIBS)
1036
1037## Compute Fibonacci numbers to arbitrary precision.
1038bin_PROGRAMS += fibonacci
1039fibonacci_LDADD = $(UTILS_LIBS)
1040
1041## Compute hashes of files.
1042bin_PROGRAMS += hashsum
1043hashsum_LDADD = $(UTILS_LIBS)
1044dist_man_MANS += hashsum.1
1045
1046## Key management utility.
1047bin_PROGRAMS += key
1048key_SOURCES = keyutil.c
1049key_LDADD = $(UTILS_LIBS)
1050dist_man_MANS += key.1 keyring.5
1051
1052## Generate passphrases with given entropy using wordlists and Markov models.
1053bin_PROGRAMS += mkphrase
1054mkphrase_LDADD = $(UTILS_LIBS)
1055dist_man_MANS += mkphrase.1
1056
1057## Performance testing.
1058bin_PROGRAMS += perftest
1059perftest_LDADD = $(UTILS_LIBS)
1060
1061## Remember passphrases for limited periods of time.
1062bin_PROGRAMS += pixie
1063pixie_SOURCES = pixie.c
1064pixie_LDADD = libcatacomb.la
1065dist_man_MANS += pixie.1
1066EXTRA_DIST += xpixie
1067
1068## Generate random data.
1069bin_PROGRAMS += rspit
1070rspit_LDADD = $(UTILS_LIBS)
1071
1072###--------------------------------------------------------------------------
1073### Testing.
1074
1075SUFFIXES += .c .$t .to
1076.c.to:
1077 $(AM_V_CC)$(COMPILE) -c -DTEST_RIG -DSRCDIR=\"$(srcdir)\" $< -o $@
1078.to.$t: libcatacomb.la
1079 $(AM_V_CCLD)$(LINK) $< libcatacomb.la $(LIBS)
1080.PRECIOUS: %.to
1081CLEANFILES += *.to *.$t
1082
1083###--------------------------------------------------------------------------
1084### The pkg-config file.
1085
1086pkgconfigdir = $(libdir)/pkgconfig
1087pkgconfig_DATA = catacomb.pc
1088EXTRA_DIST += catacomb.pc.in
1089CLEANFILES += catacomb.pc
1090
1091catacomb.pc: catacomb.pc.in Makefile
1092 $(SUBST) $(srcdir)/catacomb.pc.in >$@.new $(SUBSTITUTIONS) && \
1093 mv $@.new $@
1094
1095###--------------------------------------------------------------------------
1096### Release tweaking.
1097
1098## Release number.
1099dist-hook::
1100 echo $(VERSION) >$(distdir)/RELEASE
1101
1102## Additional build tools.
1103EXTRA_DIST += auto-version
1104
1105###--------------------------------------------------------------------------
1106### Debian.
1107
1108## General stuff.
1109EXTRA_DIST += debian/rules
1110EXTRA_DIST += debian/control
1111EXTRA_DIST += debian/changelog
1112EXTRA_DIST += debian/copyright
1113
1114## catacomb-bin
1115EXTRA_DIST += debian/catacomb-bin.prerm
1116EXTRA_DIST += debian/catacomb-bin.postinst
1117EXTRA_DIST += debian/catacomb-bin.config
1118EXTRA_DIST += debian/catacomb-bin.templates
1119
1120###----- That's all, folks --------------------------------------------------