commit
						783cbc7917
					
				| @ -357,10 +357,6 @@ | ||||
| 					RelativePath="src\encauth\ccm\ccm_memory.c" | ||||
| 					> | ||||
| 				</File> | ||||
| 				<File | ||||
| 					RelativePath="src\encauth\ccm\ccm_memory_ex.c" | ||||
| 					> | ||||
| 				</File> | ||||
| 				<File | ||||
| 					RelativePath="src\encauth\ccm\ccm_process.c" | ||||
| 					> | ||||
|  | ||||
| @ -359,10 +359,6 @@ | ||||
| 					RelativePath="src\encauth\ccm\ccm_memory.c" | ||||
| 					> | ||||
| 				</File> | ||||
| 				<File | ||||
| 					RelativePath="src\encauth\ccm\ccm_memory_ex.c" | ||||
| 					> | ||||
| 				</File> | ||||
| 				<File | ||||
| 					RelativePath="src\encauth\ccm\ccm_process.c" | ||||
| 					> | ||||
|  | ||||
							
								
								
									
										20
									
								
								makefile
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								makefile
									
									
									
									
									
								
							| @ -48,16 +48,16 @@ src/ciphers/kseed.o src/ciphers/multi2.o src/ciphers/noekeon.o src/ciphers/rc2.o | ||||
| src/ciphers/rc6.o src/ciphers/safer/safer.o src/ciphers/safer/saferp.o src/ciphers/skipjack.o \ | ||||
| src/ciphers/twofish/twofish.o src/ciphers/xtea.o src/encauth/ccm/ccm_add_aad.o \ | ||||
| src/encauth/ccm/ccm_add_nonce.o src/encauth/ccm/ccm_done.o src/encauth/ccm/ccm_init.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_memory_ex.o src/encauth/ccm/ccm_process.o \ | ||||
| src/encauth/ccm/ccm_reset.o src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o \ | ||||
| src/encauth/eax/eax_decrypt.o src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o \ | ||||
| src/encauth/eax/eax_encrypt.o src/encauth/eax/eax_encrypt_authenticate_memory.o \ | ||||
| src/encauth/eax/eax_init.o src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o \ | ||||
| src/encauth/gcm/gcm_add_iv.o src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o \ | ||||
| src/encauth/gcm/gcm_init.o src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o \ | ||||
| src/encauth/gcm/gcm_process.o src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o \ | ||||
| src/encauth/ocb/ocb_decrypt.o src/encauth/ocb/ocb_decrypt_verify_memory.o \ | ||||
| src/encauth/ocb/ocb_done_decrypt.o src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_process.o src/encauth/ccm/ccm_reset.o \ | ||||
| src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o src/encauth/eax/eax_decrypt.o \ | ||||
| src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o src/encauth/eax/eax_encrypt.o \ | ||||
| src/encauth/eax/eax_encrypt_authenticate_memory.o src/encauth/eax/eax_init.o \ | ||||
| src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o src/encauth/gcm/gcm_add_iv.o \ | ||||
| src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o src/encauth/gcm/gcm_init.o \ | ||||
| src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o src/encauth/gcm/gcm_process.o \ | ||||
| src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o src/encauth/ocb/ocb_decrypt.o \ | ||||
| src/encauth/ocb/ocb_decrypt_verify_memory.o src/encauth/ocb/ocb_done_decrypt.o \ | ||||
| src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ocb/ocb_encrypt_authenticate_memory.o src/encauth/ocb/ocb_init.o src/encauth/ocb/ocb_ntz.o \ | ||||
| src/encauth/ocb/ocb_shift_xor.o src/encauth/ocb/ocb_test.o src/encauth/ocb/s_ocb_done.o \ | ||||
| src/encauth/ocb3/ocb3_add_aad.o src/encauth/ocb3/ocb3_decrypt.o src/encauth/ocb3/ocb3_decrypt_last.o \ | ||||
|  | ||||
							
								
								
									
										20
									
								
								makefile.icc
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								makefile.icc
									
									
									
									
									
								
							| @ -105,16 +105,16 @@ src/ciphers/kseed.o src/ciphers/multi2.o src/ciphers/noekeon.o src/ciphers/rc2.o | ||||
