blob: 0777d41b3b27288d64327e1cce8c1d7661adb2ce [file] [log] [blame]
Paul Bakker0049c2f2009-07-11 19:15:43 +00001
2# To compile on SunOS: add "-lsocket -lnsl" to LDFLAGS
Paul Bakker62f88dc2012-05-10 21:26:28 +00003# To compile on MinGW: add "-lws2_32" to LDFLAGS or define WINDOWS in your env
Paul Bakker43b7e352011-01-18 15:27:19 +00004# To compile with PKCS11: add "-lpkcs11-helper" to LDFLAGS
Paul Bakker0049c2f2009-07-11 19:15:43 +00005
Paul Bakker46eb1382011-01-30 17:10:13 +00006CFLAGS += -I../include -D_FILE_OFFSET_BITS=64 -Wall -W -Wdeclaration-after-statement \
Paul Bakker0049c2f2009-07-11 19:15:43 +00007 -Wno-unused-function -Wno-unused-value
8
Paul Bakkerf1ab0ec2012-10-23 12:12:53 +00009OFLAGS = -O2
Paul Bakkera585beb2011-06-21 08:59:44 +000010LDFLAGS += -L../library -lpolarssl $(SYS_LDFLAGS)
Paul Bakker0049c2f2009-07-11 19:15:43 +000011
Paul Bakkerc7ffd362012-04-05 12:08:29 +000012ifdef DEBUG
13CFLAGS += -g3
14endif
15
Paul Bakkercd5b5292012-05-10 20:49:10 +000016ifdef WINDOWS
17LDFLAGS += -lws2_32
18endif
19
Paul Bakker2770fbd2012-07-03 13:30:23 +000020# Zlib shared library extensions:
21ifdef ZLIB
22LDFLAGS += -lz
23endif
24
Paul Bakkerd68703b2013-04-12 13:20:30 +020025APPS = test_suite_aes.ecb test_suite_aes.cbc \
26 test_suite_aes.cfb test_suite_aes.rest \
27 test_suite_arc4 \
Paul Bakkera9379c02012-07-04 11:02:11 +000028 test_suite_base64 test_suite_blowfish \
Paul Bakker6132d0a2012-07-04 17:10:40 +000029 test_suite_camellia test_suite_cipher.aes \
30 test_suite_cipher.blowfish \
31 test_suite_cipher.camellia \
Paul Bakkerfab5c822012-02-06 16:45:10 +000032 test_suite_cipher.des test_suite_cipher.null \
33 test_suite_ctr_drbg test_suite_debug \
Paul Bakker9d781402011-05-09 16:17:09 +000034 test_suite_des test_suite_dhm \
Paul Bakkerd68703b2013-04-12 13:20:30 +020035 test_suite_error \
36 test_suite_gcm.decrypt_128 \
37 test_suite_gcm.decrypt_192 \
38 test_suite_gcm.decrypt_256 \
39 test_suite_gcm.encrypt_128 \
40 test_suite_gcm.encrypt_192 \
41 test_suite_gcm.encrypt_256 \
42 test_suite_hmac_shax \
Paul Bakker9d781402011-05-09 16:17:09 +000043 test_suite_md test_suite_mdx \
Paul Bakkerf518b162012-08-23 13:03:18 +000044 test_suite_mpi test_suite_pbkdf2 \
45 test_suite_pkcs1_v21 \
Paul Bakker9d781402011-05-09 16:17:09 +000046 test_suite_rsa test_suite_shax \
Paul Bakker6d620502012-02-16 14:09:13 +000047 test_suite_x509parse test_suite_x509write \
48 test_suite_xtea test_suite_version
Paul Bakker0049c2f2009-07-11 19:15:43 +000049
50.SILENT:
51
52all: $(APPS)
53
Paul Bakkerd68703b2013-04-12 13:20:30 +020054test_suite_aes.ecb.c : suites/test_suite_aes.function suites/test_suite_aes.ecb.data scripts/generate_code.pl suites/helpers.function
55 echo " Generate $@"
56 scripts/generate_code.pl suites test_suite_aes test_suite_aes.ecb
57
58test_suite_aes.cbc.c : suites/test_suite_aes.function suites/test_suite_aes.cbc.data scripts/generate_code.pl suites/helpers.function
59 echo " Generate $@"
60 scripts/generate_code.pl suites test_suite_aes test_suite_aes.cbc
61
62test_suite_aes.cfb.c : suites/test_suite_aes.function suites/test_suite_aes.cfb.data scripts/generate_code.pl suites/helpers.function
63 echo " Generate $@"
64 scripts/generate_code.pl suites test_suite_aes test_suite_aes.cfb
65
66test_suite_aes.rest.c : suites/test_suite_aes.function suites/test_suite_aes.rest.data scripts/generate_code.pl suites/helpers.function
67 echo " Generate $@"
68 scripts/generate_code.pl suites test_suite_aes test_suite_aes.rest
69
Paul Bakker46c17942011-07-13 14:54:54 +000070test_suite_cipher.aes.c : suites/test_suite_cipher.function suites/test_suite_cipher.aes.data scripts/generate_code.pl suites/helpers.function
71 echo " Generate $@"
72 scripts/generate_code.pl suites test_suite_cipher test_suite_cipher.aes
73
Paul Bakker6132d0a2012-07-04 17:10:40 +000074test_suite_cipher.blowfish.c : suites/test_suite_cipher.function suites/test_suite_cipher.blowfish.data scripts/generate_code.pl suites/helpers.function
75 echo " Generate $@"
76 scripts/generate_code.pl suites test_suite_cipher test_suite_cipher.blowfish
77
Paul Bakker46c17942011-07-13 14:54:54 +000078test_suite_cipher.camellia.c : suites/test_suite_cipher.function suites/test_suite_cipher.camellia.data scripts/generate_code.pl suites/helpers.function
79 echo " Generate $@"
80 scripts/generate_code.pl suites test_suite_cipher test_suite_cipher.camellia
81
82test_suite_cipher.des.c : suites/test_suite_cipher.function suites/test_suite_cipher.des.data scripts/generate_code.pl suites/helpers.function
83 echo " Generate $@"
84 scripts/generate_code.pl suites test_suite_cipher test_suite_cipher.des
85
Paul Bakkerfab5c822012-02-06 16:45:10 +000086test_suite_cipher.null.c : suites/test_suite_cipher.function suites/test_suite_cipher.null.data scripts/generate_code.pl suites/helpers.function
87 echo " Generate $@"
88 scripts/generate_code.pl suites test_suite_cipher test_suite_cipher.null
89
Paul Bakkerd68703b2013-04-12 13:20:30 +020090test_suite_gcm.decrypt_128.c : suites/test_suite_gcm.function suites/test_suite_gcm.decrypt_128.data scripts/generate_code.pl suites/helpers.function
Paul Bakker89e80c92012-03-20 13:50:09 +000091 echo " Generate $@"
Paul Bakkerd68703b2013-04-12 13:20:30 +020092 scripts/generate_code.pl suites test_suite_gcm test_suite_gcm.decrypt_128
Paul Bakker89e80c92012-03-20 13:50:09 +000093
Paul Bakkerd68703b2013-04-12 13:20:30 +020094test_suite_gcm.decrypt_192.c : suites/test_suite_gcm.function suites/test_suite_gcm.decrypt_192.data scripts/generate_code.pl suites/helpers.function
Paul Bakker89e80c92012-03-20 13:50:09 +000095 echo " Generate $@"
Paul Bakkerd68703b2013-04-12 13:20:30 +020096 scripts/generate_code.pl suites test_suite_gcm test_suite_gcm.decrypt_192
97
98test_suite_gcm.decrypt_256.c : suites/test_suite_gcm.function suites/test_suite_gcm.decrypt_256.data scripts/generate_code.pl suites/helpers.function
99 echo " Generate $@"
100 scripts/generate_code.pl suites test_suite_gcm test_suite_gcm.decrypt_256
101
102test_suite_gcm.encrypt_128.c : suites/test_suite_gcm.function suites/test_suite_gcm.encrypt_128.data scripts/generate_code.pl suites/helpers.function
103 echo " Generate $@"
104 scripts/generate_code.pl suites test_suite_gcm test_suite_gcm.encrypt_128
105
106test_suite_gcm.encrypt_192.c : suites/test_suite_gcm.function suites/test_suite_gcm.encrypt_192.data scripts/generate_code.pl suites/helpers.function
107 echo " Generate $@"
108 scripts/generate_code.pl suites test_suite_gcm test_suite_gcm.encrypt_192
109
110test_suite_gcm.encrypt_256.c : suites/test_suite_gcm.function suites/test_suite_gcm.encrypt_256.data scripts/generate_code.pl suites/helpers.function
111 echo " Generate $@"
112 scripts/generate_code.pl suites test_suite_gcm test_suite_gcm.encrypt_256
Paul Bakker89e80c92012-03-20 13:50:09 +0000113
Paul Bakker4fa1a762011-03-13 16:56:11 +0000114%.c : suites/%.function suites/%.data scripts/generate_code.pl suites/helpers.function
Paul Bakker0049c2f2009-07-11 19:15:43 +0000115 echo " Generate $@"
Paul Bakker46c17942011-07-13 14:54:54 +0000116 scripts/generate_code.pl suites $* $*
Paul Bakker0049c2f2009-07-11 19:15:43 +0000117
Paul Bakkerd68703b2013-04-12 13:20:30 +0200118test_suite_aes.ecb: test_suite_aes.ecb.c ../library/libpolarssl.a
119 echo " CC $@.c"
120 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
121
122test_suite_aes.cbc: test_suite_aes.cbc.c ../library/libpolarssl.a
123 echo " CC $@.c"
124 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
125
126test_suite_aes.cfb: test_suite_aes.cfb.c ../library/libpolarssl.a
127 echo " CC $@.c"
128 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
129
130test_suite_aes.rest: test_suite_aes.rest.c ../library/libpolarssl.a
Paul Bakker0049c2f2009-07-11 19:15:43 +0000131 echo " CC $@.c"
132 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
133
134test_suite_arc4: test_suite_arc4.c ../library/libpolarssl.a
135 echo " CC $@.c"
136 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
137
138test_suite_base64: test_suite_base64.c ../library/libpolarssl.a
139 echo " CC $@.c"
140 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
141
Paul Bakkera9379c02012-07-04 11:02:11 +0000142test_suite_blowfish: test_suite_blowfish.c ../library/libpolarssl.a
143 echo " CC $@.c"
144 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
145
Paul Bakker0049c2f2009-07-11 19:15:43 +0000146test_suite_camellia: test_suite_camellia.c ../library/libpolarssl.a
147 echo " CC $@.c"
148 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
149
Paul Bakker46c17942011-07-13 14:54:54 +0000150test_suite_cipher.aes: test_suite_cipher.aes.c ../library/libpolarssl.a
151 echo " CC $@.c"
152 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
153
Paul Bakker6132d0a2012-07-04 17:10:40 +0000154test_suite_cipher.blowfish: test_suite_cipher.blowfish.c ../library/libpolarssl.a
155 echo " CC $@.c"
156 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
157
Paul Bakker46c17942011-07-13 14:54:54 +0000158test_suite_cipher.camellia: test_suite_cipher.camellia.c ../library/libpolarssl.a
159 echo " CC $@.c"
160 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
161
Paul Bakkerfab5c822012-02-06 16:45:10 +0000162test_suite_cipher.des: test_suite_cipher.des.c ../library/libpolarssl.a
Paul Bakker0e04d0e2011-11-27 14:46:59 +0000163 echo " CC $@.c"
164 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
165
Paul Bakkerfab5c822012-02-06 16:45:10 +0000166test_suite_cipher.null: test_suite_cipher.null.c ../library/libpolarssl.a
167 echo " CC $@.c"
168 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
169
170test_suite_ctr_drbg: test_suite_ctr_drbg.c ../library/libpolarssl.a
Paul Bakker8123e9d2011-01-06 15:37:30 +0000171 echo " CC $@.c"
172 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
173
Paul Bakker0049c2f2009-07-11 19:15:43 +0000174test_suite_des: test_suite_des.c ../library/libpolarssl.a
175 echo " CC $@.c"
176 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
177
178test_suite_dhm: test_suite_dhm.c ../library/libpolarssl.a
179 echo " CC $@.c"
180 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
181
Paul Bakker9d781402011-05-09 16:17:09 +0000182test_suite_error: test_suite_error.c ../library/libpolarssl.a
183 echo " CC $@.c"
184 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
185
Paul Bakkerd68703b2013-04-12 13:20:30 +0200186test_suite_gcm.decrypt_128: test_suite_gcm.decrypt_128.c ../library/libpolarssl.a
Paul Bakker89e80c92012-03-20 13:50:09 +0000187 echo " CC $@.c"
188 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
189
Paul Bakkerd68703b2013-04-12 13:20:30 +0200190test_suite_gcm.decrypt_192: test_suite_gcm.decrypt_192.c ../library/libpolarssl.a
191 echo " CC $@.c"
192 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
193
194test_suite_gcm.decrypt_256: test_suite_gcm.decrypt_256.c ../library/libpolarssl.a
195 echo " CC $@.c"
196 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
197
198test_suite_gcm.encrypt_128: test_suite_gcm.encrypt_128.c ../library/libpolarssl.a
199 echo " CC $@.c"
200 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
201
202test_suite_gcm.encrypt_192: test_suite_gcm.encrypt_192.c ../library/libpolarssl.a
203 echo " CC $@.c"
204 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
205
206test_suite_gcm.encrypt_256: test_suite_gcm.encrypt_256.c ../library/libpolarssl.a
Paul Bakker89e80c92012-03-20 13:50:09 +0000207 echo " CC $@.c"
208 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
209
Paul Bakker0049c2f2009-07-11 19:15:43 +0000210test_suite_hmac_shax: test_suite_hmac_shax.c ../library/libpolarssl.a
211 echo " CC $@.c"
212 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
213
Paul Bakker17373852011-01-06 14:20:01 +0000214test_suite_md: test_suite_md.c ../library/libpolarssl.a
215 echo " CC $@.c"
216 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
217
Paul Bakker0049c2f2009-07-11 19:15:43 +0000218test_suite_mdx: test_suite_mdx.c ../library/libpolarssl.a
219 echo " CC $@.c"
220 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
221
222test_suite_mpi: test_suite_mpi.c ../library/libpolarssl.a
223 echo " CC $@.c"
224 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
225
Paul Bakkerf518b162012-08-23 13:03:18 +0000226test_suite_pbkdf2: test_suite_pbkdf2.c ../library/libpolarssl.a
227 echo " CC $@.c"
228 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
229
Paul Bakker9dcc3222011-03-08 14:16:06 +0000230test_suite_pkcs1_v21: test_suite_pkcs1_v21.c ../library/libpolarssl.a
231 echo " CC $@.c"
232 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
233
Paul Bakker0049c2f2009-07-11 19:15:43 +0000234test_suite_rsa: test_suite_rsa.c ../library/libpolarssl.a
235 echo " CC $@.c"
236 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
237
238test_suite_shax: test_suite_shax.c ../library/libpolarssl.a
239 echo " CC $@.c"
240 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
241
242test_suite_x509parse: test_suite_x509parse.c ../library/libpolarssl.a
243 echo " CC $@.c"
244 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
245
Paul Bakker6d620502012-02-16 14:09:13 +0000246test_suite_x509write: test_suite_x509write.c ../library/libpolarssl.a
247 echo " CC $@.c"
248 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
249
Paul Bakker0049c2f2009-07-11 19:15:43 +0000250test_suite_xtea: test_suite_xtea.c ../library/libpolarssl.a
251 echo " CC $@.c"
252 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
253
Paul Bakker7d7f4f42010-02-18 18:26:04 +0000254test_suite_debug: test_suite_debug.c ../library/libpolarssl.a
255 echo " CC $@.c"
256 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
257
Paul Bakker3ac1b2d2010-06-18 22:47:29 +0000258test_suite_version: test_suite_version.c ../library/libpolarssl.a
259 echo " CC $@.c"
260 $(CC) $(CFLAGS) $(OFLAGS) $@.c $(LDFLAGS) -o $@
261
Paul Bakker0049c2f2009-07-11 19:15:43 +0000262clean:
Paul Bakker62f88dc2012-05-10 21:26:28 +0000263ifndef WINDOWS
Paul Bakker0049c2f2009-07-11 19:15:43 +0000264 rm -f $(APPS) *.c
Paul Bakker62f88dc2012-05-10 21:26:28 +0000265endif
266ifdef WINDOWS
267 del /Q /F *.c *.exe
268endif
Paul Bakker0049c2f2009-07-11 19:15:43 +0000269
Paul Bakker9794cb42009-07-28 18:55:00 +0000270check: $(APPS)
Paul Bakker62f88dc2012-05-10 21:26:28 +0000271ifndef WINDOWS
Paul Bakkerd14cd352012-05-08 15:39:50 +0000272 echo "Running checks (Success if all tests PASSED)"
273 RETURN=0; \
Paul Bakkerd947d762009-07-28 20:16:47 +0000274 for i in $(APPS); \
275 do \
276 echo " - $${i}"; \
Paul Bakkerd14cd352012-05-08 15:39:50 +0000277 RESULT=`./$${i} | grep -v 'PASS$$' | grep -v -- '-----' | grep -v '^$$'`; \
278 FAILED=`echo $$RESULT |grep FAILED`; \
279 echo " $$RESULT"; \
280 if [ "$$FAILED" != "" ]; \
281 then \
282 echo "**** Failed ***************"; \
283 RETURN=1; \
284 fi; \
Paul Bakkerd947d762009-07-28 20:16:47 +0000285 echo ""; \
Paul Bakkerd14cd352012-05-08 15:39:50 +0000286 done; \
287 if [ "$$RETURN" -eq 1 ]; then exit 1; fi
Paul Bakker62f88dc2012-05-10 21:26:28 +0000288endif