Makefile.in 21.8 KB
Newer Older
1
2
3
4
5
6
7
# Nettle Makefile

@SET_MAKE@

srcdir = @srcdir@
VPATH = @srcdir@

8
9
10
11
12
INSTALL = @INSTALL@
INSTALL_DATA = @INSTALL_DATA@
INSTALL_PROGRAM = @INSTALL_PROGRAM@
INSTALL_SCRIPT = @INSTALL_SCRIPT@
INSTALL_STRIP_PROGRAM = $(INSTALL_PROGRAM) -s
13
MKDIR_P = @MKDIR_P@
14

15
16
OPT_ASM_NETTLE_SOURCES = @OPT_ASM_NETTLE_SOURCES@
OPT_ASM_HOGWEED_SOURCES = @OPT_ASM_HOGWEED_SOURCES@
17

18
19
OPT_HOGWEED_SOURCES = @IF_MINI_GMP@ mini-gmp.c

20
21
22
23
SUBDIRS = tools testsuite examples

include config.make

24
25
# $(srcdir) is needed for includes in bignum.h.
PRE_CPPFLAGS = -I. -I$(srcdir)
26
EXTRA_CFLAGS = $(CCPIC)
27

28
# FIXME: Add configuration of LIBEXT?
29
30
LIBTARGETS = @IF_STATIC@ libnettle.a @IF_HOGWEED@ libhogweed.a
SHLIBTARGETS = @IF_SHARED@ $(LIBNETTLE_FORLINK) @IF_HOGWEED@ $(LIBHOGWEED_FORLINK)
31

32
33
34
getopt_SOURCES = getopt.c getopt1.c
getopt_TARGETS = $(getopt_SOURCES:.c=.$(OBJEXT))

35
36
37
internal_SOURCES = nettle-internal.c
internal_TARGETS = $(internal_SOURCES:.c=.$(OBJEXT))

38
39
40
TARGETS = aesdata$(EXEEXT_FOR_BUILD) desdata$(EXEEXT_FOR_BUILD) \
          twofishdata$(EXEEXT_FOR_BUILD) shadata$(EXEEXT_FOR_BUILD) \
          gcmdata$(EXEEXT_FOR_BUILD) \
41
	  $(getopt_TARGETS) $(internal_TARGETS) \
42
	  $(LIBTARGETS) $(SHLIBTARGETS)
43
IMPLICIT_TARGETS = @IF_DLL@ $(LIBNETTLE_FILE) $(LIBHOGWEED_FILE)
44

Sam Thursfield's avatar
Sam Thursfield committed
45
DOCTARGETS = @IF_DOCUMENTATION@ nettle.info nettle.html nettle.pdf
46

47
48
49
PKGCONFIG_FILES = nettle.pc @IF_HOGWEED@ hogweed.pc
pkgconfigdir = $(libdir)/pkgconfig

50
all check install uninstall:
51
	$(MAKE) $@-here
Niels Möller's avatar
Niels Möller committed
52
53
	set -e; for d in $(SUBDIRS); do \
	  echo "Making $@ in $$d" ; (cd $$d && $(MAKE) $@); done
54

55
clean distclean mostlyclean maintainer-clean tags:
Niels Möller's avatar
Niels Möller committed
56
57
	set -e; for d in $(SUBDIRS); do \
	  echo "Making $@ in $$d" ; (cd $$d && $(MAKE) $@); done
58
59
	$(MAKE) $@-here

60
61
62
check-here:
	true

63
# FIXME: Remove. These targets aren't supported, but they are expected by the
64
65
66
67
# automake generated Makefiles in the lsh build.
dvi installcheck uninstallcheck:
	true

68
all-here: $(TARGETS) $(DOCTARGETS)
69

70
71
nettle_SOURCES = aes-decrypt-internal.c aes-decrypt.c \
		 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 \
Niels Möller's avatar
Niels Möller committed
74
75
		 aes128-set-encrypt-key.c aes128-set-decrypt-key.c \
		 aes128-meta.c \
Niels Möller's avatar
Niels Möller committed
76
77
		 aes192-set-encrypt-key.c aes192-set-decrypt-key.c \
		 aes192-meta.c \
78
79
		 aes256-set-encrypt-key.c aes256-set-decrypt-key.c \
		 aes256-meta.c \
80
		 arcfour.c arcfour-crypt.c \
Niels Möller's avatar
Niels Möller committed
81
		 arctwo.c arctwo-meta.c blowfish.c \