| src/ciphers/rc6.o src/ciphers/safer/safer.o src/ciphers/safer/saferp.o src/ciphers/skipjack.o \ | ||||
| src/ciphers/twofish/twofish.o src/ciphers/xtea.o src/encauth/ccm/ccm_add_aad.o \ | ||||
| src/encauth/ccm/ccm_add_nonce.o src/encauth/ccm/ccm_done.o src/encauth/ccm/ccm_init.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_memory_ex.o src/encauth/ccm/ccm_process.o \ | ||||
| src/encauth/ccm/ccm_reset.o src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o \ | ||||
| src/encauth/eax/eax_decrypt.o src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o \ | ||||
| src/encauth/eax/eax_encrypt.o src/encauth/eax/eax_encrypt_authenticate_memory.o \ | ||||
| src/encauth/eax/eax_init.o src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o \ | ||||
| src/encauth/gcm/gcm_add_iv.o src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o \ | ||||
| src/encauth/gcm/gcm_init.o src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o \ | ||||
| src/encauth/gcm/gcm_process.o src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o \ | ||||
| src/encauth/ocb/ocb_decrypt.o src/encauth/ocb/ocb_decrypt_verify_memory.o \ | ||||
| src/encauth/ocb/ocb_done_decrypt.o src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_process.o src/encauth/ccm/ccm_reset.o \ | ||||
| src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o src/encauth/eax/eax_decrypt.o \ | ||||
| src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o src/encauth/eax/eax_encrypt.o \ | ||||
| src/encauth/eax/eax_encrypt_authenticate_memory.o src/encauth/eax/eax_init.o \ | ||||
| src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o src/encauth/gcm/gcm_add_iv.o \ | ||||
| src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o src/encauth/gcm/gcm_init.o \ | ||||
| src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o src/encauth/gcm/gcm_process.o \ | ||||
| src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o src/encauth/ocb/ocb_decrypt.o \ | ||||
| src/encauth/ocb/ocb_decrypt_verify_memory.o src/encauth/ocb/ocb_done_decrypt.o \ | ||||
| src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ocb/ocb_encrypt_authenticate_memory.o src/encauth/ocb/ocb_init.o src/encauth/ocb/ocb_ntz.o \ | ||||
| src/encauth/ocb/ocb_shift_xor.o src/encauth/ocb/ocb_test.o src/encauth/ocb/s_ocb_done.o \ | ||||
| src/encauth/ocb3/ocb3_add_aad.o src/encauth/ocb3/ocb3_decrypt.o src/encauth/ocb3/ocb3_decrypt_last.o \ | ||||
|  | ||||
| @ -52,16 +52,16 @@ src/ciphers/kseed.o src/ciphers/multi2.o src/ciphers/noekeon.o src/ciphers/rc2.o | ||||
| src/ciphers/rc6.o src/ciphers/safer/safer.o src/ciphers/safer/saferp.o src/ciphers/skipjack.o \ | ||||
| src/ciphers/twofish/twofish.o src/ciphers/xtea.o src/encauth/ccm/ccm_add_aad.o \ | ||||
| src/encauth/ccm/ccm_add_nonce.o src/encauth/ccm/ccm_done.o src/encauth/ccm/ccm_init.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_memory_ex.o src/encauth/ccm/ccm_process.o \ | ||||
| src/encauth/ccm/ccm_reset.o src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o \ | ||||
| src/encauth/eax/eax_decrypt.o src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o \ | ||||
| src/encauth/eax/eax_encrypt.o src/encauth/eax/eax_encrypt_authenticate_memory.o \ | ||||
| src/encauth/eax/eax_init.o src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o \ | ||||
| src/encauth/gcm/gcm_add_iv.o src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o \ | ||||
| src/encauth/gcm/gcm_init.o src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o \ | ||||
| src/encauth/gcm/gcm_process.o src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o \ | ||||
| src/encauth/ocb/ocb_decrypt.o src/encauth/ocb/ocb_decrypt_verify_memory.o \ | ||||
| src/encauth/ocb/ocb_done_decrypt.o src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_process.o src/encauth/ccm/ccm_reset.o \ | ||||
| src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o src/encauth/eax/eax_decrypt.o \ | ||||
| src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o src/encauth/eax/eax_encrypt.o \ | ||||
| src/encauth/eax/eax_encrypt_authenticate_memory.o src/encauth/eax/eax_init.o \ | ||||
| src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o src/encauth/gcm/gcm_add_iv.o \ | ||||
| src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o src/encauth/gcm/gcm_init.o \ | ||||
| src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o src/encauth/gcm/gcm_process.o \ | ||||
| src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o src/encauth/ocb/ocb_decrypt.o \ | ||||
| src/encauth/ocb/ocb_decrypt_verify_memory.o src/encauth/ocb/ocb_done_decrypt.o \ | ||||
| src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ocb/ocb_encrypt_authenticate_memory.o src/encauth/ocb/ocb_init.o src/encauth/ocb/ocb_ntz.o \ | ||||
| src/encauth/ocb/ocb_shift_xor.o src/encauth/ocb/ocb_test.o src/encauth/ocb/s_ocb_done.o \ | ||||
| src/encauth/ocb3/ocb3_add_aad.o src/encauth/ocb3/ocb3_decrypt.o src/encauth/ocb3/ocb3_decrypt_last.o \ | ||||
|  | ||||
| @ -10,16 +10,16 @@ src/ciphers/kseed.obj src/ciphers/multi2.obj src/ciphers/noekeon.obj src/ciphers | ||||
| src/ciphers/rc6.obj src/ciphers/safer/safer.obj src/ciphers/safer/saferp.obj src/ciphers/skipjack.obj \ | ||||
| src/ciphers/twofish/twofish.obj src/ciphers/xtea.obj src/encauth/ccm/ccm_add_aad.obj \ | ||||
| src/encauth/ccm/ccm_add_nonce.obj src/encauth/ccm/ccm_done.obj src/encauth/ccm/ccm_init.obj \ | ||||
| src/encauth/ccm/ccm_memory.obj src/encauth/ccm/ccm_memory_ex.obj src/encauth/ccm/ccm_process.obj \ | ||||
| src/encauth/ccm/ccm_reset.obj src/encauth/ccm/ccm_test.obj src/encauth/eax/eax_addheader.obj \ | ||||
| src/encauth/eax/eax_decrypt.obj src/encauth/eax/eax_decrypt_verify_memory.obj src/encauth/eax/eax_done.obj \ | ||||
| src/encauth/eax/eax_encrypt.obj src/encauth/eax/eax_encrypt_authenticate_memory.obj \ | ||||
| src/encauth/eax/eax_init.obj src/encauth/eax/eax_test.obj src/encauth/gcm/gcm_add_aad.obj \ | ||||
| src/encauth/gcm/gcm_add_iv.obj src/encauth/gcm/gcm_done.obj src/encauth/gcm/gcm_gf_mult.obj \ | ||||
| src/encauth/gcm/gcm_init.obj src/encauth/gcm/gcm_memory.obj src/encauth/gcm/gcm_mult_h.obj \ | ||||
| src/encauth/gcm/gcm_process.obj src/encauth/gcm/gcm_reset.obj src/encauth/gcm/gcm_test.obj \ | ||||
| src/encauth/ocb/ocb_decrypt.obj src/encauth/ocb/ocb_decrypt_verify_memory.obj \ | ||||
| src/encauth/ocb/ocb_done_decrypt.obj src/encauth/ocb/ocb_done_encrypt.obj src/encauth/ocb/ocb_encrypt.obj \ | ||||
| src/encauth/ccm/ccm_memory.obj src/encauth/ccm/ccm_process.obj src/encauth/ccm/ccm_reset.obj \ | ||||
| src/encauth/ccm/ccm_test.obj src/encauth/eax/eax_addheader.obj src/encauth/eax/eax_decrypt.obj \ | ||||
| src/encauth/eax/eax_decrypt_verify_memory.obj src/encauth/eax/eax_done.obj src/encauth/eax/eax_encrypt.obj \ | ||||
| src/encauth/eax/eax_encrypt_authenticate_memory.obj src/encauth/eax/eax_init.obj \ | ||||
| src/encauth/eax/eax_test.obj src/encauth/gcm/gcm_add_aad.obj src/encauth/gcm/gcm_add_iv.obj \ | ||||
| src/encauth/gcm/gcm_done.obj src/encauth/gcm/gcm_gf_mult.obj src/encauth/gcm/gcm_init.obj \ | ||||
| src/encauth/gcm/gcm_memory.obj src/encauth/gcm/gcm_mult_h.obj src/encauth/gcm/gcm_process.obj \ | ||||
| src/encauth/gcm/gcm_reset.obj src/encauth/gcm/gcm_test.obj src/encauth/ocb/ocb_decrypt.obj \ | ||||
| src/encauth/ocb/ocb_decrypt_verify_memory.obj src/encauth/ocb/ocb_done_decrypt.obj \ | ||||
| src/encauth/ocb/ocb_done_encrypt.obj src/encauth/ocb/ocb_encrypt.obj \ | ||||
| src/encauth/ocb/ocb_encrypt_authenticate_memory.obj src/encauth/ocb/ocb_init.obj src/encauth/ocb/ocb_ntz.obj \ | ||||
| src/encauth/ocb/ocb_shift_xor.obj src/encauth/ocb/ocb_test.obj src/encauth/ocb/s_ocb_done.obj \ | ||||
| src/encauth/ocb3/ocb3_add_aad.obj src/encauth/ocb3/ocb3_decrypt.obj src/encauth/ocb3/ocb3_decrypt_last.obj \ | ||||
|  | ||||
| @ -38,16 +38,16 @@ src/ciphers/kseed.o src/ciphers/multi2.o src/ciphers/noekeon.o src/ciphers/rc2.o | ||||
| src/ciphers/rc6.o src/ciphers/safer/safer.o src/ciphers/safer/saferp.o src/ciphers/skipjack.o \ | ||||
| src/ciphers/twofish/twofish.o src/ciphers/xtea.o src/encauth/ccm/ccm_add_aad.o \ | ||||
| src/encauth/ccm/ccm_add_nonce.o src/encauth/ccm/ccm_done.o src/encauth/ccm/ccm_init.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_memory_ex.o src/encauth/ccm/ccm_process.o \ | ||||
| src/encauth/ccm/ccm_reset.o src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o \ | ||||
| src/encauth/eax/eax_decrypt.o src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o \ | ||||
| src/encauth/eax/eax_encrypt.o src/encauth/eax/eax_encrypt_authenticate_memory.o \ | ||||
| src/encauth/eax/eax_init.o src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o \ | ||||
| src/encauth/gcm/gcm_add_iv.o src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o \ | ||||
| src/encauth/gcm/gcm_init.o src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o \ | ||||
| src/encauth/gcm/gcm_process.o src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o \ | ||||
| src/encauth/ocb/ocb_decrypt.o src/encauth/ocb/ocb_decrypt_verify_memory.o \ | ||||
| src/encauth/ocb/ocb_done_decrypt.o src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_process.o src/encauth/ccm/ccm_reset.o \ | ||||
| src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o src/encauth/eax/eax_decrypt.o \ | ||||
| src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o src/encauth/eax/eax_encrypt.o \ | ||||
| src/encauth/eax/eax_encrypt_authenticate_memory.o src/encauth/eax/eax_init.o \ | ||||
| src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o src/encauth/gcm/gcm_add_iv.o \ | ||||
| src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o src/encauth/gcm/gcm_init.o \ | ||||
| src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o src/encauth/gcm/gcm_process.o \ | ||||
| src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o src/encauth/ocb/ocb_decrypt.o \ | ||||
| src/encauth/ocb/ocb_decrypt_verify_memory.o src/encauth/ocb/ocb_done_decrypt.o \ | ||||
| src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ocb/ocb_encrypt_authenticate_memory.o src/encauth/ocb/ocb_init.o src/encauth/ocb/ocb_ntz.o \ | ||||
| src/encauth/ocb/ocb_shift_xor.o src/encauth/ocb/ocb_test.o src/encauth/ocb/s_ocb_done.o \ | ||||
| src/encauth/ocb3/ocb3_add_aad.o src/encauth/ocb3/ocb3_decrypt.o src/encauth/ocb3/ocb3_decrypt_last.o \ | ||||
|  | ||||
| @ -46,16 +46,16 @@ src/ciphers/kseed.o src/ciphers/multi2.o src/ciphers/noekeon.o src/ciphers/rc2.o | ||||
| src/ciphers/rc6.o src/ciphers/safer/safer.o src/ciphers/safer/saferp.o src/ciphers/skipjack.o \ | ||||
| src/ciphers/twofish/twofish.o src/ciphers/xtea.o src/encauth/ccm/ccm_add_aad.o \ | ||||
| src/encauth/ccm/ccm_add_nonce.o src/encauth/ccm/ccm_done.o src/encauth/ccm/ccm_init.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_memory_ex.o src/encauth/ccm/ccm_process.o \ | ||||
| src/encauth/ccm/ccm_reset.o src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o \ | ||||
| src/encauth/eax/eax_decrypt.o src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o \ | ||||
| src/encauth/eax/eax_encrypt.o src/encauth/eax/eax_encrypt_authenticate_memory.o \ | ||||
| src/encauth/eax/eax_init.o src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o \ | ||||
| src/encauth/gcm/gcm_add_iv.o src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o \ | ||||
| src/encauth/gcm/gcm_init.o src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o \ | ||||
| src/encauth/gcm/gcm_process.o src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o \ | ||||
| src/encauth/ocb/ocb_decrypt.o src/encauth/ocb/ocb_decrypt_verify_memory.o \ | ||||
| src/encauth/ocb/ocb_done_decrypt.o src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ccm/ccm_memory.o src/encauth/ccm/ccm_process.o src/encauth/ccm/ccm_reset.o \ | ||||
| src/encauth/ccm/ccm_test.o src/encauth/eax/eax_addheader.o src/encauth/eax/eax_decrypt.o \ | ||||
| src/encauth/eax/eax_decrypt_verify_memory.o src/encauth/eax/eax_done.o src/encauth/eax/eax_encrypt.o \ | ||||
| src/encauth/eax/eax_encrypt_authenticate_memory.o src/encauth/eax/eax_init.o \ | ||||
| src/encauth/eax/eax_test.o src/encauth/gcm/gcm_add_aad.o src/encauth/gcm/gcm_add_iv.o \ | ||||
| src/encauth/gcm/gcm_done.o src/encauth/gcm/gcm_gf_mult.o src/encauth/gcm/gcm_init.o \ | ||||
| src/encauth/gcm/gcm_memory.o src/encauth/gcm/gcm_mult_h.o src/encauth/gcm/gcm_process.o \ | ||||
| src/encauth/gcm/gcm_reset.o src/encauth/gcm/gcm_test.o src/encauth/ocb/ocb_decrypt.o \ | ||||
| src/encauth/ocb/ocb_decrypt_verify_memory.o src/encauth/ocb/ocb_done_decrypt.o \ | ||||
| src/encauth/ocb/ocb_done_encrypt.o src/encauth/ocb/ocb_encrypt.o \ | ||||
| src/encauth/ocb/ocb_encrypt_authenticate_memory.o src/encauth/ocb/ocb_init.o src/encauth/ocb/ocb_ntz.o \ | ||||
| src/encauth/ocb/ocb_shift_xor.o src/encauth/ocb/ocb_test.o src/encauth/ocb/s_ocb_done.o \ | ||||
| src/encauth/ocb3/ocb3_add_aad.o src/encauth/ocb3/ocb3_decrypt.o src/encauth/ocb3/ocb3_decrypt_last.o \ | ||||
|  | ||||
| @ -1,383 +0,0 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis
 | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  * | ||||
