1 # SPDX-License-Identifier: GPL-2.0-only
3 # linux/arch/arm64/crypto/Makefile
5 # Copyright (C) 2014 Linaro Ltd <ard.biesheuvel@linaro.org>
8 obj-
$(CONFIG_CRYPTO_SHA1_ARM64_CE
) += sha1-ce.o
9 sha1-ce-y
:= sha1-ce-glue.o sha1-ce-core.o
11 obj-
$(CONFIG_CRYPTO_SHA2_ARM64_CE
) += sha2-ce.o
12 sha2-ce-y
:= sha2-ce-glue.o sha2-ce-core.o
14 obj-
$(CONFIG_CRYPTO_SHA512_ARM64_CE
) += sha512-ce.o
15 sha512-ce-y
:= sha512-ce-glue.o sha512-ce-core.o
17 obj-
$(CONFIG_CRYPTO_SHA3_ARM64
) += sha3-ce.o
18 sha3-ce-y
:= sha3-ce-glue.o sha3-ce-core.o
20 obj-
$(CONFIG_CRYPTO_SM3_ARM64_CE
) += sm3-ce.o
21 sm3-ce-y
:= sm3-ce-glue.o sm3-ce-core.o
23 obj-
$(CONFIG_CRYPTO_SM4_ARM64_CE
) += sm4-ce.o
24 sm4-ce-y
:= sm4-ce-glue.o sm4-ce-core.o
26 obj-
$(CONFIG_CRYPTO_GHASH_ARM64_CE
) += ghash-ce.o
27 ghash-ce-y
:= ghash-ce-glue.o ghash-ce-core.o
29 obj-
$(CONFIG_CRYPTO_CRCT10DIF_ARM64_CE
) += crct10dif-ce.o
30 crct10dif-ce-y
:= crct10dif-ce-core.o crct10dif-ce-glue.o
32 obj-
$(CONFIG_CRYPTO_AES_ARM64_CE
) += aes-ce-cipher.o
33 aes-ce-cipher-y
:= aes-ce-core.o aes-ce-glue.o
35 obj-
$(CONFIG_CRYPTO_AES_ARM64_CE_CCM
) += aes-ce-ccm.o
36 aes-ce-ccm-y
:= aes-ce-ccm-glue.o aes-ce-ccm-core.o
38 obj-
$(CONFIG_CRYPTO_AES_ARM64_CE_BLK
) += aes-ce-blk.o
39 aes-ce-blk-y
:= aes-glue-ce.o aes-ce.o
41 obj-
$(CONFIG_CRYPTO_AES_ARM64_NEON_BLK
) += aes-neon-blk.o
42 aes-neon-blk-y
:= aes-glue-neon.o aes-neon.o
44 obj-
$(CONFIG_CRYPTO_SHA256_ARM64
) += sha256-arm64.o
45 sha256-arm64-y
:= sha256-glue.o sha256-core.o
47 obj-
$(CONFIG_CRYPTO_SHA512_ARM64
) += sha512-arm64.o
48 sha512-arm64-y
:= sha512-glue.o sha512-core.o
50 obj-
$(CONFIG_CRYPTO_CHACHA20_NEON
) += chacha-neon.o
51 chacha-neon-y
:= chacha-neon-core.o chacha-neon-glue.o
53 obj-
$(CONFIG_CRYPTO_POLY1305_NEON
) += poly1305-neon.o
54 poly1305-neon-y
:= poly1305-core.o poly1305-glue.o
55 AFLAGS_poly1305-core.o
+= -Dpoly1305_init
=poly1305_init_arm64
57 obj-
$(CONFIG_CRYPTO_NHPOLY1305_NEON
) += nhpoly1305-neon.o
58 nhpoly1305-neon-y
:= nh-neon-core.o nhpoly1305-neon-glue.o
60 obj-
$(CONFIG_CRYPTO_AES_ARM64
) += aes-arm64.o
61 aes-arm64-y
:= aes-cipher-core.o aes-cipher-glue.o
63 obj-
$(CONFIG_CRYPTO_AES_ARM64_BS
) += aes-neon-bs.o
64 aes-neon-bs-y
:= aes-neonbs-core.o aes-neonbs-glue.o
66 CFLAGS_aes-glue-ce.o
:= -DUSE_V8_CRYPTO_EXTENSIONS
68 $(obj
)/aes-glue-
%.o
: $(src
)/aes-glue.c FORCE
69 $(call if_changed_rule
,cc_o_c
)
71 ifdef REGENERATE_ARM64_CRYPTO
72 quiet_cmd_perlasm
= PERLASM
$@
73 cmd_perlasm
= $(PERL
) $(<) void
$(@
)
75 $(src
)/poly1305-core.S_shipped
: $(src
)/poly1305-armv8.pl
78 $(src
)/sha256-core.S_shipped
: $(src
)/sha512-armv8.pl
81 $(src
)/sha512-core.S_shipped
: $(src
)/sha512-armv8.pl
86 clean-files
+= poly1305-core.S sha256-core.S sha512-core.S