82
		 base16-encode.c base16-decode.c base16-meta.c \
Niels Möller's avatar
Niels Möller committed
83
84
		 base64-encode.c base64-decode.c base64-meta.c \
		 buffer.c buffer-init.c \
Niels Möller's avatar
Niels Möller committed
85
86
87
88
89
90
91
92
93
		 camellia-crypt-internal.c camellia-table.c \
		 camellia-absorb.c camellia-invert-key.c \
		 camellia128-set-encrypt-key.c camellia128-crypt.c \
		 camellia128-set-decrypt-key.c \
		 camellia128-meta.c \
		 camellia192-meta.c \
		 camellia256-set-encrypt-key.c camellia256-crypt.c \
		 camellia256-set-decrypt-key.c \
		 camellia256-meta.c \
Niels Möller's avatar
Niels Möller committed
94
		 cast128.c cast128-meta.c cbc.c \
Owen Kirby's avatar
Owen Kirby committed
95
		 ccm.c ccm-aes128.c ccm-aes192.c ccm-aes256.c \
96
		 chacha-crypt.c chacha-core-internal.c \
Niels Möller's avatar
Niels Möller committed
97
		 chacha-poly1305.c chacha-poly1305-meta.c \
98
		 chacha-set-key.c chacha-set-nonce.c \
99
100
		 ctr.c des.c des3.c des-compat.c \
		 eax.c eax-aes128.c eax-aes128-meta.c \
101
102
103
104
		 gcm.c gcm-aes.c \
		 gcm-aes128.c gcm-aes128-meta.c \
		 gcm-aes192.c gcm-aes192-meta.c \
		 gcm-aes256.c gcm-aes256-meta.c \
Niels Möller's avatar
Niels Möller committed
105
		 gcm-camellia128.c gcm-camellia128-meta.c \
Niels Möller's avatar
Niels Möller committed
106
		 gcm-camellia256.c gcm-camellia256-meta.c \
Niels Möller's avatar
Niels Möller committed
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
111
		 knuth-lfib.c \
		 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
115
		 nettle-meta-aeads.c nettle-meta-armors.c \
		 nettle-meta-ciphers.c nettle-meta-hashes.c \
Niels Möller's avatar
Niels Möller committed
116
117
118
		 pbkdf2.c pbkdf2-hmac-sha1.c pbkdf2-hmac-sha256.c \
		 poly1305-aes.c poly1305-internal.c \
		 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
123
		 salsa20-set-nonce.c \
		 salsa20-128-set-key.c salsa20-256-set-key.c \
124
125
		 sha1.c sha1-compress.c sha1-meta.c \
		 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
129
130
		 sha3.c sha3-permute.c \
		 sha3-224.c sha3-224-meta.c sha3-256.c sha3-256-meta.c \
		 sha3-384.c sha3-384-meta.c sha3-512.c sha3-512-meta.c\
131
132
		 serpent-set-key.c serpent-encrypt.c serpent-decrypt.c \
		 serpent-meta.c \
133
		 twofish.c twofish-meta.c \
Niels Möller's avatar
Niels Möller committed
134
135
136
		 umac-nh.c umac-nh-n.c umac-l2.c umac-l3.c \
		 umac-poly64.c umac-poly128.c umac-set-key.c \
		 umac32.c umac64.c umac96.c umac128.c \
Niels Möller's avatar
Niels Möller committed
137
138
		 write-be32.c write-le32.c write-le64.c \
		 yarrow256.c yarrow_key_event.c
139

140
141
hogweed_SOURCES = sexp.c sexp-format.c \
		  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
150
151
		  rsa-md5-sign.c rsa-md5-verify.c \
		  rsa-sha1-sign.c rsa-sha1-verify.c \
		  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
159
		  dsa-sha1-sign.c dsa-sha1-verify.c \
		  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 \
Niels Möller's avatar
Niels Möller committed
163
164
165
		  sec-add-1.c sec-sub-1.c sec-modinv.c sec-tabselect.c \
		  gmp-glue.c cnd-copy.c \
		  ecc-mod.c ecc-generic-modp.c ecc-generic-modq.c \
166
		  ecc-modp.c ecc-modq.c ecc-pp1-redc.c ecc-pm1-redc.c \
Niels Möller's avatar
Niels Möller committed
167
		  ecc-192.c ecc-224.c ecc-256.c ecc-384.c ecc-521.c \
168
		  ecc-25519.c \