|  * Tom St Denis, tomstdenis@gmail.com, http://libtom.org
 | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
| 
 | ||||
| /**
 | ||||
|   @file ccm_memory.c | ||||
|   CCM support, process a block of memory, Tom St Denis | ||||
| */ | ||||
| 
 | ||||
| #if defined LTC_CCM_MODE && 0 | ||||
| 
 | ||||
| /**
 | ||||
|    CCM encrypt/decrypt and produce an authentication tag | ||||
|    @param cipher     The index of the cipher desired | ||||
|    @param key        The secret key to use | ||||
|    @param keylen     The length of the secret key (octets) | ||||
|    @param uskey      A previously scheduled key [optional can be NULL] | ||||
|    @param nonce      The session nonce [use once] | ||||
|    @param noncelen   The length of the nonce | ||||
|    @param header     The header for the session | ||||
|    @param headerlen  The length of the header (octets) | ||||
|    @param pt         [out] The plaintext | ||||
|    @param ptlen      The length of the plaintext (octets) | ||||
|    @param ct         [out] The ciphertext | ||||
|    @param tag        [out] The destination tag | ||||
|    @param taglen     [in/out] The max size and resulting size of the authentication tag | ||||
|    @param direction  Encrypt or Decrypt direction (0 or 1) | ||||
|    @return CRYPT_OK if successful | ||||
| */ | ||||
| int ccm_memory_ex(int cipher, | ||||
|     const unsigned char *key,    unsigned long keylen, | ||||
|     symmetric_key       *uskey, | ||||
|     const unsigned char *nonce,  unsigned long noncelen, | ||||
|     const unsigned char *header, unsigned long headerlen, | ||||
|           unsigned char *pt,     unsigned long ptlen, | ||||
|           unsigned char *ct, | ||||
|           unsigned char *tag,    unsigned long *taglen, | ||||
|                     int  direction, | ||||
|     const unsigned char *B_0, | ||||
|     const unsigned char *CTR, | ||||
|                     int  ctrwidth) | ||||
| { | ||||
|    unsigned char  PAD[16], ctr[16], CTRPAD[16], ctrcopy[16], b; | ||||
|    symmetric_key *skey; | ||||
|    int            err; | ||||
|    unsigned long  len, L, x, y, z, CTRlen; | ||||
| 
 | ||||
|    if (uskey == NULL) { | ||||
|       LTC_ARGCHK(key    != NULL); | ||||
|    } | ||||
|    LTC_ARGCHK(nonce  != NULL); | ||||
|    if (headerlen > 0) { | ||||
|       LTC_ARGCHK(header != NULL); | ||||
|    } | ||||
|    LTC_ARGCHK(pt     != NULL); | ||||
|    LTC_ARGCHK(ct     != NULL); | ||||
|    LTC_ARGCHK(tag    != NULL); | ||||
|    LTC_ARGCHK(taglen != NULL); | ||||
| 
 | ||||
| #ifdef LTC_FAST | ||||
|    if (16 % sizeof(LTC_FAST_TYPE)) { | ||||
|       return CRYPT_INVALID_ARG; | ||||
|    } | ||||
| #endif | ||||
| 
 | ||||
|    /* check cipher input */ | ||||
|    if ((err = cipher_is_valid(cipher)) != CRYPT_OK) { | ||||
|       return err; | ||||
|    } | ||||
|    if (cipher_descriptor[cipher].block_length != 16) { | ||||
|       return CRYPT_INVALID_CIPHER; | ||||
|    } | ||||
| 
 | ||||
|    /* make sure the taglen is even and <= 16 */ | ||||
|    *taglen &= ~1; | ||||
|    if (*taglen > 16) { | ||||
|       *taglen = 16; | ||||
|    } | ||||
| 
 | ||||
|    /* can't use < 4 */ | ||||
|    if (*taglen < 4) { | ||||
|       return CRYPT_INVALID_ARG; | ||||
|    } | ||||
| 
 | ||||
|    /* is there an accelerator? */ | ||||
|    if (cipher_descriptor[cipher].accel_ccm_memory != NULL) { | ||||
|        return cipher_descriptor[cipher].accel_ccm_memory( | ||||
|            key,    keylen, | ||||
|            uskey, | ||||
|            nonce,  noncelen, | ||||
|            header, headerlen, | ||||
|            pt,     ptlen, | ||||
|            ct, | ||||
|            tag,    taglen, | ||||
|            direction); | ||||
|    } | ||||
| 
 | ||||
|    /* let's get the L value */ | ||||
|    len = ptlen; | ||||
|    L   = 0; | ||||
|    while (len) { | ||||
|       ++L; | ||||
|       len >>= 8; | ||||
|    } | ||||
|    if (L <= 1) { | ||||
|       L = 2; | ||||
|    } | ||||
| 
 | ||||
|    /* increase L to match the nonce len */ | ||||
|    noncelen = (noncelen > 13) ? 13 : noncelen; | ||||
|    if ((15 - noncelen) > L) { | ||||
|       L = 15 - noncelen; | ||||
|    } | ||||
| 
 | ||||
|    /* decrease noncelen to match L */ | ||||
|    if ((noncelen + L) > 15) { | ||||
|       noncelen = 15 - L; | ||||
|    } | ||||
| 
 | ||||
|    /* allocate mem for the symmetric key */ | ||||
|    if (uskey == NULL) { | ||||
|       skey = XMALLOC(sizeof(*skey)); | ||||
|       if (skey == NULL) { | ||||
|          return CRYPT_MEM; | ||||
|       } | ||||
| 
 | ||||
|       /* initialize the cipher */ | ||||
|       if ((err = cipher_descriptor[cipher].setup(key, keylen, 0, skey)) != CRYPT_OK) { | ||||
|          XFREE(skey); | ||||
|          return err; | ||||
|       } | ||||
|    } else { | ||||
|       skey = uskey; | ||||
|    } | ||||
| 
 | ||||
|    /* form B_0 == flags | Nonce N | l(m) */ | ||||
|    x = 0; | ||||
| 
 | ||||
| if (B_0 == NULL) { | ||||
|    PAD[x++] = (unsigned char)(((headerlen > 0) ? (1<<6) : 0) | | ||||
|             (((*taglen - 2)>>1)<<3)        | | ||||
|             (L-1)); | ||||
| 
 | ||||
|    /* nonce */ | ||||
|    for (y = 0; y < (16 - (L + 1)); y++) { | ||||
|        PAD[x++] = nonce[y]; | ||||
|    } | ||||
| 
 | ||||
|    /* store len */ | ||||
|    len = ptlen; | ||||
| 
 | ||||
|    /* shift len so the upper bytes of len are the contents of the length */ | ||||
|    for (y = L; y < 4; y++) { | ||||
|        len <<= 8; | ||||
|    } | ||||
| 
 | ||||
|    /* store l(m) (only store 32-bits) */ | ||||
|    for (y = 0; L > 4 && (L-y)>4; y++) { | ||||
|        PAD[x++] = 0; | ||||
|    } | ||||
|    for (; y < L; y++) { | ||||
|        PAD[x++] = (unsigned char)((len >> 24) & 255); | ||||
|        len <<= 8; | ||||
|    } | ||||
| 
 | ||||
| } else { | ||||
|    /* B_0 != NULL */ | ||||
|    XMEMCPY(PAD, B_0, 16); | ||||
| } | ||||
| 
 | ||||
|    /* encrypt PAD */ | ||||
|    if ((err = cipher_descriptor[cipher].ecb_encrypt(PAD, PAD, skey)) != CRYPT_OK) { | ||||
|        goto error; | ||||
|    } | ||||
| 
 | ||||
|    /* handle header */ | ||||
|    if (headerlen > 0) { | ||||
|       x = 0; | ||||
| 
 | ||||
| #if 0 | ||||
|       /* store length */ | ||||
|       if (headerlen < ((1UL<<16) - (1UL<<8))) { | ||||
|          PAD[x++] ^= (headerlen>>8) & 255; | ||||
|          PAD[x++] ^= headerlen & 255; | ||||
|       } else { | ||||
|          PAD[x++] ^= 0xFF; | ||||
|          PAD[x++] ^= 0xFE; | ||||
|          PAD[x++] ^= (headerlen>>24) & 255; | ||||
|          PAD[x++] ^= (headerlen>>16) & 255; | ||||
|          PAD[x++] ^= (headerlen>>8) & 255; | ||||
|          PAD[x++] ^= headerlen & 255; | ||||
|       } | ||||
| #endif | ||||
| 
 | ||||
|       /* now add the data */ | ||||
|       for (y = 0; y < headerlen; y++) { | ||||
|           if (x == 16) { | ||||
|              /* full block so let's encrypt it */ | ||||
|              if ((err = cipher_descriptor[cipher].ecb_encrypt(PAD, PAD, skey)) != CRYPT_OK) { | ||||
|                 goto error; | ||||
|              } | ||||
|              x = 0; | ||||
|           } | ||||
|           PAD[x++] ^= header[y]; | ||||
|       } | ||||
| 
 | ||||
|       /* remainder? */ | ||||
|       if (x != 0) { | ||||
|          if ((err = cipher_descriptor[cipher].ecb_encrypt(PAD, PAD, skey)) != CRYPT_OK) { | ||||
|             goto error; | ||||
|          } | ||||
|       } | ||||
|    } | ||||
| 
 | ||||
|    /* setup the ctr counter */ | ||||
| if (CTR == NULL) { | ||||
|    x = 0; | ||||
| 
 | ||||
|    /* flags */ | ||||
|    ctr[x++] = (unsigned char)L-1; | ||||
| 
 | ||||
|    /* nonce */ | ||||
|    for (y = 0; y < (16 - (L+1)); ++y) { | ||||
|       ctr[x++] = nonce[y]; | ||||
|    } | ||||
|    /* offset */ | ||||
|    while (x < 16) { | ||||
|       ctr[x++] = 0; | ||||
|    } | ||||
| } else { | ||||
|    XMEMCPY(ctr, CTR, 16); | ||||
| } | ||||
| 
 | ||||
|    x      = 0; | ||||
|    CTRlen = 16; | ||||
| 
 | ||||
|    /* now handle the PT */ | ||||
|    if (ptlen > 0) { | ||||
|       y = 0; | ||||
| #ifdef LTC_FAST2 | ||||
|       if (ptlen & ~15)  { | ||||
|           if (direction == CCM_ENCRYPT) { | ||||
|              for (; y < (ptlen & ~15); y += 16) { | ||||
|                 /* increment the ctr? */ | ||||
|                 for (z = 15; (int)z > (int)(15-ctrwidth); z--) { | ||||
|                     ctr[z] = (ctr[z] + 1) & 255; | ||||
|                     if (ctr[z]) break; | ||||
|                 } | ||||
|                 if ((err = cipher_descriptor[cipher].ecb_encrypt(ctr, CTRPAD, skey)) != CRYPT_OK) { | ||||
|                    goto error; | ||||
|                 } | ||||
| 
 | ||||
|                 /* xor the PT against the pad first */ | ||||
|                 for (z = 0; z < 16; z += sizeof(LTC_FAST_TYPE)) { | ||||
|                     *(LTC_FAST_TYPE_PTR_CAST(&PAD[z]))  ^= *(LTC_FAST_TYPE_PTR_CAST(&pt[y+z])); | ||||
|                     *(LTC_FAST_TYPE_PTR_CAST(&ct[y+z])) = *(LTC_FAST_TYPE_PTR_CAST(&pt[y+z])) ^ *(LTC_FAST_TYPE_PTR_CAST(&CTRPAD[z])); | ||||
|                 } | ||||
|                 if ((err = cipher_descriptor[cipher].ecb_encrypt(PAD, PAD, skey)) != CRYPT_OK) { | ||||
|                    goto error; | ||||
|                 } | ||||
|              } | ||||
|          } else { | ||||
|              for (; y < (ptlen & ~15); y += 16) { | ||||
|                 /* increment the ctr? */ | ||||
|                 for (z = 15; (int)z > (int)(15-ctrwidth); z--) { | ||||
|                     ctr[z] = (ctr[z] + 1) & 255; | ||||
|                     if (ctr[z]) break; | ||||
|                 } | ||||
|                 if ((err = cipher_descriptor[cipher].ecb_encrypt(ctr, CTRPAD, skey)) != CRYPT_OK) { | ||||
|                    goto error; | ||||
|                 } | ||||
| 
 | ||||
|                 /* xor the PT against the pad last */ | ||||
|                 for (z = 0; z < 16; z += sizeof(LTC_FAST_TYPE)) { | ||||
|                     *(LTC_FAST_TYPE_PTR_CAST(&pt[y+z])) = *(LTC_FAST_TYPE_PTR_CAST(&ct[y+z])) ^ *(LTC_FAST_TYPE_PTR_CAST(&CTRPAD[z])); | ||||
|                     *(LTC_FAST_TYPE_PTR_CAST(&PAD[z]))  ^= *(LTC_FAST_TYPE_PTR_CAST(&pt[y+z])); | ||||
|                 } | ||||
|                 if ((err = cipher_descriptor[cipher].ecb_encrypt(PAD, PAD, skey)) != CRYPT_OK) { | ||||
|                    goto error; | ||||
|                 } | ||||
|              } | ||||
|          } | ||||
|      } | ||||
| #endif | ||||
| 
 | ||||
|       for (; y < ptlen; y++) { | ||||
|           /* increment the ctr? */ | ||||
|           if (CTRlen == 16) { | ||||
|              for (z = 15; (int)z > (int)(15-ctrwidth); z--) { | ||||
|                  ctr[z] = (ctr[z] + 1) & 255; | ||||
|                  if (ctr[z]) break; | ||||
|              } | ||||
|              if ((err = cipher_descriptor[cipher].ecb_encrypt(ctr, CTRPAD, skey)) != CRYPT_OK) { | ||||
|                 goto error; | ||||
|              } | ||||
|              CTRlen = 0; | ||||
|           } | ||||
| 
 | ||||
|           /* if we encrypt we add the bytes to the MAC first */ | ||||
|           if (direction == CCM_ENCRYPT) { | ||||
|              b     = pt[y]; | ||||
|              ct[y] = b ^ CTRPAD[CTRlen++]; | ||||
|           } else { | ||||
|              b     = ct[y] ^ CTRPAD[CTRlen++]; | ||||
|              pt[y] = b; | ||||
|           } | ||||
| 
 | ||||
|           if (x == 16) { | ||||
|              if ((err = cipher_descriptor[cipher].ecb_encrypt(PAD, PAD, skey)) != CRYPT_OK) { | ||||
|                 goto error; | ||||
|              } | ||||
|              x = 0; | ||||
|           } | ||||
|           PAD[x++] ^= b; | ||||
|       } | ||||
| 
 | ||||
|       if (x != 0) { | ||||
|          if ((err = cipher_descriptor[cipher].ecb_encrypt(PAD, PAD, skey)) != CRYPT_OK) { | ||||
|             goto error; | ||||
|          } | ||||
|       } | ||||
|    } | ||||
| 
 | ||||
|    /* grab the CTR */ | ||||
|    XMEMCPY(ctrcopy, ctr, 16); | ||||
| 
 | ||||
|    /* setup CTR for the TAG (zero the count) */ | ||||
|    if (CTR == NULL) { | ||||
|       for (y = 15; y > 15 - L; y--) { | ||||
|          ctr[y] = 0x00; | ||||
|       } | ||||
|    } else { | ||||
|       XMEMCPY(ctr, CTR, 16); | ||||
|    } | ||||
| 
 | ||||
|    if ((err = cipher_descriptor[cipher].ecb_encrypt(ctr, CTRPAD, skey)) != CRYPT_OK) { | ||||
|       goto error; | ||||
|    } | ||||
| 
 | ||||
|    if (skey != uskey) { | ||||
|       cipher_descriptor[cipher].done(skey); | ||||
|    } | ||||
| 
 | ||||
|    /* store the TAG */ | ||||
|    for (x = 0; x < 16 && x < *taglen; x++) { | ||||
|        tag[x] = PAD[x] ^ CTRPAD[x]; | ||||
|    } | ||||
|    *taglen = x; | ||||
| 
 | ||||
| if (CTR != NULL) { | ||||
|   for (z = 15; (int)z > (int)(15-ctrwidth); z--) { | ||||
|      ctrcopy[z] = (ctrcopy[z] + 1) & 255; | ||||
|      if (ctrcopy[z]) break; | ||||
|   } | ||||
|    XMEMCPY(CTR, ctrcopy, 16); | ||||
| } | ||||
| 
 | ||||
| #ifdef LTC_CLEAN_STACK | ||||
|    zeromem(skey,   sizeof(*skey)); | ||||
|    zeromem(PAD,    sizeof(PAD)); | ||||
|    zeromem(CTRPAD, sizeof(CTRPAD)); | ||||
| #endif | ||||
| error: | ||||
|    if (skey != uskey) { | ||||
|       XFREE(skey); | ||||
|    } | ||||
| 
 | ||||
|    return err; | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| /* $Source$ */ | ||||
| /* $Revision$ */ | ||||
| /* $Date$ */ | ||||
| @ -307,19 +307,6 @@ int ccm_memory(int cipher, | ||||
|           unsigned char *tag,    unsigned long *taglen, | ||||
|                     int  direction); | ||||
| 
 | ||||
| int ccm_memory_ex(int cipher, | ||||
|     const unsigned char *key,    unsigned long keylen, | ||||
|     symmetric_key       *uskey, | ||||
|     const unsigned char *nonce,  unsigned long noncelen, | ||||
|     const unsigned char *header, unsigned long headerlen, | ||||
|           unsigned char *pt,     unsigned long ptlen, | ||||
|           unsigned char *ct, | ||||
|           unsigned char *tag,    unsigned long *taglen, | ||||
|                     int  direction, | ||||
|     const unsigned char *B_0, | ||||
|     const unsigned char *CTR, | ||||
|                     int  ctrwidth); | ||||
| 
 | ||||
| int ccm_test(void); | ||||
| 
 | ||||
| #endif /* LTC_CCM_MODE */ | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user