Mercurial > dropbear
comparison Makefile.in @ 285:1b9e69c058d2
propagate from branch 'au.asn.ucc.matt.ltc.dropbear' (head 20dccfc09627970a312d77fb41dc2970b62689c3)
to branch 'au.asn.ucc.matt.dropbear' (head fdf4a7a3b97ae5046139915de7e40399cceb2c01)
author | Matt Johnston <matt@ucc.asn.au> |
---|---|
date | Wed, 08 Mar 2006 13:23:58 +0000 |
parents | 997e6f7dc01e eed26cff980b |
children | 9d110777f345 dc6173e09ff7 7a11f8de297c |
comparison
equal
deleted
inserted
replaced
281:997e6f7dc01e | 285:1b9e69c058d2 |
---|---|
1 # MAKEFILE for linux GCC | 1 # This Makefile is for Dropbear SSH Server and Client |
2 # @configure_input@ | |
3 | |
4 # invocation: | |
5 # make PROGRAMS="dropbear dbclient scp" MULTI=1 STATIC=1 SCPPROGRESS=1 | |
2 # | 6 # |
3 # Tom St Denis | 7 # to make a multiple-program statically linked binary "staticdropbearmulti". |
4 # Modified by Clay Culver | 8 # This example will include dropbear, scp, dropbearkey, dropbearconvert, and |
5 | 9 # dbclient functionality, and includes the progress-bar functionality in scp. |
6 # The version | 10 # Hopefully that seems intuitive. |
7 VERSION=1.05 | 11 |
12 ifndef PROGRAMS | |
13 PROGRAMS=dropbear dbclient dropbearkey dropbearconvert | |
14 endif | |
15 | |
16 LTC=libtomcrypt/libtomcrypt.a | |
17 LTM=libtommath/libtommath.a | |
18 | |
19 COMMONOBJS=dbutil.o buffer.o \ | |
20 dss.o bignum.o \ | |
21 signkey.o rsa.o random.o \ | |
22 queue.o \ | |
23 atomicio.o compat.o fake-rfc2553.o | |
24 | |
25 SVROBJS=svr-kex.o svr-algo.o svr-auth.o sshpty.o \ | |
26 svr-authpasswd.o svr-authpubkey.o svr-session.o svr-service.o \ | |
27 svr-chansession.o svr-runopts.o svr-agentfwd.o svr-main.o svr-x11fwd.o\ | |
28 svr-tcpfwd.o svr-authpam.o | |
29 | |
30 CLIOBJS=cli-algo.o cli-main.o cli-auth.o cli-authpasswd.o cli-kex.o \ | |
31 cli-session.o cli-service.o cli-runopts.o cli-chansession.o \ | |
32 cli-authpubkey.o cli-tcpfwd.o cli-channel.o cli-authinteract.o | |
33 | |
34 CLISVROBJS=common-session.o packet.o common-algo.o common-kex.o \ | |
35 common-channel.o common-chansession.o termcodes.o loginrec.o \ | |
36 tcp-accept.o listener.o process-packet.o \ | |
37 common-runopts.o circbuffer.o | |
38 | |
39 KEYOBJS=dropbearkey.o gendss.o genrsa.o | |
40 | |
41 CONVERTOBJS=dropbearconvert.o keyimport.o | |
42 | |
43 SCPOBJS=scp.o progressmeter.o atomicio.o scpmisc.o | |
44 | |
45 HEADERS=options.h dbutil.h session.h packet.h algo.h ssh.h buffer.h kex.h \ | |
46 dss.h bignum.h signkey.h rsa.h random.h service.h auth.h \ | |
47 debug.h channel.h chansession.h config.h queue.h sshpty.h \ | |
48 termcodes.h gendss.h genrsa.h runopts.h includes.h \ | |
49 loginrec.h atomicio.h x11fwd.h agentfwd.h tcpfwd.h compat.h \ | |
50 listener.h fake-rfc2553.h | |
51 | |
52 dropbearobjs=$(COMMONOBJS) $(CLISVROBJS) $(SVROBJS) | |
53 dbclientobjs=$(COMMONOBJS) $(CLISVROBJS) $(CLIOBJS) | |
54 dropbearkeyobjs=$(COMMONOBJS) $(KEYOBJS) | |
55 dropbearconvertobjs=$(COMMONOBJS) $(CONVERTOBJS) | |
56 scpobjs=$(SCPOBJS) | |
8 | 57 |
9 VPATH=@srcdir@ | 58 VPATH=@srcdir@ |
10 srcdir=@srcdir@ | 59 srcdir=@srcdir@ |
11 | 60 |
12 # Compiler and Linker Names | 61 prefix=@prefix@ |
13 #CC=gcc | 62 exec_prefix=${prefix} |
14 #LD=ld | 63 bindir=${exec_prefix}/bin |
15 | 64 sbindir=${exec_prefix}/sbin |
16 # Archiver [makes .a files] | 65 |
17 #AR=ar | 66 CC=@CC@ |
18 #ARFLAGS=r | 67 LD=@LD@ |
19 | 68 AR=@AR@ |
20 # Compilation flags. Note the += does not write over the user's CFLAGS! | 69 RANLIB=@RANLIB@ |
21 # The rest of the flags come from the parent Dropbear makefile | 70 STRIP=@STRIP@ |
22 CFLAGS += -c -I$(srcdir)/src/headers/ -I$(srcdir)/../ | 71 INSTALL=@INSTALL@ |
23 | 72 CFLAGS=-I. -I$(srcdir)/libtomcrypt/src/headers/ @CFLAGS@ |
24 # additional warnings (newer GCC 3.4 and higher) | 73 LIBS=$(LTC) $(LTM) @LIBS@ |
25 #CFLAGS += -Wsystem-headers -Wdeclaration-after-statement -Wbad-function-cast -Wcast-align -Wstrict-prototypes -Wmissing-prototypes \ | 74 LDFLAGS=@LDFLAGS@ |
26 # -Wmissing-declarations -Wpointer-arith | 75 |
27 | 76 EXEEXT=@EXEEXT@ |
28 # optimize for SPEED | 77 |
29 #CFLAGS += -O3 -funroll-loops | 78 # whether we're building client, server, or both for the common objects. |
30 | 79 # evilness so we detect 'dropbear' by itself as a word |
31 # add -fomit-frame-pointer. hinders debugging! | 80 space:= $(empty) $(empty) |
32 #CFLAGS += -fomit-frame-pointer | 81 ifneq (,$(strip $(foreach prog, $(PROGRAMS), $(findstring ZdropbearZ, Z$(prog)Z)))) |
33 | 82 CFLAGS+= -DDROPBEAR_SERVER |
34 # optimize for SIZE | 83 endif |
35 #CFLAGS += -Os -DLTC_SMALL_CODE | 84 ifneq (,$(strip $(foreach prog, $(PROGRAMS), $(findstring ZdbclientZ, Z$(prog)Z)))) |
36 | 85 CFLAGS+= -DDROPBEAR_CLIENT |
37 # older GCCs can't handle the "rotate with immediate" ROLc/RORc/etc macros | 86 endif |
38 # define this to help | 87 |
39 #CFLAGS += -DLTC_NO_ROLC | 88 |
40 | 89 # these are exported so that libtomcrypt's makefile will use them |
41 # compile for DEBUGING (required for ccmalloc checking!!!) | 90 export CC |
42 #CFLAGS += -g3 -DLTC_NO_ASM | 91 export CFLAGS |
43 | 92 export RANLIB AR STRIP |
44 #Output filenames for various targets. | 93 |
45 LIBNAME=libtomcrypt.a | 94 ifeq ($(STATIC), 1) |
46 LIBTEST=testprof/libtomcrypt_prof.a | 95 LDFLAGS+=-static |
47 HASH=hashsum | 96 endif |
48 CRYPT=encrypt | 97 |
49 SMALL=small | 98 ifeq ($(MULTI), 1) |
50 PROF=x86_prof | 99 TARGETS=dropbearmulti |
51 TV=tv_gen | |
52 MULTI=multi | |
53 TIMING=timing | |
54 TEST=test | |
55 | |
56 #LIBPATH-The directory for libtomcrypt to be installed to. | |
57 #INCPATH-The directory to install the header files for libtomcrypt. | |
58 #DATAPATH-The directory to install the pdf docs. | |
59 DESTDIR= | |
60 LIBPATH=/usr/lib | |
61 INCPATH=/usr/include | |
62 DATAPATH=/usr/share/doc/libtomcrypt/pdf | |
63 | |
64 #Who do we install as? | |
65 ifdef INSTALL_USER | |
66 USER=$(INSTALL_USER) | |
67 else | 100 else |
68 USER=root | 101 TARGETS=$(PROGRAMS) |
69 endif | 102 endif |
70 | 103 |
71 ifdef INSTALL_GROUP | 104 # for the scp progress meter. The -D doesn't affect anything else. |
72 GROUP=$(INSTALL_GROUP) | 105 ifeq ($(SCPPROGRESS), 1) |
73 else | 106 CFLAGS+=-DPROGRESS_METER |
74 GROUP=wheel | 107 endif |
75 endif | 108 |
76 | 109 #%: $(HEADERS) |
77 #List of objects to compile. | 110 #%: $(HEADERS) Makefile |
78 | 111 # TODO |
79 #Leave MPI built-in or force developer to link against libtommath? | 112 |
80 #MPIOBJECT=src/misc/mpi/mpi.o | 113 all: $(TARGETS) |
81 #Dropbear uses libtommath | 114 |
82 MPIOBJECT= | 115 strip: $(TARGETS) |
83 | 116 $(STRIP) $(addsuffix $(EXEEXT), $(TARGETS)) |
84 OBJECTS=src/ciphers/aes/aes_enc.o $(MPIOBJECT) src/ciphers/aes/aes.o src/ciphers/anubis.o \ | 117 |
85 src/ciphers/blowfish.o src/ciphers/cast5.o src/ciphers/des.o src/ciphers/khazad.o src/ciphers/noekeon.o \ | 118 install: $(addprefix inst_, $(TARGETS)) |
86 src/ciphers/rc2.o src/ciphers/rc5.o src/ciphers/rc6.o src/ciphers/safer/safer.o \ | 119 |
87 src/ciphers/safer/safer_tab.o src/ciphers/safer/saferp.o src/ciphers/skipjack.o \ | 120 installdropbearmulti: insdbmulti $(addprefix insmulti, $(PROGRAMS)) |
88 src/ciphers/twofish/twofish.o src/ciphers/xtea.o src/encauth/ccm/ccm_memory.o \ | 121 |
89 src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o src/encauth/eax/eax_decrypt.o \ | 122 insdbmulti: dropbearmulti |
90 src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o src/encauth/eax/eax_encrypt.o \ | 123 $(INSTALL) -d -m 755 $(DESTDIR)$(bindir) |
91 src/encauth/eax/eax_encrypt_authenticate_memory.o src/encauth/eax/eax_init.o \ | 124 $(INSTALL) -m 755 dropbearmulti$(EXEEXT) $(DESTDIR)$(bindir) |
92 src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o src/encauth/gcm/gcm_add_iv.o \ | 125 -chown root $(DESTDIR)$(bindir)/dropbearmulti$(EXEEXT) |
93 src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o src/encauth/gcm/gcm_init.o \ | 126 -chgrp 0 $(DESTDIR)$(bindir)/dropbearmulti$(EXEEXT) |
94 src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_process.o src/encauth/gcm/gcm_reset.o \ | 127 |
95 src/encauth/gcm/gcm_test.o src/encauth/ocb/ocb_decrypt.o src/encauth/ocb/ocb_decrypt_verify_memory.o \ | 128 insmultidropbear: dropbearmulti |
96 src/encauth/ocb/ocb_done_decrypt.o src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | 129 -rm -f $(DESTDIR)$(sbindir)/dropbear$(EXEEXT) |
97 src/encauth/ocb/ocb_encrypt_authenticate_memory.o src/encauth/ocb/ocb_init.o src/encauth/ocb/ocb_ntz.o \ | 130 -ln -s $(DESTDIR)$(bindir)/dropbearmulti$(EXEEXT) $(DESTDIR)$(sbindir)/dropbear$(EXEEXT) |
98 src/encauth/ocb/ocb_shift_xor.o src/encauth/ocb/ocb_test.o src/encauth/ocb/s_ocb_done.o \ | 131 |
99 src/hashes/chc/chc.o src/hashes/helper/hash_file.o src/hashes/helper/hash_filehandle.o \ | 132 insmulti%: dropbearmulti |
100 src/hashes/helper/hash_memory.o src/hashes/helper/hash_memory_multi.o src/hashes/md2.o src/hashes/md4.o \ | 133 -rm -f $(DESTDIR)$(bindir)/$*$(EXEEXT) |
101 src/hashes/md5.o src/hashes/rmd128.o src/hashes/rmd160.o src/hashes/sha1.o src/hashes/sha2/sha256.o \ | 134 -ln -s $(DESTDIR)$(bindir)/dropbearmulti$(EXEEXT) $(DESTDIR)$(bindir)/$*$(EXEEXT) |
102 src/hashes/sha2/sha512.o src/hashes/tiger.o src/hashes/whirl/whirl.o src/mac/hmac/hmac_done.o \ | 135 |
103 src/mac/hmac/hmac_file.o src/mac/hmac/hmac_init.o src/mac/hmac/hmac_memory.o \ | 136 # dropbear should go in sbin, so it needs a seperate rule |
104 src/mac/hmac/hmac_memory_multi.o src/mac/hmac/hmac_process.o src/mac/hmac/hmac_test.o \ | 137 inst_dropbear: dropbear |
105 src/mac/omac/omac_done.o src/mac/omac/omac_file.o src/mac/omac/omac_init.o src/mac/omac/omac_memory.o \ | 138 $(INSTALL) -d -m 755 $(DESTDIR)$(sbindir) |
106 src/mac/omac/omac_memory_multi.o src/mac/omac/omac_process.o src/mac/omac/omac_test.o \ | 139 $(INSTALL) -m 755 dropbear$(EXEEXT) $(DESTDIR)$(sbindir) |
107 src/mac/pelican/pelican.o src/mac/pelican/pelican_memory.o src/mac/pelican/pelican_test.o \ | 140 -chown root $(DESTDIR)$(sbindir)/dropbear$(EXEEXT) |
108 src/mac/pmac/pmac_done.o src/mac/pmac/pmac_file.o src/mac/pmac/pmac_init.o src/mac/pmac/pmac_memory.o \ | 141 -chgrp 0 $(DESTDIR)$(sbindir)/dropbear$(EXEEXT) |
109 src/mac/pmac/pmac_memory_multi.o src/mac/pmac/pmac_ntz.o src/mac/pmac/pmac_process.o \ | 142 |
110 src/mac/pmac/pmac_shift_xor.o src/mac/pmac/pmac_test.o src/misc/base64/base64_decode.o \ | 143 inst_%: $* |
111 src/misc/base64/base64_encode.o src/misc/burn_stack.o src/misc/crypt/crypt.o \ | 144 $(INSTALL) -d -m 755 $(DESTDIR)$(bindir) |
112 src/misc/crypt/crypt_argchk.o src/misc/crypt/crypt_cipher_descriptor.o \ | 145 $(INSTALL) -m 755 $*$(EXEEXT) $(DESTDIR)$(bindir) |
113 src/misc/crypt/crypt_cipher_is_valid.o src/misc/crypt/crypt_find_cipher.o \ | 146 -chown root $(DESTDIR)$(bindir)/$*$(EXEEXT) |
114 src/misc/crypt/crypt_find_cipher_any.o src/misc/crypt/crypt_find_cipher_id.o \ | 147 -chgrp 0 $(DESTDIR)$(bindir)/$*$(EXEEXT) |
115 src/misc/crypt/crypt_find_hash.o src/misc/crypt/crypt_find_hash_any.o \ | 148 |
116 src/misc/crypt/crypt_find_hash_id.o src/misc/crypt/crypt_find_prng.o \ | 149 |
117 src/misc/crypt/crypt_hash_descriptor.o src/misc/crypt/crypt_hash_is_valid.o \ | 150 # for some reason the rule further down doesn't like $($@objs) as a prereq. |
118 src/misc/crypt/crypt_prng_descriptor.o src/misc/crypt/crypt_prng_is_valid.o \ | 151 dropbear: $(dropbearobjs) |
119 src/misc/crypt/crypt_register_cipher.o src/misc/crypt/crypt_register_hash.o \ | 152 dbclient: $(dbclientobjs) |
120 src/misc/crypt/crypt_register_prng.o src/misc/crypt/crypt_unregister_cipher.o \ | 153 dropbearkey: $(dropbearkeyobjs) |
121 src/misc/crypt/crypt_unregister_hash.o src/misc/crypt/crypt_unregister_prng.o \ | 154 dropbearconvert: $(dropbearconvertobjs) |
122 src/misc/error_to_string.o src/misc/mpi/is_prime.o src/misc/mpi/mpi_to_ltc_error.o \ | 155 |
123 src/misc/mpi/rand_prime.o src/misc/pkcs5/pkcs_5_1.o src/misc/pkcs5/pkcs_5_2.o src/misc/zeromem.o \ | 156 dropbear dbclient dropbearkey dropbearconvert: $(HEADERS) $(LTC) $(LTM) \ |
124 src/modes/cbc/cbc_decrypt.o src/modes/cbc/cbc_done.o src/modes/cbc/cbc_encrypt.o \ | 157 Makefile |
125 src/modes/cbc/cbc_getiv.o src/modes/cbc/cbc_setiv.o src/modes/cbc/cbc_start.o \ | 158 $(LD) $(LDFLAGS) -o $@$(EXEEXT) $($@objs) $(LIBS) |
126 src/modes/cfb/cfb_decrypt.o src/modes/cfb/cfb_done.o src/modes/cfb/cfb_encrypt.o \ | 159 |
127 src/modes/cfb/cfb_getiv.o src/modes/cfb/cfb_setiv.o src/modes/cfb/cfb_start.o \ | 160 # scp doesn't use the libs so is special. |
128 src/modes/ctr/ctr_decrypt.o src/modes/ctr/ctr_done.o src/modes/ctr/ctr_encrypt.o \ | 161 scp: $(SCPOBJS) $(HEADERS) Makefile |
129 src/modes/ctr/ctr_getiv.o src/modes/ctr/ctr_setiv.o src/modes/ctr/ctr_start.o \ | 162 $(LD) $(LDFLAGS) -o $@$(EXEEXT) $(SCPOBJS) |
130 src/modes/ecb/ecb_decrypt.o src/modes/ecb/ecb_done.o src/modes/ecb/ecb_encrypt.o \ | 163 |
131 src/modes/ecb/ecb_start.o src/modes/ofb/ofb_decrypt.o src/modes/ofb/ofb_done.o \ | 164 |
132 src/modes/ofb/ofb_encrypt.o src/modes/ofb/ofb_getiv.o src/modes/ofb/ofb_setiv.o \ | 165 # multi-binary compilation. |
133 src/modes/ofb/ofb_start.o | 166 MULTIOBJS= |
134 | 167 ifeq ($(MULTI),1) |
135 HEADERS=src/headers/tommath_superclass.h src/headers/tomcrypt_cfg.h src/headers/tomcrypt_mac.h \ | 168 MULTIOBJS=dbmulti.o $(sort $(foreach prog, $(PROGRAMS), $($(prog)objs))) |
136 src/headers/tomcrypt_macros.h src/headers/tomcrypt_custom.h src/headers/tomcrypt_argchk.h \ | 169 CFLAGS+=$(addprefix -DDBMULTI_, $(PROGRAMS)) -DDROPBEAR_MULTI |
137 src/headers/tomcrypt_cipher.h src/headers/tomcrypt_pk.h src/headers/tommath_class.h \ | 170 endif |
138 src/headers/ltc_tommath.h src/headers/tomcrypt_hash.h src/headers/tomcrypt_misc.h \ | 171 |
139 src/headers/tomcrypt.h src/headers/tomcrypt_pkcs.h src/headers/tomcrypt_prng.h testprof/tomcrypt_test.h | 172 dropbearmulti: multilink |
140 | 173 |
141 TESTOBJECTS=demos/test.o | 174 multibinary: $(HEADERS) $(MULTIOBJS) $(LTC) $(LTM) Makefile |
142 HASHOBJECTS=demos/hashsum.o | 175 $(LD) $(LDFLAGS) -o dropbearmulti$(EXEEXT) $(MULTIOBJS) $(LIBS) |
143 CRYPTOBJECTS=demos/encrypt.o | 176 |
144 SMALLOBJECTS=demos/small.o | 177 multilink: multibinary $(addprefix link, $(PROGRAMS)) |
145 TVS=demos/tv_gen.o | 178 |
146 MULTIS=demos/multi.o | 179 link%: |
147 TIMINGS=demos/timing.o | 180 -rm -f $*$(EXEEXT) |
148 TESTS=demos/test.o | 181 -ln -s dropbearmulti$(EXEEXT) $*$(EXEEXT) |
149 | 182 |
150 #Files left over from making the crypt.pdf. | 183 $(LTC): options.h |
151 LEFTOVERS=*.dvi *.log *.aux *.toc *.idx *.ilg *.ind *.out | 184 cd libtomcrypt && $(MAKE) clean && $(MAKE) |
152 | 185 |
153 #Compressed filenames | 186 $(LTM): options.h |
154 COMPRESSED=crypt-$(VERSION).tar.bz2 crypt-$(VERSION).zip | 187 cd libtommath && $(MAKE) |
155 | 188 |
156 #The default rule for make builds the libtomcrypt library. | 189 ltc-clean: |
157 default:library | 190 cd libtomcrypt && $(MAKE) clean |
158 | 191 |
159 #ciphers come in two flavours... enc+dec and enc | 192 ltm-clean: |
160 src/ciphers/aes/aes_enc.o: src/ciphers/aes/aes.c src/ciphers/aes/aes_tab.c | 193 cd libtommath && $(MAKE) clean |
161 $(CC) $(CFLAGS) -DENCRYPT_ONLY -c src/ciphers/aes/aes.c -o src/ciphers/aes/aes_enc.o | 194 |
162 | 195 sizes: dropbear |
163 #These are the rules to make certain object files. | 196 objdump -t dropbear|grep ".text"|cut -d "." -f 2|sort -rn |
164 src/ciphers/aes/aes.o: src/ciphers/aes/aes.c src/ciphers/aes/aes_tab.c | 197 |
165 src/ciphers/twofish/twofish.o: src/ciphers/twofish/twofish.c src/ciphers/twofish/twofish_tab.c | 198 clean: ltc-clean ltm-clean thisclean |
166 src/hashes/whirl/whirl.o: src/hashes/whirl/whirl.c src/hashes/whirl/whirltab.c | 199 |
167 src/pk/ecc/ecc.o: src/pk/ecc/ecc.c src/pk/ecc/ecc_sys.c | 200 thisclean: |
168 src/pk/dh/dh.o: src/pk/dh/dh.c src/pk/dh/dh_sys.c | 201 -rm -f dropbear dbclient dropbearkey dropbearconvert scp scp-progress \ |
169 src/hashes/sha2/sha512.o: src/hashes/sha2/sha512.c src/hashes/sha2/sha384.c | 202 dropbearmulti *.o *.da *.bb *.bbg *.prof |
170 src/hashes/sha2/sha256.o: src/hashes/sha2/sha256.c src/hashes/sha2/sha224.c | 203 |
171 | 204 distclean: clean tidy |
172 #This rule makes the libtomcrypt library. | 205 -rm -f config.h |
173 library: $(LIBNAME) | 206 -rm -f Makefile |
174 | 207 |
175 $(LIBTEST): | 208 tidy: |
176 cd testprof ; CFLAGS="$(CFLAGS)" make | 209 -rm -f *~ *.gcov */*~ |
177 | |
178 $(LIBNAME): $(OBJECTS) | |
179 $(AR) $(ARFLAGS) $@ $(OBJECTS) | |
180 $(RANLIB) $(LIBNAME) | |
181 | |
182 #This rule makes the hash program included with libtomcrypt | |
183 hashsum: library $(HASHOBJECTS) | |
184 $(CC) $(HASHOBJECTS) $(LIBNAME) -o $(HASH) $(WARN) | |
185 | |
186 #makes the crypt program | |
187 crypt: library $(CRYPTOBJECTS) | |
188 $(CC) $(CRYPTOBJECTS) $(LIBNAME) -o $(CRYPT) $(WARN) | |
189 | |
190 #makes the small program | |
191 small: library $(SMALLOBJECTS) | |
192 $(CC) $(SMALLOBJECTS) $(LIBNAME) -o $(SMALL) $(WARN) | |
193 | |
194 tv_gen: library $(TVS) | |
195 $(CC) $(TVS) $(LIBNAME) -o $(TV) | |
196 | |
197 multi: library $(MULTIS) | |
198 $(CC) $(MULTIS) $(LIBNAME) -o $(MULTI) | |
199 | |
200 timing: library $(LIBTEST) $(TIMINGS) | |
201 $(CC) $(TIMINGS) $(LIBTEST) $(LIBNAME) $(EXTRALIBS) -o $(TIMING) | |
202 | |
203 test: library $(LIBTEST) $(TESTS) | |
204 $(CC) $(TESTS) $(LIBTEST) $(LIBNAME) -o $(TEST) | |
205 | |
206 | |
207 #This rule installs the library and the header files. This must be run | |
208 #as root in order to have a high enough permission to write to the correct | |
209 #directories and to set the owner and group to root. | |
210 install: library docs | |
211 install -d -g $(GROUP) -o $(USER) $(DESTDIR)$(LIBPATH) | |
212 install -d -g $(GROUP) -o $(USER) $(DESTDIR)$(INCPATH) | |
213 install -d -g $(GROUP) -o $(USER) $(DESTDIR)$(DATAPATH) | |
214 install -g $(GROUP) -o $(USER) $(LIBNAME) $(DESTDIR)$(LIBPATH) | |
215 install -g $(GROUP) -o $(USER) $(HEADERS) $(DESTDIR)$(INCPATH) | |
216 install -g $(GROUP) -o $(USER) doc/crypt.pdf $(DESTDIR)$(DATAPATH) | |
217 | |
218 install_test: $(LIBTEST) | |
219 install -d -g $(GROUP) -o $(USER) $(DESTDIR)$(LIBPATH) | |
220 install -d -g $(GROUP) -o $(USER) $(DESTDIR)$(INCPATH) | |
221 install -g $(GROUP) -o $(USER) $(LIBTEST) $(DESTDIR)$(LIBPATH) | |
222 | |
223 profile: | |
224 CFLAGS="$(CFLAGS) -fprofile-generate" make timing EXTRALIBS=-lgcov | |
225 ./timing | |
226 rm -f timing `find . -type f | grep [.][ao] | xargs` | |
227 CFLAGS="$(CFLAGS) -fprofile-use" make timing EXTRALIBS=-lgcov | |
228 | |
229 | |
230 #This rule cleans the source tree of all compiled code, not including the pdf | |
231 #documentation. | |
232 clean: | |
233 -rm -f $(OBJECTS) | |
234 -rm -f libtomcrypt.a | |
235 | |
236 #build the doxy files (requires Doxygen, tetex and patience) | |
237 doxy: | |
238 doxygen | |
239 cd doc/doxygen/latex ; make ; mv -f refman.pdf ../../. | |
240 echo The huge doxygen PDF should be available as doc/refman.pdf | |
241 | |
242 #This builds the crypt.pdf file. Note that the rm -f *.pdf has been removed | |
243 #from the clean command! This is because most people would like to keep the | |
244 #nice pre-compiled crypt.pdf that comes with libtomcrypt! We only need to | |
245 #delete it if we are rebuilding it. | |
246 docs: crypt.tex | |
247 rm -f doc/crypt.pdf $(LEFTOVERS) | |
248 echo "hello" > crypt.ind | |
249 latex crypt > /dev/null | |
250 latex crypt > /dev/null | |
251 makeindex crypt.idx > /dev/null | |
252 latex crypt > /dev/null | |
253 dvipdf crypt | |
254 mv -ivf crypt.pdf doc/crypt.pdf | |
255 rm -f $(LEFTOVERS) | |
256 | |
257 docdvi: crypt.tex | |
258 echo hello > crypt.ind | |
259 latex crypt > /dev/null | |
260 latex crypt > /dev/null | |
261 makeindex crypt.idx | |
262 latex crypt > /dev/null | |
263 | |
264 #zipup the project (take that!) | |
265 no_oops: clean | |
266 cd .. ; cvs commit | |
267 echo Scanning for scratch/dirty files | |
268 find . -type f | grep -v CVS | xargs -n 1 bash mess.sh | |
269 | |
270 zipup: no_oops docs | |
271 cd .. ; rm -rf crypt* libtomcrypt-$(VERSION) ; mkdir libtomcrypt-$(VERSION) ; \ | |
272 cp -R ./libtomcrypt/* ./libtomcrypt-$(VERSION)/ ; \ | |
273 cd libtomcrypt-$(VERSION) ; rm -rf `find . -type d | grep CVS | xargs` ; cd .. ; \ | |
274 tar -cjvf crypt-$(VERSION).tar.bz2 libtomcrypt-$(VERSION) ; \ | |
275 zip -9r crypt-$(VERSION).zip libtomcrypt-$(VERSION) ; \ | |
276 gpg -b -a crypt-$(VERSION).tar.bz2 ; gpg -b -a crypt-$(VERSION).zip ; \ | |
277 mv -fv crypt* ~ ; rm -rf libtomcrypt-$(VERSION) | |
278 | |
279 | |
280 # $Source: /cvs/libtom/libtomcrypt/makefile,v $ | |
281 # $Revision: 1.70 $ | |
282 # $Date: 2005/06/19 18:03:24 $ |