Niels Möller's avatar
Niels Möller committed
169
170
		  ecc-size.c ecc-j-to-a.c ecc-a-to-j.c \
		  ecc-dup-jj.c ecc-add-jja.c ecc-add-jjj.c \
171
172
173
		  ecc-a-to-eh.c ecc-eh-to-a.c \
		  ecc-dup-eh.c ecc-add-eh.c ecc-add-ehh.c \
		  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 \
Owen Kirby's avatar
Owen Kirby committed
183
	  cbc.h ccm.h chacha.h chacha-poly1305.h ctr.h \
Niels Möller's avatar
Niels Möller committed
184
	  curve25519.h des.h des-compat.h dsa.h dsa-compat.h eax.h \
185
	  ecc-curve.h ecc.h ecdsa.h \
Niels Möller's avatar
Niels Möller committed
186
	  gcm.h gosthash94.h hmac.h \
187
188
189
190
191
	  knuth-lfib.h \
	  macros.h \
	  md2.h md4.h \
	  md5.h md5-compat.h \
	  memxor.h \
Niels Möller's avatar
Niels Möller committed
192
	  nettle-meta.h nettle-types.h \
Niels Möller's avatar
Niels Möller committed
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
202
SOURCES = $(nettle_SOURCES) $(hogweed_SOURCES) \
	  $(getopt_SOURCES) $(internal_SOURCES) \
203
	  aesdata.c desdata.c twofishdata.c shadata.c gcmdata.c eccdata.c
204

205
206
DISTFILES = $(SOURCES) $(HEADERS) getopt.h getopt_int.h \
	.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 \
Niels Möller's avatar
Niels Möller committed
211
212
	README AUTHORS COPYING.LESSERv3 COPYINGv2 COPYINGv3 \
	INSTALL NEWS TODO ChangeLog \
213
	nettle.pc.in hogweed.pc.in \
Niels Möller's avatar
Niels Möller committed
214
	$(des_headers) descore.README \
215
216
	aes-internal.h camellia-internal.h serpent-internal.h \
	cast128_sboxes.h desinfo.h desCode.h \
217
	nettle-internal.h nettle-write.h \
Niels Möller's avatar
Niels Möller committed
218
	gmp-glue.h ecc-internal.h \
Niels Möller's avatar
Niels Möller committed
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
nettle_PURE_OBJS = $(nettle_OBJS:.$(OBJEXT)=.p$(OBJEXT))

226
hogweed_OBJS = $(hogweed_SOURCES:.c=.$(OBJEXT)) $(OPT_ASM_HOGWEED_SOURCES:.asm=.$(OBJEXT))
227
hogweed_PURE_OBJS = $(hogweed_OBJS:.$(OBJEXT)=.p$(OBJEXT))
228

229
libnettle.a: $(nettle_OBJS)
230
	-rm -f $@
231
	$(AR) $(ARFLAGS) $@ $(nettle_OBJS)
232
	$(RANLIB) $@
233
	echo nettle > libnettle.stamp
234

235
236
237
238
libhogweed.a: $(hogweed_OBJS)
	-rm -f $@
	$(AR) $(ARFLAGS) $@ $(hogweed_OBJS)
	$(RANLIB) $@
239
	echo hogweed > libhogweed.stamp
240

241
.c.$(OBJEXT):
242
	$(COMPILE) -c $< \
243
244
	&& $(DEP_PROCESS)

245
# Rules building shared libraries.
246
$(LIBNETTLE_FORLINK): $(nettle_PURE_OBJS)
247
	$(LIBNETTLE_LINK) $(nettle_PURE_OBJS) -o $@ $(LIBNETTLE_LIBS)
248
	-mkdir .lib 2>/dev/null
249
250
251
	(cd .lib \
          && rm -f $(LIBNETTLE_FORLINK) \
	  && $(LN_S) ../$(LIBNETTLE_FORLINK) $(LIBNETTLE_FORLINK) \
252
	  && [ -z "$(LIBNETTLE_SONAME)" ] \
253
254
	  || { rm -f $(LIBNETTLE_SONAME) \
	       && $(LN_S) $(LIBNETTLE_FORLINK) $(LIBNETTLE_SONAME) ; } )
255
	echo nettle > libnettle.stamp
256

257
$(LIBHOGWEED_FORLINK): $(hogweed_PURE_OBJS) $(LIBNETTLE_FORLINK)
258
	$(LIBHOGWEED_LINK) $(hogweed_PURE_OBJS) -o $@ $(LIBHOGWEED_LIBS)
259
	-mkdir .lib 2>/dev/null
