1#
2# Arch-specific CryptoAPI modules.
3#
4
5obj-$(CONFIG_CRYPTO_AES_ARM) += aes-arm.o
6obj-$(CONFIG_CRYPTO_AES_ARM_BS) += aes-arm-bs.o
7obj-$(CONFIG_CRYPTO_SHA1_ARM) += sha1-arm.o
8obj-$(CONFIG_CRYPTO_SHA1_ARM_NEON) += sha1-arm-neon.o
9obj-$(CONFIG_CRYPTO_SHA256_ARM) += sha256-arm.o
10obj-$(CONFIG_CRYPTO_SHA512_ARM_NEON) += sha512-arm-neon.o
11
12ce-obj-$(CONFIG_CRYPTO_AES_ARM_CE) += aes-arm-ce.o
13ce-obj-$(CONFIG_CRYPTO_SHA1_ARM_CE) += sha1-arm-ce.o
14ce-obj-$(CONFIG_CRYPTO_SHA2_ARM_CE) += sha2-arm-ce.o
15ce-obj-$(CONFIG_CRYPTO_GHASH_ARM_CE) += ghash-arm-ce.o
16
17ifneq ($(ce-obj-y)$(ce-obj-m),)
18ifeq ($(call as-instr,.fpu crypto-neon-fp-armv8,y,n),y)
19obj-y += $(ce-obj-y)
20obj-m += $(ce-obj-m)
21else
22$(warning These ARMv8 Crypto Extensions modules need binutils 2.23 or higher)
23$(warning $(ce-obj-y) $(ce-obj-m))
24endif
25endif
26
27aes-arm-y	:= aes-armv4.o aes_glue.o
28aes-arm-bs-y	:= aesbs-core.o aesbs-glue.o
29sha1-arm-y	:= sha1-armv4-large.o sha1_glue.o
30sha1-arm-neon-y	:= sha1-armv7-neon.o sha1_neon_glue.o
31sha256-arm-neon-$(CONFIG_KERNEL_MODE_NEON) := sha256_neon_glue.o
32sha256-arm-y	:= sha256-core.o sha256_glue.o $(sha256-arm-neon-y)
33sha512-arm-neon-y := sha512-armv7-neon.o sha512_neon_glue.o
34sha1-arm-ce-y	:= sha1-ce-core.o sha1-ce-glue.o
35sha2-arm-ce-y	:= sha2-ce-core.o sha2-ce-glue.o
36aes-arm-ce-y	:= aes-ce-core.o aes-ce-glue.o
37ghash-arm-ce-y	:= ghash-ce-core.o ghash-ce-glue.o
38
39quiet_cmd_perl = PERL    $@
40      cmd_perl = $(PERL) $(<) > $(@)
41
42$(src)/aesbs-core.S_shipped: $(src)/bsaes-armv7.pl
43	$(call cmd,perl)
44
45$(src)/sha256-core.S_shipped: $(src)/sha256-armv4.pl
46	$(call cmd,perl)
47
48.PRECIOUS: $(obj)/aesbs-core.S $(obj)/sha256-core.S
49