2 # Arch-specific CryptoAPI modules.
5 obj-
$(CONFIG_CRYPTO_AES_586
) += aes-i586.o
6 obj-
$(CONFIG_CRYPTO_TWOFISH_586
) += twofish-i586.o
7 obj-
$(CONFIG_CRYPTO_SALSA20_586
) += salsa20-i586.o
9 obj-
$(CONFIG_CRYPTO_AES_X86_64
) += aes-x86_64.o
10 obj-
$(CONFIG_CRYPTO_BLOWFISH_X86_64
) += blowfish-x86_64.o
11 obj-
$(CONFIG_CRYPTO_TWOFISH_X86_64
) += twofish-x86_64.o
12 obj-
$(CONFIG_CRYPTO_TWOFISH_X86_64_3WAY
) += twofish-x86_64-3way.o
13 obj-
$(CONFIG_CRYPTO_SALSA20_X86_64
) += salsa20-x86_64.o
14 obj-
$(CONFIG_CRYPTO_AES_NI_INTEL
) += aesni-intel.o
15 obj-
$(CONFIG_CRYPTO_GHASH_CLMUL_NI_INTEL
) += ghash-clmulni-intel.o
17 obj-
$(CONFIG_CRYPTO_CRC32C_INTEL
) += crc32c-intel.o
18 obj-
$(CONFIG_CRYPTO_SHA1_SSSE3
) += sha1-ssse3.o
20 aes-i586-y
:= aes-i586-asm_32.o aes_glue.o
21 twofish-i586-y
:= twofish-i586-asm_32.o twofish_glue.o
22 salsa20-i586-y
:= salsa20-i586-asm_32.o salsa20_glue.o
24 aes-x86_64-y
:= aes-x86_64-asm_64.o aes_glue.o
25 blowfish-x86_64-y
:= blowfish-x86_64-asm_64.o blowfish_glue.o
26 twofish-x86_64-y
:= twofish-x86_64-asm_64.o twofish_glue.o
27 twofish-x86_64-3way-y
:= twofish-x86_64-asm_64-3way.o twofish_glue_3way.o
28 salsa20-x86_64-y
:= salsa20-x86_64-asm_64.o salsa20_glue.o
30 aesni-intel-y
:= aesni-intel_asm.o aesni-intel_glue.o fpu.o
32 ghash-clmulni-intel-y
:= ghash-clmulni-intel_asm.o ghash-clmulni-intel_glue.o
34 # enable AVX support only when $(AS) can actually assemble the instructions
35 ifeq ($(call as-instr
,vpxor
%xmm0
$(comma
)%xmm1
$(comma
)%xmm2
,yes
,no
),yes
)
36 AFLAGS_sha1_ssse3_asm.o
+= -DSHA1_ENABLE_AVX_SUPPORT
37 CFLAGS_sha1_ssse3_glue.o
+= -DSHA1_ENABLE_AVX_SUPPORT
39 sha1-ssse3-y
:= sha1_ssse3_asm.o sha1_ssse3_glue.o