260
261
262
	(cd .lib \
          && rm -f $(LIBHOGWEED_FORLINK) \
	  && $(LN_S) ../$(LIBHOGWEED_FORLINK) $(LIBHOGWEED_FORLINK) \
263
	  && [ -z "$(LIBHOGWEED_SONAME)" ] \
264
265
	  || { rm -f $(LIBHOGWEED_SONAME) \
	       && $(LN_S) $(LIBHOGWEED_FORLINK) $(LIBHOGWEED_SONAME) ; } )
266
	echo hogweed > libhogweed.stamp
267
268

.c.p$(OBJEXT):
269
	$(COMPILE) -c $< -o $@ \
270
271
	&& $(DEP_PROCESS)

Niels Möller's avatar
Niels Möller committed
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
# For Solaris and BSD make, we have to use an explicit rule for each
# executable. Avoid object file targets to make it easy to run the
# right compiler.
aesdata$(EXEEXT_FOR_BUILD): aesdata.c
	$(CC_FOR_BUILD) `test -f aesdata.c || echo '$(srcdir)/'`aesdata.c \
	-o aesdata$(EXEEXT_FOR_BUILD)

desdata$(EXEEXT_FOR_BUILD): desdata.c
	$(CC_FOR_BUILD) `test -f desdata.c || echo '$(srcdir)/'`desdata.c \
	-o desdata$(EXEEXT_FOR_BUILD)

twofishdata$(EXEEXT_FOR_BUILD): twofishdata.c
	$(CC_FOR_BUILD) `test -f twofishdata.c || echo '$(srcdir)/'`twofishdata.c \
	-o twofishdata$(EXEEXT_FOR_BUILD)

shadata$(EXEEXT_FOR_BUILD): shadata.c
	$(CC_FOR_BUILD) `test -f shadata.c || echo '$(srcdir)/'`shadata.c -lm \
	-o shadata$(EXEEXT_FOR_BUILD)

gcmdata$(EXEEXT_FOR_BUILD): gcmdata.c
	$(CC_FOR_BUILD) `test -f gcmdata.c || echo '$(srcdir)/'`gcmdata.c \
	-o gcmdata$(EXEEXT_FOR_BUILD)

295
eccdata$(EXEEXT_FOR_BUILD): eccdata.c mini-gmp.c mini-gmp.h
296
	$(CC_FOR_BUILD) `test -f eccdata.c || echo '$(srcdir)/'`eccdata.c \
Niels Möller's avatar
Niels Möller committed
297
	-o eccdata$(EXEEXT_FOR_BUILD)
298

299
300
# desCore rules
# It seems using $(srcdir)/ doesn't work with GNU make 3.79.1
301
302
# des_headers = $(srcdir)/rotors.h $(srcdir)/keymap.h 
des_headers = rotors.h keymap.h 
303
304
305

# Generate DES headers.
$(des_headers): desdata.c
306
	$(MAKE) desdata$(EXEEXT_FOR_BUILD)
307
	f="$(srcdir)/`basename $@`"; \
308
	  ./desdata$(EXEEXT_FOR_BUILD) $(@F) > $${f}T; \
309
	  test -s $${f}T && mv -f $${f}T $$f
310

Niels Möller's avatar
Niels Möller committed
311
des.$(OBJEXT): des.c des.h $(des_headers)
Niels Möller's avatar
Niels Möller committed
312
des.p$(OBJEXT): des.c des.h $(des_headers)
313

314
315
316
317
318
319
320
321
# Generate ECC files.
# Some possible choices for 192:
#	k = 15, c = 4,  64 entries,  ~3 KB
#	k = 20, c = 6, 128 entries,  ~6 KB
#	k = 10, c = 6, 256 entries, ~12 KB
#	k =  7, c = 6, 320 entries, ~15 KB
#	k =  9, c = 7, 512 entries, ~24 KB
ecc-192.h: eccdata.stamp
322
	./eccdata$(EXEEXT_FOR_BUILD) 192 7 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
323
324
325
326
327
328
329
# Some possible choices for 224:
#	k = 18, c = 4,  64 entries,  ~4 KB
#	k = 24, c = 6, 128 entries,  ~8 KB
#	k = 12, c = 6, 256 entries, ~16 KB
#	k =  8, c = 6, 320 entries, ~20 KB
#	k = 10, c = 7, 512 entries, ~32 KB
ecc-224.h: eccdata.stamp
330
	./eccdata$(EXEEXT_FOR_BUILD) 224 12 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
