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