tomcrypt-sys 0.1.0

Raw bindings to libtomcrypt
Documentation
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
extern crate cc;

fn main() {
	// Build tomsfastmath
	cc::Build::new()
		.include("tomsfastmath/src/headers")
		.files([
			"tomsfastmath/src/addsub/fp_add.c",
			"tomsfastmath/src/addsub/fp_add_d.c",
			"tomsfastmath/src/addsub/fp_addmod.c",
			"tomsfastmath/src/addsub/fp_cmp.c",
			"tomsfastmath/src/addsub/fp_cmp_d.c",
			"tomsfastmath/src/addsub/fp_cmp_mag.c",
			"tomsfastmath/src/addsub/fp_sub.c",
			"tomsfastmath/src/addsub/fp_sub_d.c",
			"tomsfastmath/src/addsub/fp_submod.c",
			"tomsfastmath/src/addsub/s_fp_add.c",
			"tomsfastmath/src/addsub/s_fp_sub.c",
			"tomsfastmath/src/bin/fp_radix_size.c",
			"tomsfastmath/src/bin/fp_read_radix.c",
			"tomsfastmath/src/bin/fp_read_signed_bin.c",
			"tomsfastmath/src/bin/fp_read_unsigned_bin.c",
			"tomsfastmath/src/bin/fp_reverse.c",
			"tomsfastmath/src/bin/fp_signed_bin_size.c",
			"tomsfastmath/src/bin/fp_s_rmap.c",
			"tomsfastmath/src/bin/fp_toradix.c",
			"tomsfastmath/src/bin/fp_toradix_n.c",
			"tomsfastmath/src/bin/fp_to_signed_bin.c",
			"tomsfastmath/src/bin/fp_to_unsigned_bin.c",
			"tomsfastmath/src/bin/fp_unsigned_bin_size.c",
			"tomsfastmath/src/bit/fp_cnt_lsb.c",
			"tomsfastmath/src/bit/fp_count_bits.c",
			"tomsfastmath/src/bit/fp_div_2.c",
			"tomsfastmath/src/bit/fp_div_2d.c",
			"tomsfastmath/src/bit/fp_lshd.c",
			"tomsfastmath/src/bit/fp_mod_2d.c",
			"tomsfastmath/src/bit/fp_rshd.c",
			"tomsfastmath/src/divide/fp_div.c",
			"tomsfastmath/src/divide/fp_div_d.c",
			"tomsfastmath/src/divide/fp_mod.c",
			"tomsfastmath/src/divide/fp_mod_d.c",
			"tomsfastmath/src/exptmod/fp_2expt.c",
			"tomsfastmath/src/exptmod/fp_exptmod.c",
			"tomsfastmath/src/misc/fp_ident.c",
			"tomsfastmath/src/misc/fp_rand.c",
			"tomsfastmath/src/misc/fp_set.c",
			"tomsfastmath/src/mont/fp_montgomery_calc_normalization.c",
			"tomsfastmath/src/mont/fp_montgomery_reduce.c",
			"tomsfastmath/src/mont/fp_montgomery_setup.c",
			"tomsfastmath/src/mul/fp_mul_2.c",
			"tomsfastmath/src/mul/fp_mul_2d.c",
			"tomsfastmath/src/mul/fp_mul.c",
			"tomsfastmath/src/mul/fp_mul_comba_12.c",
			"tomsfastmath/src/mul/fp_mul_comba_17.c",
			"tomsfastmath/src/mul/fp_mul_comba_20.c",
			"tomsfastmath/src/mul/fp_mul_comba_24.c",
			"tomsfastmath/src/mul/fp_mul_comba_28.c",
			"tomsfastmath/src/mul/fp_mul_comba_32.c",
			"tomsfastmath/src/mul/fp_mul_comba_3.c",
			"tomsfastmath/src/mul/fp_mul_comba_48.c",
			"tomsfastmath/src/mul/fp_mul_comba_4.c",
			"tomsfastmath/src/mul/fp_mul_comba_64.c",
			"tomsfastmath/src/mul/fp_mul_comba_6.c",
			"tomsfastmath/src/mul/fp_mul_comba_7.c",
			"tomsfastmath/src/mul/fp_mul_comba_8.c",
			"tomsfastmath/src/mul/fp_mul_comba_9.c",
			"tomsfastmath/src/mul/fp_mul_comba.c",
			"tomsfastmath/src/mul/fp_mul_comba_small_set.c",
			"tomsfastmath/src/mul/fp_mul_d.c",
			"tomsfastmath/src/mul/fp_mulmod.c",
			"tomsfastmath/src/numtheory/fp_gcd.c",
			"tomsfastmath/src/numtheory/fp_invmod.c",
			"tomsfastmath/src/numtheory/fp_isprime.c",
			"tomsfastmath/src/numtheory/fp_isprime_ex.c",
			"tomsfastmath/src/numtheory/fp_lcm.c",
			"tomsfastmath/src/numtheory/fp_prime_miller_rabin.c",
			"tomsfastmath/src/numtheory/fp_prime_random_ex.c",
			"tomsfastmath/src/sqr/fp_sqr.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_12.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_17.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_20.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_24.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_28.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_32.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_3.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_48.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_4.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_64.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_6.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_7.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_8.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_9.c",
			"tomsfastmath/src/sqr/fp_sqr_comba.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_generic.c",
			"tomsfastmath/src/sqr/fp_sqr_comba_small_set.c",
			"tomsfastmath/src/sqr/fp_sqrmod.c",
		].iter())
		.compile("tfm");

	// Build tomcrypt
	let mut ltc_build = cc::Build::new();
	ltc_build
		.define("USE_TFM", None)
		.define("TFM_DESC", None)
		.define("LTC_SOURCE", None)
		.define("MECC_PF", None)
		.include("libtomcrypt/src/headers")
		.include("tomsfastmath/src/headers");

	#[cfg(target_os = "linux")]
	ltc_build.flag("-Wno-unused-parameter");

	// Compile only needed features
	/*for d in &["NO_CIPHERS", "NO_MODES", "NO_HASHES", "NO_MACS", "NO_PRNGS",
		"NO_PK", "NO_PKCS", "NO_MISC", "NO_FILE", "RIJNDAEL", "CTR_MODE",
		"OMAC", "DEVRANDOM", "SPRNG", "TRY_URANDOM_FIRST", "EAX_MODE", "MECC",
		"DER", "RNG_GET_BYTES"] {
		ltc_build.define(&format!("LTC_{}", d), None);
	}*/

	let ltc_files = [
		"libtomcrypt/src/ciphers/aes/aes.c",
		"libtomcrypt/src/ciphers/aes/aes_tab.c",
		"libtomcrypt/src/ciphers/anubis.c",
		"libtomcrypt/src/ciphers/blowfish.c",
		"libtomcrypt/src/ciphers/camellia.c",
		"libtomcrypt/src/ciphers/cast5.c",
		"libtomcrypt/src/ciphers/des.c",
		"libtomcrypt/src/ciphers/kasumi.c",
		"libtomcrypt/src/ciphers/khazad.c",
		"libtomcrypt/src/ciphers/kseed.c",
		"libtomcrypt/src/ciphers/multi2.c",
		"libtomcrypt/src/ciphers/noekeon.c",
		"libtomcrypt/src/ciphers/rc2.c",
		"libtomcrypt/src/ciphers/rc5.c",
		"libtomcrypt/src/ciphers/rc6.c",
		"libtomcrypt/src/ciphers/safer/safer.c",
		"libtomcrypt/src/ciphers/safer/saferp.c",
		"libtomcrypt/src/ciphers/skipjack.c",
		"libtomcrypt/src/ciphers/twofish/twofish.c",
		"libtomcrypt/src/ciphers/xtea.c",
		"libtomcrypt/src/encauth/ccm/ccm_add_aad.c",
		"libtomcrypt/src/encauth/ccm/ccm_add_nonce.c",
		"libtomcrypt/src/encauth/ccm/ccm_done.c",
		"libtomcrypt/src/encauth/ccm/ccm_init.c",
		"libtomcrypt/src/encauth/ccm/ccm_memory.c",
		"libtomcrypt/src/encauth/ccm/ccm_process.c",
		"libtomcrypt/src/encauth/ccm/ccm_reset.c",
		"libtomcrypt/src/encauth/ccm/ccm_test.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_add_aad.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_decrypt.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_done.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_encrypt.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_init.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_memory.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_setiv.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_setiv_rfc7905.c",
		"libtomcrypt/src/encauth/chachapoly/chacha20poly1305_test.c",
		"libtomcrypt/src/encauth/eax/eax_addheader.c",
		"libtomcrypt/src/encauth/eax/eax_decrypt.c",
		"libtomcrypt/src/encauth/eax/eax_decrypt_verify_memory.c",
		"libtomcrypt/src/encauth/eax/eax_done.c",
		"libtomcrypt/src/encauth/eax/eax_encrypt.c",
		"libtomcrypt/src/encauth/eax/eax_encrypt_authenticate_memory.c",
		"libtomcrypt/src/encauth/eax/eax_init.c",
		"libtomcrypt/src/encauth/eax/eax_test.c",
		"libtomcrypt/src/encauth/gcm/gcm_add_aad.c",
		"libtomcrypt/src/encauth/gcm/gcm_add_iv.c",
		"libtomcrypt/src/encauth/gcm/gcm_done.c",
		"libtomcrypt/src/encauth/gcm/gcm_gf_mult.c",
		"libtomcrypt/src/encauth/gcm/gcm_init.c",
		"libtomcrypt/src/encauth/gcm/gcm_memory.c",
		"libtomcrypt/src/encauth/gcm/gcm_mult_h.c",
		"libtomcrypt/src/encauth/gcm/gcm_process.c",
		"libtomcrypt/src/encauth/gcm/gcm_reset.c",
		"libtomcrypt/src/encauth/gcm/gcm_test.c",
		"libtomcrypt/src/encauth/ocb/ocb_decrypt.c",
		"libtomcrypt/src/encauth/ocb/ocb_decrypt_verify_memory.c",
		"libtomcrypt/src/encauth/ocb/ocb_done_decrypt.c",
		"libtomcrypt/src/encauth/ocb/ocb_done_encrypt.c",
		"libtomcrypt/src/encauth/ocb/ocb_encrypt.c",
		"libtomcrypt/src/encauth/ocb/ocb_encrypt_authenticate_memory.c",
		"libtomcrypt/src/encauth/ocb/ocb_init.c",
		"libtomcrypt/src/encauth/ocb/ocb_ntz.c",
		"libtomcrypt/src/encauth/ocb/ocb_shift_xor.c",
		"libtomcrypt/src/encauth/ocb/ocb_test.c",
		"libtomcrypt/src/encauth/ocb/s_ocb_done.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_add_aad.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_decrypt.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_decrypt_last.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_decrypt_verify_memory.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_done.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_encrypt.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_encrypt_authenticate_memory.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_encrypt_last.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_init.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_int_ntz.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_int_xor_blocks.c",
		"libtomcrypt/src/encauth/ocb3/ocb3_test.c",
		"libtomcrypt/src/hashes/blake2b.c",
		"libtomcrypt/src/hashes/blake2s.c",
		"libtomcrypt/src/hashes/chc/chc.c",
		"libtomcrypt/src/hashes/helper/hash_file.c",
		"libtomcrypt/src/hashes/helper/hash_filehandle.c",
		"libtomcrypt/src/hashes/helper/hash_memory.c",
		"libtomcrypt/src/hashes/helper/hash_memory_multi.c",
		"libtomcrypt/src/hashes/md2.c",
		"libtomcrypt/src/hashes/md4.c",
		"libtomcrypt/src/hashes/md5.c",
		"libtomcrypt/src/hashes/rmd128.c",
		"libtomcrypt/src/hashes/rmd160.c",
		"libtomcrypt/src/hashes/rmd256.c",
		"libtomcrypt/src/hashes/rmd320.c",
		"libtomcrypt/src/hashes/sha1.c",
		"libtomcrypt/src/hashes/sha2/sha224.c",
		"libtomcrypt/src/hashes/sha2/sha256.c",
		"libtomcrypt/src/hashes/sha2/sha384.c",
		"libtomcrypt/src/hashes/sha2/sha512.c",
		"libtomcrypt/src/hashes/sha2/sha512_224.c",
		"libtomcrypt/src/hashes/sha2/sha512_256.c",
		"libtomcrypt/src/hashes/sha3.c",
		"libtomcrypt/src/hashes/sha3_test.c",
		"libtomcrypt/src/hashes/tiger.c",
		"libtomcrypt/src/hashes/whirl/whirl.c",
		"libtomcrypt/src/mac/blake2/blake2bmac.c",
		"libtomcrypt/src/mac/blake2/blake2bmac_file.c",
		"libtomcrypt/src/mac/blake2/blake2bmac_memory.c",
		"libtomcrypt/src/mac/blake2/blake2bmac_memory_multi.c",
		"libtomcrypt/src/mac/blake2/blake2bmac_test.c",
		"libtomcrypt/src/mac/blake2/blake2smac.c",
		"libtomcrypt/src/mac/blake2/blake2smac_file.c",
		"libtomcrypt/src/mac/blake2/blake2smac_memory.c",
		"libtomcrypt/src/mac/blake2/blake2smac_memory_multi.c",
		"libtomcrypt/src/mac/blake2/blake2smac_test.c",
		"libtomcrypt/src/mac/f9/f9_done.c",
		"libtomcrypt/src/mac/f9/f9_file.c",
		"libtomcrypt/src/mac/f9/f9_init.c",
		"libtomcrypt/src/mac/f9/f9_memory.c",
		"libtomcrypt/src/mac/f9/f9_memory_multi.c",
		"libtomcrypt/src/mac/f9/f9_process.c",
		"libtomcrypt/src/mac/f9/f9_test.c",
		"libtomcrypt/src/mac/hmac/hmac_done.c",
		"libtomcrypt/src/mac/hmac/hmac_file.c",
		"libtomcrypt/src/mac/hmac/hmac_init.c",
		"libtomcrypt/src/mac/hmac/hmac_memory.c",
		"libtomcrypt/src/mac/hmac/hmac_memory_multi.c",
		"libtomcrypt/src/mac/hmac/hmac_process.c",
		"libtomcrypt/src/mac/hmac/hmac_test.c",
		"libtomcrypt/src/mac/omac/omac_done.c",
		"libtomcrypt/src/mac/omac/omac_file.c",
		"libtomcrypt/src/mac/omac/omac_init.c",
		"libtomcrypt/src/mac/omac/omac_memory.c",
		"libtomcrypt/src/mac/omac/omac_memory_multi.c",
		"libtomcrypt/src/mac/omac/omac_process.c",
		"libtomcrypt/src/mac/omac/omac_test.c",
		"libtomcrypt/src/mac/pelican/pelican.c",
		"libtomcrypt/src/mac/pelican/pelican_memory.c",
		"libtomcrypt/src/mac/pelican/pelican_test.c",
		"libtomcrypt/src/mac/pmac/pmac_done.c",
		"libtomcrypt/src/mac/pmac/pmac_file.c",
		"libtomcrypt/src/mac/pmac/pmac_init.c",
		"libtomcrypt/src/mac/pmac/pmac_memory.c",
		"libtomcrypt/src/mac/pmac/pmac_memory_multi.c",
		"libtomcrypt/src/mac/pmac/pmac_ntz.c",
		"libtomcrypt/src/mac/pmac/pmac_process.c",
		"libtomcrypt/src/mac/pmac/pmac_shift_xor.c",
		"libtomcrypt/src/mac/pmac/pmac_test.c",
		"libtomcrypt/src/mac/poly1305/poly1305.c",
		"libtomcrypt/src/mac/poly1305/poly1305_file.c",
		"libtomcrypt/src/mac/poly1305/poly1305_memory.c",
		"libtomcrypt/src/mac/poly1305/poly1305_memory_multi.c",
		"libtomcrypt/src/mac/poly1305/poly1305_test.c",
		"libtomcrypt/src/mac/xcbc/xcbc_done.c",
		"libtomcrypt/src/mac/xcbc/xcbc_file.c",
		"libtomcrypt/src/mac/xcbc/xcbc_init.c",
		"libtomcrypt/src/mac/xcbc/xcbc_memory.c",
		"libtomcrypt/src/mac/xcbc/xcbc_memory_multi.c",
		"libtomcrypt/src/mac/xcbc/xcbc_process.c",
		"libtomcrypt/src/mac/xcbc/xcbc_test.c",
		"libtomcrypt/src/math/fp/ltc_ecc_fp_mulmod.c",
		"libtomcrypt/src/math/gmp_desc.c",
		"libtomcrypt/src/math/ltm_desc.c",
		"libtomcrypt/src/math/multi.c",
		"libtomcrypt/src/math/radix_to_bin.c",
		"libtomcrypt/src/math/rand_bn.c",
		"libtomcrypt/src/math/rand_prime.c",
		"libtomcrypt/src/math/tfm_desc.c",
		"libtomcrypt/src/misc/adler32.c",
		"libtomcrypt/src/misc/base64/base64_decode.c",
		"libtomcrypt/src/misc/base64/base64_encode.c",
		"libtomcrypt/src/misc/burn_stack.c",
		"libtomcrypt/src/misc/compare_testvector.c",
		"libtomcrypt/src/misc/crc32.c",
		"libtomcrypt/src/misc/crypt/crypt.c",
		"libtomcrypt/src/misc/crypt/crypt_argchk.c",
		"libtomcrypt/src/misc/crypt/crypt_cipher_descriptor.c",
		"libtomcrypt/src/misc/crypt/crypt_cipher_is_valid.c",
		"libtomcrypt/src/misc/crypt/crypt_constants.c",
		"libtomcrypt/src/misc/crypt/crypt_find_cipher.c",
		"libtomcrypt/src/misc/crypt/crypt_find_cipher_any.c",
		"libtomcrypt/src/misc/crypt/crypt_find_cipher_id.c",
		"libtomcrypt/src/misc/crypt/crypt_find_hash.c",
		"libtomcrypt/src/misc/crypt/crypt_find_hash_any.c",
		"libtomcrypt/src/misc/crypt/crypt_find_hash_id.c",
		"libtomcrypt/src/misc/crypt/crypt_find_hash_oid.c",
		"libtomcrypt/src/misc/crypt/crypt_find_prng.c",
		"libtomcrypt/src/misc/crypt/crypt_fsa.c",
		"libtomcrypt/src/misc/crypt/crypt_hash_descriptor.c",
		"libtomcrypt/src/misc/crypt/crypt_hash_is_valid.c",
		"libtomcrypt/src/misc/crypt/crypt_inits.c",
		"libtomcrypt/src/misc/crypt/crypt_ltc_mp_descriptor.c",
		"libtomcrypt/src/misc/crypt/crypt_prng_descriptor.c",
		"libtomcrypt/src/misc/crypt/crypt_prng_is_valid.c",
		"libtomcrypt/src/misc/crypt/crypt_prng_rng_descriptor.c",
		"libtomcrypt/src/misc/crypt/crypt_register_all_ciphers.c",
		"libtomcrypt/src/misc/crypt/crypt_register_all_hashes.c",
		"libtomcrypt/src/misc/crypt/crypt_register_all_prngs.c",
		"libtomcrypt/src/misc/crypt/crypt_register_cipher.c",
		"libtomcrypt/src/misc/crypt/crypt_register_hash.c",
		"libtomcrypt/src/misc/crypt/crypt_register_prng.c",
		"libtomcrypt/src/misc/crypt/crypt_sizes.c",
		"libtomcrypt/src/misc/crypt/crypt_unregister_cipher.c",
		"libtomcrypt/src/misc/crypt/crypt_unregister_hash.c",
		"libtomcrypt/src/misc/crypt/crypt_unregister_prng.c",
		"libtomcrypt/src/misc/error_to_string.c",
		"libtomcrypt/src/misc/hkdf/hkdf.c",
		"libtomcrypt/src/misc/hkdf/hkdf_test.c",
		"libtomcrypt/src/misc/mem_neq.c",
		"libtomcrypt/src/misc/pk_get_oid.c",
		"libtomcrypt/src/misc/pkcs5/pkcs_5_1.c",
		"libtomcrypt/src/misc/pkcs5/pkcs_5_2.c",
		"libtomcrypt/src/misc/pkcs5/pkcs_5_test.c",
		"libtomcrypt/src/misc/zeromem.c",
		"libtomcrypt/src/modes/cbc/cbc_decrypt.c",
		"libtomcrypt/src/modes/cbc/cbc_done.c",
		"libtomcrypt/src/modes/cbc/cbc_encrypt.c",
		"libtomcrypt/src/modes/cbc/cbc_getiv.c",
		"libtomcrypt/src/modes/cbc/cbc_setiv.c",
		"libtomcrypt/src/modes/cbc/cbc_start.c",
		"libtomcrypt/src/modes/cfb/cfb_decrypt.c",
		"libtomcrypt/src/modes/cfb/cfb_done.c",
		"libtomcrypt/src/modes/cfb/cfb_encrypt.c",
		"libtomcrypt/src/modes/cfb/cfb_getiv.c",
		"libtomcrypt/src/modes/cfb/cfb_setiv.c",
		"libtomcrypt/src/modes/cfb/cfb_start.c",
		"libtomcrypt/src/modes/ctr/ctr_decrypt.c",
		"libtomcrypt/src/modes/ctr/ctr_done.c",
		"libtomcrypt/src/modes/ctr/ctr_encrypt.c",
		"libtomcrypt/src/modes/ctr/ctr_getiv.c",
		"libtomcrypt/src/modes/ctr/ctr_setiv.c",
		"libtomcrypt/src/modes/ctr/ctr_start.c",
		"libtomcrypt/src/modes/ctr/ctr_test.c",
		"libtomcrypt/src/modes/ecb/ecb_decrypt.c",
		"libtomcrypt/src/modes/ecb/ecb_done.c",
		"libtomcrypt/src/modes/ecb/ecb_encrypt.c",
		"libtomcrypt/src/modes/ecb/ecb_start.c",
		"libtomcrypt/src/modes/f8/f8_decrypt.c",
		"libtomcrypt/src/modes/f8/f8_done.c",
		"libtomcrypt/src/modes/f8/f8_encrypt.c",
		"libtomcrypt/src/modes/f8/f8_getiv.c",
		"libtomcrypt/src/modes/f8/f8_setiv.c",
		"libtomcrypt/src/modes/f8/f8_start.c",
		"libtomcrypt/src/modes/f8/f8_test_mode.c",
		"libtomcrypt/src/modes/lrw/lrw_decrypt.c",
		"libtomcrypt/src/modes/lrw/lrw_done.c",
		"libtomcrypt/src/modes/lrw/lrw_encrypt.c",
		"libtomcrypt/src/modes/lrw/lrw_getiv.c",
		"libtomcrypt/src/modes/lrw/lrw_process.c",
		"libtomcrypt/src/modes/lrw/lrw_setiv.c",
		"libtomcrypt/src/modes/lrw/lrw_start.c",
		"libtomcrypt/src/modes/lrw/lrw_test.c",
		"libtomcrypt/src/modes/ofb/ofb_decrypt.c",
		"libtomcrypt/src/modes/ofb/ofb_done.c",
		"libtomcrypt/src/modes/ofb/ofb_encrypt.c",
		"libtomcrypt/src/modes/ofb/ofb_getiv.c",
		"libtomcrypt/src/modes/ofb/ofb_setiv.c",
		"libtomcrypt/src/modes/ofb/ofb_start.c",
		"libtomcrypt/src/modes/xts/xts_decrypt.c",
		"libtomcrypt/src/modes/xts/xts_done.c",
		"libtomcrypt/src/modes/xts/xts_encrypt.c",
		"libtomcrypt/src/modes/xts/xts_init.c",
		"libtomcrypt/src/modes/xts/xts_mult_x.c",
		"libtomcrypt/src/modes/xts/xts_test.c",
		"libtomcrypt/src/pk/asn1/der/bit/der_decode_bit_string.c",
		"libtomcrypt/src/pk/asn1/der/bit/der_decode_raw_bit_string.c",
		"libtomcrypt/src/pk/asn1/der/bit/der_encode_bit_string.c",
		"libtomcrypt/src/pk/asn1/der/bit/der_encode_raw_bit_string.c",
		"libtomcrypt/src/pk/asn1/der/bit/der_length_bit_string.c",
		"libtomcrypt/src/pk/asn1/der/boolean/der_decode_boolean.c",
		"libtomcrypt/src/pk/asn1/der/boolean/der_encode_boolean.c",
		"libtomcrypt/src/pk/asn1/der/boolean/der_length_boolean.c",
		"libtomcrypt/src/pk/asn1/der/choice/der_decode_choice.c",
		"libtomcrypt/src/pk/asn1/der/generalizedtime/der_decode_generalizedtime.c",
		"libtomcrypt/src/pk/asn1/der/generalizedtime/der_encode_generalizedtime.c",
		"libtomcrypt/src/pk/asn1/der/generalizedtime/der_length_generalizedtime.c",
		"libtomcrypt/src/pk/asn1/der/ia5/der_decode_ia5_string.c",
		"libtomcrypt/src/pk/asn1/der/ia5/der_encode_ia5_string.c",
		"libtomcrypt/src/pk/asn1/der/ia5/der_length_ia5_string.c",
		"libtomcrypt/src/pk/asn1/der/integer/der_decode_integer.c",
		"libtomcrypt/src/pk/asn1/der/integer/der_encode_integer.c",
		"libtomcrypt/src/pk/asn1/der/integer/der_length_integer.c",
		"libtomcrypt/src/pk/asn1/der/object_identifier/der_decode_object_identifier.c",
		"libtomcrypt/src/pk/asn1/der/object_identifier/der_encode_object_identifier.c",
		"libtomcrypt/src/pk/asn1/der/object_identifier/der_length_object_identifier.c",
		"libtomcrypt/src/pk/asn1/der/octet/der_decode_octet_string.c",
		"libtomcrypt/src/pk/asn1/der/octet/der_encode_octet_string.c",
		"libtomcrypt/src/pk/asn1/der/octet/der_length_octet_string.c",
		"libtomcrypt/src/pk/asn1/der/printable_string/der_decode_printable_string.c",
		"libtomcrypt/src/pk/asn1/der/printable_string/der_encode_printable_string.c",
		"libtomcrypt/src/pk/asn1/der/printable_string/der_length_printable_string.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_decode_sequence_ex.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_decode_sequence_flexi.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_decode_sequence_multi.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_decode_subject_public_key_info.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_encode_sequence_ex.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_encode_sequence_multi.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_encode_subject_public_key_info.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_length_sequence.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_sequence_free.c",
		"libtomcrypt/src/pk/asn1/der/sequence/der_sequence_shrink.c",
		"libtomcrypt/src/pk/asn1/der/set/der_encode_set.c",
		"libtomcrypt/src/pk/asn1/der/set/der_encode_setof.c",
		"libtomcrypt/src/pk/asn1/der/short_integer/der_decode_short_integer.c",
		"libtomcrypt/src/pk/asn1/der/short_integer/der_encode_short_integer.c",
		"libtomcrypt/src/pk/asn1/der/short_integer/der_length_short_integer.c",
		"libtomcrypt/src/pk/asn1/der/teletex_string/der_decode_teletex_string.c",
		"libtomcrypt/src/pk/asn1/der/teletex_string/der_length_teletex_string.c",
		"libtomcrypt/src/pk/asn1/der/utctime/der_decode_utctime.c",
		"libtomcrypt/src/pk/asn1/der/utctime/der_encode_utctime.c",
		"libtomcrypt/src/pk/asn1/der/utctime/der_length_utctime.c",
		"libtomcrypt/src/pk/asn1/der/utf8/der_decode_utf8_string.c",
		"libtomcrypt/src/pk/asn1/der/utf8/der_encode_utf8_string.c",
		"libtomcrypt/src/pk/asn1/der/utf8/der_length_utf8_string.c",
		"libtomcrypt/src/pk/dh/dh.c",
		"libtomcrypt/src/pk/dh/dh_check_pubkey.c",
		"libtomcrypt/src/pk/dh/dh_export.c",
		"libtomcrypt/src/pk/dh/dh_export_key.c",
		"libtomcrypt/src/pk/dh/dh_free.c",
		"libtomcrypt/src/pk/dh/dh_generate_key.c",
		"libtomcrypt/src/pk/dh/dh_import.c",
		"libtomcrypt/src/pk/dh/dh_set.c",
		"libtomcrypt/src/pk/dh/dh_set_pg_dhparam.c",
		"libtomcrypt/src/pk/dh/dh_shared_secret.c",
		"libtomcrypt/src/pk/dsa/dsa_decrypt_key.c",
		"libtomcrypt/src/pk/dsa/dsa_encrypt_key.c",
		"libtomcrypt/src/pk/dsa/dsa_export.c",
		"libtomcrypt/src/pk/dsa/dsa_free.c",
		"libtomcrypt/src/pk/dsa/dsa_generate_key.c",
		"libtomcrypt/src/pk/dsa/dsa_generate_pqg.c",
		"libtomcrypt/src/pk/dsa/dsa_import.c",
		"libtomcrypt/src/pk/dsa/dsa_make_key.c",
		"libtomcrypt/src/pk/dsa/dsa_set.c",
		"libtomcrypt/src/pk/dsa/dsa_set_pqg_dsaparam.c",
		"libtomcrypt/src/pk/dsa/dsa_shared_secret.c",
		"libtomcrypt/src/pk/dsa/dsa_sign_hash.c",
		"libtomcrypt/src/pk/dsa/dsa_verify_hash.c",
		"libtomcrypt/src/pk/dsa/dsa_verify_key.c",
		"libtomcrypt/src/pk/ecc/ecc.c",
		"libtomcrypt/src/pk/ecc/ecc_ansi_x963_export.c",
		"libtomcrypt/src/pk/ecc/ecc_ansi_x963_import.c",
		"libtomcrypt/src/pk/ecc/ecc_decrypt_key.c",
		"libtomcrypt/src/pk/ecc/ecc_encrypt_key.c",
		"libtomcrypt/src/pk/ecc/ecc_export.c",
		"libtomcrypt/src/pk/ecc/ecc_free.c",
		"libtomcrypt/src/pk/ecc/ecc_get_size.c",
		"libtomcrypt/src/pk/ecc/ecc_import.c",
		"libtomcrypt/src/pk/ecc/ecc_make_key.c",
		"libtomcrypt/src/pk/ecc/ecc_shared_secret.c",
		"libtomcrypt/src/pk/ecc/ecc_sign_hash.c",
		"libtomcrypt/src/pk/ecc/ecc_sizes.c",
		"libtomcrypt/src/pk/ecc/ecc_test.c",
		"libtomcrypt/src/pk/ecc/ecc_verify_hash.c",
		"libtomcrypt/src/pk/ecc/ltc_ecc_is_valid_idx.c",
		"libtomcrypt/src/pk/ecc/ltc_ecc_map.c",
		"libtomcrypt/src/pk/ecc/ltc_ecc_mul2add.c",
		"libtomcrypt/src/pk/ecc/ltc_ecc_mulmod.c",
		"libtomcrypt/src/pk/ecc/ltc_ecc_mulmod_timing.c",
		"libtomcrypt/src/pk/ecc/ltc_ecc_points.c",
		"libtomcrypt/src/pk/ecc/ltc_ecc_projective_add_point.c",
		"libtomcrypt/src/pk/ecc/ltc_ecc_projective_dbl_point.c",
		"libtomcrypt/src/pk/katja/katja_decrypt_key.c",
		"libtomcrypt/src/pk/katja/katja_encrypt_key.c",
		"libtomcrypt/src/pk/katja/katja_export.c",
		"libtomcrypt/src/pk/katja/katja_exptmod.c",
		"libtomcrypt/src/pk/katja/katja_free.c",
		"libtomcrypt/src/pk/katja/katja_import.c",
		"libtomcrypt/src/pk/katja/katja_make_key.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_i2osp.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_mgf1.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_oaep_decode.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_oaep_encode.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_os2ip.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_pss_decode.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_pss_encode.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_v1_5_decode.c",
		"libtomcrypt/src/pk/pkcs1/pkcs_1_v1_5_encode.c",
		"libtomcrypt/src/pk/rsa/rsa_decrypt_key.c",
		"libtomcrypt/src/pk/rsa/rsa_encrypt_key.c",
		"libtomcrypt/src/pk/rsa/rsa_export.c",
		"libtomcrypt/src/pk/rsa/rsa_exptmod.c",
		"libtomcrypt/src/pk/rsa/rsa_free.c",
		"libtomcrypt/src/pk/rsa/rsa_get_size.c",
		"libtomcrypt/src/pk/rsa/rsa_import.c",
		"libtomcrypt/src/pk/rsa/rsa_import_pkcs8.c",
		"libtomcrypt/src/pk/rsa/rsa_import_x509.c",
		"libtomcrypt/src/pk/rsa/rsa_make_key.c",
		"libtomcrypt/src/pk/rsa/rsa_set.c",
		"libtomcrypt/src/pk/rsa/rsa_sign_hash.c",
		"libtomcrypt/src/pk/rsa/rsa_sign_saltlen_get.c",
		"libtomcrypt/src/pk/rsa/rsa_verify_hash.c",
		"libtomcrypt/src/prngs/chacha20.c",
		"libtomcrypt/src/prngs/fortuna.c",
		"libtomcrypt/src/prngs/rc4.c",
		"libtomcrypt/src/prngs/rng_get_bytes.c",
		"libtomcrypt/src/prngs/rng_make_prng.c",
		"libtomcrypt/src/prngs/sober128.c",
		"libtomcrypt/src/prngs/sprng.c",
		"libtomcrypt/src/prngs/yarrow.c",
		"libtomcrypt/src/stream/chacha/chacha_crypt.c",
		"libtomcrypt/src/stream/chacha/chacha_done.c",
		"libtomcrypt/src/stream/chacha/chacha_ivctr32.c",
		"libtomcrypt/src/stream/chacha/chacha_ivctr64.c",
		"libtomcrypt/src/stream/chacha/chacha_keystream.c",
		"libtomcrypt/src/stream/chacha/chacha_setup.c",
		"libtomcrypt/src/stream/chacha/chacha_test.c",
		"libtomcrypt/src/stream/rc4/rc4_stream.c",
		"libtomcrypt/src/stream/rc4/rc4_test.c",
		"libtomcrypt/src/stream/sober128/sober128_stream.c",
		"libtomcrypt/src/stream/sober128/sober128_test.c",
	];

	#[cfg(not(target_os = "windows"))]
	ltc_build
		.files(ltc_files.iter())
		.compile("tomcrypt");

	#[cfg(target_os = "windows")]
	for (i, w) in ltc_files.chunks(20).enumerate() {
		ltc_build.clone()
			.files(w.iter())
			.compile(&format!("tomcrypt{}", i));
	}

	println!("cargo:rustc-link-lib=static=tfm");

	#[cfg(not(target_os = "windows"))]
	println!("cargo:rustc-link-lib=static=tomcrypt");

	#[cfg(target_os = "windows")]
	for i in 0..((ltc_files.len() + 19) / 20) {
		println!("cargo:rustc-link-lib=static=tomcrypt{}", i);
	}
}