331
332
333
334
335
336
337
# Some possible choices for 256:
#	k = 20, c = 4,  64 entries,  ~4 KB
#	k = 27, c = 6, 128 entries,  ~8 KB
#	k = 14, c = 6, 256 entries, ~16 KB
#	k =  9, c = 6, 320 entries, ~20 KB
#	k = 12, c = 7, 512 entries, ~32 KB
ecc-256.h: eccdata.stamp
338
	./eccdata$(EXEEXT_FOR_BUILD) 256 14 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
339
340
341
342
343
344
345
# Some possible choices for 384:
#	k = 31, c = 4,  64 entries,  ~6 KB
#	k = 41, c = 6, 128 entries, ~12 KB
#	k = 20, c = 6, 256 entries, ~24 KB
#	k = 14, c = 6, 320 entries, ~30 KB
#	k = 18, c = 7, 512 entries, ~48 KB
ecc-384.h: eccdata.stamp
346
	./eccdata$(EXEEXT_FOR_BUILD) 384 41 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
347
348
349
350
351
352
353
# Some possible choices for 521:
#	k = 42, c = 4,  64 entries,  ~9 KB
#	k = 56, c = 6, 128 entries, ~18 KB
#	k = 28, c = 6, 256 entries, ~35 KB
#	k = 19, c = 6, 320 entries, ~44 KB
#	k = 24, c = 7, 512 entries, ~70 KB
ecc-521.h: eccdata.stamp
354
	./eccdata$(EXEEXT_FOR_BUILD) 521 56 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@
355

356
357
358
ecc-25519.h: eccdata.stamp
	./eccdata$(EXEEXT_FOR_BUILD) 255 14 6 $(GMP_NUMB_BITS) > $@T && mv $@T $@

359
eccdata.stamp: eccdata.c
360
	$(MAKE) eccdata$(EXEEXT_FOR_BUILD)
361
362
363
364
365
366
367
	echo stamp > eccdata.stamp

ecc-192.$(OBJEXT): ecc-192.h
ecc-224.$(OBJEXT): ecc-224.h
ecc-256.$(OBJEXT): ecc-256.h
ecc-384.$(OBJEXT): ecc-384.h
ecc-521.$(OBJEXT): ecc-521.h
368
ecc-25519.$(OBJEXT): ecc-25519.h
369
370
371
372
373
374

ecc-192.p$(OBJEXT): ecc-192.h
ecc-224.p$(OBJEXT): ecc-224.h
ecc-256.p$(OBJEXT): ecc-256.h
ecc-384.p$(OBJEXT): ecc-384.h
ecc-521.p$(OBJEXT): ecc-521.h
375
ecc-25519.p$(OBJEXT): ecc-25519.h
376

377
.asm.s: $(srcdir)/asm.m4 machine.m4 config.m4
378
379
380
381
	$(M4) $(srcdir)/asm.m4 machine.m4 config.m4 $< >$@T \
	&& test -s $@T && mv -f $@T $@

.s.$(OBJEXT):
382
	$(COMPILE) -c $<
383
	@echo > $@.d
384
385

.s.p$(OBJEXT):
386
	$(COMPILE) -c $< -o $@
387
	@echo > $@.d
388

389
390
# Texinfo rules
.texinfo.info:
391
	cd $(srcdir) && $(MAKEINFO) --output $@ `basename "$<"`
392
393

.texinfo.html:
394
	cd $(srcdir) && $(MAKEINFO) --html --no-split \
395
	  --output $@T `basename "$<"` \
396
	  && test -s $@T && mv -f $@T $@
397

398
.texinfo.dvi:
Niels Möller's avatar
Niels Möller committed
399
	cd $(srcdir) && texi2dvi -b `basename "$<"`
400
401

.dvi.ps:
402
	cd $(srcdir) && dvips -Ppdf -G0 -o `basename "$<" .dvi`.ps `basename "$<"`
403

404
# Avoid rebuilding .dvi and .ps files when the .texinfo source is unchanged.
405
PS2PDFFLAGS=-dCompatibilityLevel=1.3 -dMAxSubsetPct=100 -dSubsetFonts=true -dEmbedAllFonts=true
406
407
408
.texinfo.pdf:
	$(MAKE) `basename "$<" .texinfo`.ps
	cd $(srcdir) && ps2pdf $(PS2PDFFLAGS) `basename "$<" .texinfo`.ps
409

410
411
# Configure-related rules, mostly copied from the autoconf manual. No
# $(srcdir) prefixes on the targets, though.
412

