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
8 obj-
$(CONFIG_CRYPTO_SERPENT_SSE2_586
) += serpent-sse2-i586.o
10 obj-
$(CONFIG_CRYPTO_AES_X86_64
) += aes-x86_64.o
11 obj-
$(CONFIG_CRYPTO_BLOWFISH_X86_64
) += blowfish-x86_64.o
12 obj-
$(CONFIG_CRYPTO_TWOFISH_X86_64
) += twofish-x86_64.o
13 obj-
$(CONFIG_CRYPTO_TWOFISH_X86_64_3WAY
) += twofish-x86_64-3way.o
14 obj-
$(CONFIG_CRYPTO_SALSA20_X86_64
) += salsa20-x86_64.o
15 obj-
$(CONFIG_CRYPTO_SERPENT_SSE2_X86_64
) += serpent-sse2-x86_64.o
16 obj-
$(CONFIG_CRYPTO_AES_NI_INTEL
) += aesni-intel.o
17 obj-
$(CONFIG_CRYPTO_GHASH_CLMUL_NI_INTEL
) += ghash-clmulni-intel.o
19 obj-
$(CONFIG_CRYPTO_CRC32C_INTEL
) += crc32c-intel.o
20 obj-
$(CONFIG_CRYPTO_SHA1_SSSE3
) += sha1-ssse3.o
22 aes-i586-y
:= aes-i586-asm_32.o aes_glue.o
23 twofish-i586-y
:= twofish-i586-asm_32.o twofish_glue.o
24 salsa20-i586-y
:= salsa20-i586-asm_32.o salsa20_glue.o
25 serpent-sse2-i586-y
:= serpent-sse2-i586-asm_32.o serpent_sse2_glue.o
27 aes-x86_64-y
:= aes-x86_64-asm_64.o aes_glue.o
28 blowfish-x86_64-y
:= blowfish-x86_64-asm_64.o blowfish_glue.o
29 twofish-x86_64-y
:= twofish-x86_64-asm_64.o twofish_glue.o
30 twofish-x86_64-3way-y
:= twofish-x86_64-asm_64-3way.o twofish_glue_3way.o
31 salsa20-x86_64-y
:= salsa20-x86_64-asm_64.o salsa20_glue.o
32 serpent-sse2-x86_64-y
:= serpent-sse2-x86_64-asm_64.o serpent_sse2_glue.o
34 aesni-intel-y
:= aesni-intel_asm.o aesni-intel_glue.o fpu.o
36 ghash-clmulni-intel-y
:= ghash-clmulni-intel_asm.o ghash-clmulni-intel_glue.o
38 # enable AVX support only when $(AS) can actually assemble the instructions
39 ifeq ($(call as-instr
,vpxor
%xmm0
$(comma
)%xmm1
$(comma
)%xmm2
,yes
,no
),yes
)
40 AFLAGS_sha1_ssse3_asm.o
+= -DSHA1_ENABLE_AVX_SUPPORT
41 CFLAGS_sha1_ssse3_glue.o
+= -DSHA1_ENABLE_AVX_SUPPORT
43 sha1-ssse3-y
:= sha1_ssse3_asm.o sha1_ssse3_glue.o