######################################################################## # Copyright(c) 2011-2016 Intel Corporation All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # * Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # * Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in # the documentation and/or other materials provided with the # distribution. # * Neither the name of Intel Corporation nor the names of its # contributors may be used to endorse or promote products derived # from this software without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ######################################################################## # Assembling AES requires including cbc_common.asm, gcm_defines.asm src_include += -I $(srcdir)/aes extern_hdrs += include/aes_gcm.h include/aes_cbc.h include/aes_xts.h include/aes_keyexp.h lsrc_x86_64 += aes/gcm_multibinary.asm aes/gcm_pre.c lsrc_x86_64 += aes/gcm128_avx_gen2.asm aes/gcm128_avx_gen4.asm aes/gcm128_sse.asm lsrc_x86_64 += aes/gcm256_avx_gen2.asm aes/gcm256_avx_gen4.asm aes/gcm256_sse.asm lsrc_x86_64 += aes/gcm128_vaes_avx512.asm aes/gcm256_vaes_avx512.asm lsrc_x86_64 += aes/gcm128_avx_gen2_nt.asm aes/gcm128_avx_gen4_nt.asm aes/gcm128_sse_nt.asm lsrc_x86_64 += aes/gcm256_avx_gen2_nt.asm aes/gcm256_avx_gen4_nt.asm aes/gcm256_sse_nt.asm lsrc_x86_64 += aes/gcm128_vaes_avx512_nt.asm aes/gcm256_vaes_avx512_nt.asm lsrc_x86_64 += aes/gcm_multibinary_nt.asm lsrc_x86_64 += aes/keyexp_multibinary.asm lsrc_x86_64 += aes/keyexp_128.asm aes/keyexp_192.asm aes/keyexp_256.asm lsrc_x86_64 += aes/cbc_multibinary.asm lsrc_x86_64 += aes/cbc_dec_128_x4_sse.asm aes/cbc_dec_128_x8_avx.asm lsrc_x86_64 += aes/cbc_dec_192_x4_sse.asm aes/cbc_dec_192_x8_avx.asm lsrc_x86_64 += aes/cbc_dec_256_x4_sse.asm aes/cbc_dec_256_x8_avx.asm lsrc_x86_64 += aes/cbc_enc_128_x4_sb.asm aes/cbc_enc_128_x8_sb.asm lsrc_x86_64 += aes/cbc_enc_192_x4_sb.asm aes/cbc_enc_192_x8_sb.asm lsrc_x86_64 += aes/cbc_enc_256_x4_sb.asm aes/cbc_enc_256_x8_sb.asm lsrc_x86_64 += aes/cbc_dec_vaes_avx512.asm lsrc_x86_64 += aes/cbc_pre.c lsrc_x86_64 += aes/xts_aes_128_multibinary.asm lsrc_x86_64 += aes/XTS_AES_128_dec_sse.asm aes/XTS_AES_128_dec_expanded_key_sse.asm lsrc_x86_64 += aes/XTS_AES_128_enc_sse.asm aes/XTS_AES_128_enc_expanded_key_sse.asm lsrc_x86_64 += aes/XTS_AES_128_dec_avx.asm aes/XTS_AES_128_dec_expanded_key_avx.asm lsrc_x86_64 += aes/XTS_AES_128_enc_avx.asm aes/XTS_AES_128_enc_expanded_key_avx.asm lsrc_x86_64 += aes/xts_aes_256_multibinary.asm lsrc_x86_64 += aes/XTS_AES_256_dec_avx.asm aes/XTS_AES_256_dec_expanded_key_avx.asm lsrc_x86_64 += aes/XTS_AES_256_enc_avx.asm aes/XTS_AES_256_enc_expanded_key_avx.asm lsrc_x86_64 += aes/XTS_AES_256_dec_sse.asm aes/XTS_AES_256_dec_expanded_key_sse.asm lsrc_x86_64 += aes/XTS_AES_256_enc_sse.asm aes/XTS_AES_256_enc_expanded_key_sse.asm lsrc_x86_64 += aes/XTS_AES_256_enc_vaes.asm lsrc_x86_64 += aes/XTS_AES_128_enc_vaes.asm lsrc_x86_64 += aes/XTS_AES_256_enc_expanded_key_vaes.asm lsrc_x86_64 += aes/XTS_AES_128_enc_expanded_key_vaes.asm lsrc_x86_64 += aes/XTS_AES_256_dec_vaes.asm lsrc_x86_64 += aes/XTS_AES_128_dec_vaes.asm lsrc_x86_64 += aes/XTS_AES_256_dec_expanded_key_vaes.asm lsrc_x86_64 += aes/XTS_AES_128_dec_expanded_key_vaes.asm lsrc_x86_32 += $(lsrc_x86_64) lsrc_aarch64 += aes/gcm_pre.c \ aes/aarch64/gcm_multibinary_aarch64.S \ aes/aarch64/keyexp_multibinary_aarch64.S \ aes/aarch64/gcm_aarch64_dispatcher.c \ aes/aarch64/keyexp_aarch64_dispatcher.c \ aes/aarch64/keyexp_128_aarch64_aes.S \ aes/aarch64/keyexp_192_aarch64_aes.S \ aes/aarch64/keyexp_256_aarch64_aes.S \ aes/aarch64/aes_gcm_aes_finalize_128.S \ aes/aarch64/aes_gcm_aes_init.S \ aes/aarch64/aes_gcm_enc_dec_128.S \ aes/aarch64/aes_gcm_precomp_128.S \ aes/aarch64/aes_gcm_update_128.S \ aes/aarch64/aes_gcm_aes_finalize_256.S \ aes/aarch64/aes_gcm_consts.S \ aes/aarch64/aes_gcm_enc_dec_256.S \ aes/aarch64/aes_gcm_precomp_256.S \ aes/aarch64/aes_gcm_update_256.S \ aes/aarch64/xts_aarch64_dispatcher.c \ aes/aarch64/xts_aes_128_dec.S \ aes/aarch64/xts_aes_128_enc.S \ aes/aarch64/xts_keyexp_aes_128_dec.S \ aes/aarch64/xts_keyexp_aes_128_enc.S \ aes/aarch64/xts_aes_256_dec.S \ aes/aarch64/xts_aes_256_enc.S \ aes/aarch64/xts_keyexp_aes_256_dec.S \ aes/aarch64/xts_keyexp_aes_256_enc.S \ aes/aarch64/xts_multibinary_aarch64.S \ aes/cbc_pre.c \ aes/aarch64/cbc_multibinary_aarch64.S \ aes/aarch64/cbc_aarch64_dispatcher.c \ aes/aarch64/cbc_enc_aes.S \ aes/aarch64/cbc_dec_aes.S other_src += include/multibinary.asm other_src += include/test.h include/types.h include/reg_sizes.asm other_src += aes/gcm_defines.asm other_src += aes/aes_common.asm other_src += aes/clear_regs.asm other_src += aes/cbc_common.asm aes/cbc_std_vectors.h other_src += aes/gcm_vectors.h aes/ossl_helper.h other_src += aes/xts_128_vect.h other_src += aes/xts_256_vect.h other_src += aes/gcm_sse.asm other_src += aes/gcm_avx_gen2.asm other_src += aes/gcm_avx_gen4.asm other_src += aes/gcm_keys_vaes_avx512.asm other_src += aes/gcm_vaes_avx512.asm check_tests += aes/cbc_std_vectors_test check_tests += aes/gcm_std_vectors_test check_tests += aes/gcm_nt_std_vectors_test check_tests += aes/xts_128_test check_tests += aes/xts_256_test check_tests += aes/xts_128_expanded_key_test check_tests += aes/xts_256_expanded_key_test unit_tests += aes/cbc_std_vectors_random_test unit_tests += aes/gcm_std_vectors_random_test unit_tests += aes/gcm_nt_rand_test unit_tests += aes/xts_128_rand aes/xts_128_rand_ossl_test unit_tests += aes/xts_256_rand aes/xts_256_rand_ossl_test perf_tests += aes/cbc_ossl_perf perf_tests += aes/gcm_ossl_perf perf_tests += aes/xts_128_enc_ossl_perf perf_tests += aes/xts_256_enc_ossl_perf perf_tests += aes/xts_128_enc_perf aes/xts_128_dec_perf aes/xts_128_dec_ossl_perf perf_tests += aes/xts_256_enc_perf aes/xts_256_dec_perf aes/xts_256_dec_ossl_perf examples += aes/gcm_simple_example cbc_ossl_perf: LDLIBS += -lcrypto aes_cbc_ossl_perf_LDFLAGS = -lcrypto cbc_std_vectors_random_test: LDLIBS += -lcrypto aes_cbc_std_vectors_random_test_LDFLAGS = -lcrypto gcm_ossl_perf: LDLIBS += -lcrypto aes_gcm_ossl_perf_LDFLAGS = -lcrypto gcm_std_vectors_random_test: LDLIBS += -lcrypto aes_gcm_std_vectors_random_test_LDFLAGS = -lcrypto gcm_nt_rand_test: LDLIBS += -lcrypto aes_gcm_nt_rand_test_LDFLAGS = -lcrypto xts_128_enc_ossl_perf: LDLIBS += -lcrypto aes_xts_128_enc_ossl_perf_LDFLAGS = -lcrypto xts_128_dec_ossl_perf: LDLIBS += -lcrypto aes_xts_128_dec_ossl_perf_LDFLAGS = -lcrypto xts_128_rand_ossl_test: LDLIBS += -lcrypto aes_xts_128_rand_ossl_test_LDFLAGS = -lcrypto xts_256_enc_ossl_perf : LDLIBS += -lcrypto aes_xts_256_enc_ossl_perf_LDFLAGS = -lcrypto xts_256_dec_ossl_perf : LDLIBS += -lcrypto aes_xts_256_dec_ossl_perf_LDFLAGS = -lcrypto xts_256_rand_ossl_test: LDLIBS += -lcrypto aes_xts_256_rand_ossl_test_LDFLAGS = -lcrypto