413
414
configure: configure.ac aclocal.m4
	cd $(srcdir) && $(AUTOCONF)
415

416
417
418
# autoheader might not change config.h.in, so touch a stamp file.
config.h.in: stamp-h.in
stamp-h.in: configure.ac aclocal.m4
419
	cd $(srcdir) && $(AUTOHEADER)
420
	echo timestamp > $(srcdir)/stamp-h.in
421

422
423
config.status: configure
	./config.status --recheck
424

425
426
427
428
config.h: stamp-h
stamp-h: config.h.in config.status
	./config.status config.h
	echo timestamp > stamp-h
429

430
431
432
bignum.h: bignum.h.in config.status
	./config.status $@

433
434
Makefile: Makefile.in config.status
	./config.status $@
435

436
437
config.make: config.make.in config.status
	./config.status $@
438

Niels Möller's avatar
Niels Möller committed
439
440
441
config.m4: config.m4.in config.status
	./config.status $@

442
443
444
445
446
447
nettle.pc: nettle.pc.in config.status
	./config.status $@

hogweed.pc: hogweed.pc.in config.status
	./config.status $@

448
# Installation
Sam Thursfield's avatar
Sam Thursfield committed
449
450
install-doc: @IF_DOCUMENTATION@ install-info
install-here: install-doc install-headers install-static install-pkgconfig \
451
	@IF_SHARED@ install-shared-nettle @IF_HOGWEED@ install-shared-hogweed
452
453

install-static: $(LIBTARGETS)
454
	$(MKDIR_P) $(DESTDIR)$(libdir)
455
456
457
458
	for f in $(LIBTARGETS); do \
	  $(INSTALL_DATA) $$f $(DESTDIR)$(libdir) ; \
	done

459
460
461
462
463
install-dll-nettle:
	$(MKDIR_P) $(DESTDIR)$(bindir)
	$(INSTALL_DATA) $(LIBNETTLE_FORLINK) $(DESTDIR)$(bindir)/$(LIBNETTLE_FORLINK)

install-shared-nettle: $(LIBNETTLE_FORLINK) @IF_DLL@ install-dll-nettle
464
	$(MKDIR_P) $(DESTDIR)$(libdir)
465
	$(INSTALL_DATA) $(LIBNETTLE_FILE_SRC) $(DESTDIR)$(libdir)/$(LIBNETTLE_FILE)
466
467
	[ -z "$(LIBNETTLE_SONAME)" ] \
                || (cd $(DESTDIR)$(libdir) \
468
469
470
		&& rm -f $(LIBNETTLE_SONAME) $(LIBNETTLE_FORLINK) \
		&& $(LN_S) $(LIBNETTLE_FILE) $(LIBNETTLE_SONAME) \
		&& $(LN_S) $(LIBNETTLE_FILE) $(LIBNETTLE_FORLINK))
471

472
473
474
475
476
install-dll-hogweed:
	$(MKDIR_P) $(DESTDIR)$(bindir)
	$(INSTALL_DATA) $(LIBHOGWEED_FORLINK) $(DESTDIR)$(bindir)/$(LIBHOGWEED_FORLINK)

install-shared-hogweed: $(LIBHOGWEED_FORLINK) @IF_DLL@ install-dll-hogweed
477
	$(MKDIR_P) $(DESTDIR)$(libdir)
478
	$(INSTALL_DATA) $(LIBHOGWEED_FILE_SRC) $(DESTDIR)$(libdir)/$(LIBHOGWEED_FILE)
479
	[ -z "$(LIBHOGWEED_SONAME)" ] \
480
                || (cd $(DESTDIR)$(libdir) \
481
482
483
		&& rm -f $(LIBHOGWEED_SONAME) $(LIBHOGWEED_FORLINK) \
		&& $(LN_S) $(LIBHOGWEED_FILE) $(LIBHOGWEED_SONAME) \
		&& $(LN_S) $(LIBHOGWEED_FILE) $(LIBHOGWEED_FORLINK))
484

485
486
487
488
# I'd like to use makes VPATH search to locate the files to be
# installed. But it seems most make programs don't set $<, $^, $? and
# friends for ordinary explicit rules.

489
install-info: nettle.info
490
	$(MKDIR_P) $(DESTDIR)$(infodir)
491
492
493
	f=nettle.info ; \
	[ -f $$f ] || f="$(srcdir)/$$f" ; \
	$(INSTALL_DATA) "$$f" $(DESTDIR)$(infodir) ; \
494
495
	if (install-info --version && \
	    install-info --version 2>&1 | sed 1q | grep -i -v debian) >/dev/null 2>&1; then \
496
	  install-info --info-dir="$(DESTDIR)$(infodir)" "$$f" ; \
497
498
	else : ; fi

499
500
# NOTE: I'd like to use $^, but that's a GNU extension. $? should be
# more portable, and equivalent for phony targets.
501
install-headers: $(INSTALL_HEADERS)
502
	$(MKDIR_P) $(DESTDIR)$(includedir)/nettle
503
504
505
506
507
508
	for f in $(INSTALL_HEADERS) ; do \
	  if [ -f "$$f" ] ; then \
	    $(INSTALL_DATA) "$$f" $(DESTDIR)$(includedir)/nettle ; \
	  else \
	    $(INSTALL_DATA) "$(srcdir)/$$f" $(DESTDIR)$(includedir)/nettle ; \
	  fi ; done
509

510
511
512
513
514
515
install-pkgconfig: $(PKGCONFIG_FILES)
	$(MKDIR_P) $(DESTDIR)$(pkgconfigdir)
	for f in $(PKGCONFIG_FILES) ; do \
	  $(INSTALL_DATA) "$$f" $(DESTDIR)$(pkgconfigdir) ; \
	done

516
# Uninstall
517
uninstall-here: uninstall-info uninstall-headers uninstall-static \
518
		uninstall-pkgconfig @IF_SHARED@ uninstall-shared
519
520

uninstall-static:
521
	for f in $(LIBTARGETS) ; do \
522
523
	  rm -f $(DESTDIR)$(libdir)/$$f ; \
	done
524
525
526
527
528
529
530
531
532
533
534
535
536
537

uninstall-headers:
	for f in $(INSTALL_HEADERS) ; do \
	  rm -f $(DESTDIR)$(includedir)/nettle/$$f ; \
	done

uninstall-info:
	if (install-info --version && \
	    install-info --version 2>&1 | sed 1q | grep -i -v debian) >/dev/null 2>&1; then \
	  install-info --info-dir="$(DESTDIR)$(infodir)" --remove "$(DESTDIR)$(infodir)"/nettle.info ; \
	else : ; fi
	-rm -f $(DESTDIR)$(infodir)/nettle.info

# FIXME: Leaves the links around
538
539
uninstall-shared: uninstall-shared-nettle @IF_HOGWEED@ uninstall-shared-hogweed

540
541
542
543
uninstall-dll-nettle:
	rm -f $(DESTDIR)$(bindir)/$(LIBNETTLE_FORLINK)

uninstall-shared-nettle: @IF_DLL@ uninstall-dll-nettle
544
545
546
547
	rm -f $(DESTDIR)$(libdir)/$(LIBNETTLE_FILE)
	[ -z "$(LIBNETTLE_SONAME)" ] \
		|| rm -f $(LIBNETTLE_SONAME) $(LIBNETTLE_FORLINK)

548
549
550
551
uninstall-dll-hogweed:
	rm -f $(DESTDIR)$(bindir)/$(LIBHOGWEED_FORLINK)

uninstall-shared-hogweed: @IF_DLL@ uninstall-dll-hogweed
552
553
554
	rm -f $(DESTDIR)$(libdir)/$(LIBHOGWEED_FILE)
	[ -z "$(LIBHOGWEED_SONAME)" ] \
		|| rm -f $(LIBHOGWEED_SONAME) $(LIBHOGWEED_FORLINK)
555

556
557
558
559
560
uninstall-pkgconfig:
	for f in $(PKGCONFIG_FILES) ; do \
	  rm -f $(DESTDIR)$(pkgconfigdir)/$$f ; \
	done

561
562
563
564
# Distribution
distdir = $(PACKAGE_NAME)-$(PACKAGE_VERSION)
top_distdir = $(distdir)

Niels Möller's avatar
Niels Möller committed
565
# NOTE: We should handle both absolute and relative $destdir.
566

567
distdir: $(DISTFILES)
568
569
	rm -rf "$(distdir)"
	mkdir "$(distdir)"
570
	set -e; for f in $(DISTFILES) ; do \
571
	  if [ -f "$$f" ] ; then cp "$$f" "$(distdir)" ; \
572
573
574
	  else cp "$(srcdir)/$$f" "$(distdir)" ; \
	  fi ; \
	done
575
	set -e; for d in sparc32 sparc64 x86 x86_64 arm arm/neon arm/v6 ; do \
576
	  mkdir "$(distdir)/$$d" ; \
Niels Möller's avatar
Niels Möller committed
577
578
	  find "$(srcdir)/$$d" -maxdepth 1 '(' -name '*.asm' -o -name '*.m4' ')' \
	    -exec cp '{}' "$(distdir)/$$d" ';' ; \
579
	done
580
	set -e; for d in $(SUBDIRS); do \
581
582
	  sd="$(distdir)/$$d" ; \
	  mkdir "$$sd" && $(MAKE) -C $$d distdir="`cd $$sd && pwd`" $@ ; \
583
584
585
586
587
588
589
590
	done

dist: distdir
	tar cf - $(distdir) | gzip -c >$(distdir).tar.gz	
	rm -rf $(distdir)

rm_distcheck = test ! -d distcheck-tmp \
	    || { find distcheck-tmp -type d ! -perm -200 -exec chmod u+w {} ';' \
591
                 && rm -fr distcheck-tmp; }; 
592
593
594
595

distcheck: dist
	$(rm_distcheck)
	mkdir distcheck-tmp
596
597
	gzip -d < $(distdir).tar.gz \
	  | { cd distcheck-tmp && tar xf - && chmod -R a-w $(distdir) ; }
598
599
	mkdir distcheck-tmp/build
	mkdir distcheck-tmp/install
600
	cd distcheck-tmp/build && ../$(distdir)/configure --prefix="`cd ../install && pwd`"
601
602
603
	cd distcheck-tmp/build && $(MAKE)
	cd distcheck-tmp/build && $(MAKE) check
	cd distcheck-tmp/build && $(MAKE) install
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
	cd distcheck-tmp/build && $(MAKE) uninstall
	cd distcheck-tmp && find install -type f -print > leftover-install-files
	@test `cat distcheck-tmp/leftover-install-files | wc -l` -le 1  \
	  || { echo "ERROR: files left after uninstall:" ; \
	       cat distcheck-tmp/leftover-install-files ; \
	       exit 1; }
	chmod -R a-w distcheck-tmp/install
	mkdir distcheck-tmp/destdir
	destdir="`cd distcheck-tmp/destdir && pwd`" \
	  && cd distcheck-tmp/build \
	  && $(MAKE) install DESTDIR="$$destdir" \
	  && $(MAKE) uninstall DESTDIR="$$destdir"
	cd distcheck-tmp && find destdir -type f -print > leftover-destdir-files
	@test `cat distcheck-tmp/leftover-destdir-files | wc -l` -le 1  \
	  || { echo "ERROR: destdir files left after uninstall:" ; \
	       cat distcheck-tmp/leftover-destdir-files ; \
	       exit 1; }	
621
622
	cd distcheck-tmp/build && $(MAKE) dist
	cd distcheck-tmp/build && rm *.gz
623
	cd distcheck-tmp/build && $(MAKE) distclean
624
625
	cd distcheck-tmp && find build -type f -print > leftover-build-files
	@test `cat distcheck-tmp/leftover-build-files | wc -l` -eq 0  \
626
	  || { echo "ERROR: files left in build directory after distclean:" ; \
627
	       cat distcheck-tmp/leftover-build-files ; \
628
629
630
631
	       exit 1; }
	$(rm_distcheck)

clean-here:
632
	-rm -f $(TARGETS) $(IMPLICIT_TARGETS) *.$(OBJEXT) *.p$(OBJEXT) *.s \
633
		ecc-192.h ecc-224.h ecc-256.h ecc-384.h ecc-521.h ecc-25519.h \
634
		eccdata$(EXEEXT_FOR_BUILD) eccdata.stamp
635
	-rm -rf .lib libnettle.stamp libhogweed.stamp
636

637
distclean-here: clean-here
638
	-rm -f config.h stamp-h config.log config.status machine.m4 \
639
	config.make config.m4 Makefile nettle-stdint.h bignum.h \
640
641
	nettle.pc hogweed.pc \
	*.asm *.d
642

643
644
645
maintainer-clean-here:
	-rm -f $(DOCTARGETS) *.dvi *.ps

646
tags-here:	
647
	etags -o $(srcdir)/TAGS $(srcdir)/*.c $(srcdir)/*.h
648

649
DEP_FILES = $(SOURCES:.c=.$(OBJEXT).d) $(SOURCES:.c=.p$(OBJEXT).d) asm.d
650
@DEP_INCLUDE@ $(DEP_FILES)