aboutsummaryrefslogtreecommitdiffstats
path: root/package/kernel/linux
diff options
context:
space:
mode:
authorDaniel Gimpelevich <daniel@gimpelevich.san-francisco.ca.us>2018-01-21 13:00:12 -0800
committerJohn Crispin <john@phrozen.org>2018-07-30 10:43:38 +0200
commitc762817c9211f439c5da6ea30b6ed828c9861c4f (patch)
treeb7200a08b4841df699f76eff18c3b39cba56cf37 /package/kernel/linux
parentaa5838adb7be733c427e63bb6cc702f9a533292d (diff)
downloadupstream-c762817c9211f439c5da6ea30b6ed828c9861c4f.tar.gz
upstream-c762817c9211f439c5da6ea30b6ed828c9861c4f.tar.bz2
upstream-c762817c9211f439c5da6ea30b6ed828c9861c4f.zip
kernel: package x86-optimized crypto-misc modules
Some of the modules in the crypto-misc package have alternate implementations optimized for different x86 instruction set extensions, but only one of these was built for this package until now: twofish-i586.ko Tested with insmod, on both x86 and x86_64. The modules now have an autoload, which they previous didn't, loading the dependencies in the correct order. Signed-off-by: Daniel Gimpelevich <daniel@gimpelevich.san-francisco.ca.us>
Diffstat (limited to 'package/kernel/linux')
-rw-r--r--package/kernel/linux/modules/crypto.mk52
1 files changed, 50 insertions, 2 deletions
diff --git a/package/kernel/linux/modules/crypto.mk b/package/kernel/linux/modules/crypto.mk
index 2ea2d2c0e7..235e6dadac 100644
--- a/package/kernel/linux/modules/crypto.mk
+++ b/package/kernel/linux/modules/crypto.mk
@@ -441,8 +441,21 @@ $(eval $(call KernelPackage,crypto-michael-mic))
define KernelPackage/crypto-misc
TITLE:=Other CryptoAPI modules
- DEPENDS:=+kmod-crypto-manager
+ DEPENDS:=+kmod-crypto-xts
KCONFIG:= \
+ CONFIG_CRYPTO_CAMELLIA_X86_64 \
+ CONFIG_CRYPTO_BLOWFISH_X86_64 \
+ CONFIG_CRYPTO_TWOFISH_X86_64 \
+ CONFIG_CRYPTO_TWOFISH_X86_64_3WAY \
+ CONFIG_CRYPTO_SERPENT_SSE2_X86_64 \
+ CONFIG_CRYPTO_CAMELLIA_AESNI_AVX_X86_64 \
+ CONFIG_CRYPTO_CAST5_AVX_X86_64 \
+ CONFIG_CRYPTO_CAST6_AVX_X86_64 \
+ CONFIG_CRYPTO_TWOFISH_AVX_X86_64 \
+ CONFIG_CRYPTO_SERPENT_AVX_X86_64 \
+ CONFIG_CRYPTO_CAMELLIA_AESNI_AVX2_X86_64 \
+ CONFIG_CRYPTO_SERPENT_AVX2_X86_64 \
+ CONFIG_CRYPTO_SERPENT_SSE2_586 \
CONFIG_CRYPTO_ANUBIS \
CONFIG_CRYPTO_BLOWFISH \
CONFIG_CRYPTO_CAMELLIA \
@@ -472,15 +485,50 @@ define KernelPackage/crypto-misc
$(LINUX_DIR)/crypto/blowfish_common.ko \
$(LINUX_DIR)/crypto/blowfish_generic.ko \
$(LINUX_DIR)/crypto/serpent_generic.ko
+ AUTOLOAD:=$(call AutoLoad,10,anubis camellia_generic cast_common \
+ cast5_generic cast6_generic khazad tea tgr192 twofish_common \
+ wp512 blowfish_common serpent_generic)
+ ifndef CONFIG_TARGET_x86
+ AUTOLOAD+= $(call AutoLoad,10,twofish_generic blowfish_generic)
+ endif
$(call AddDepends/crypto)
endef
ifndef CONFIG_TARGET_x86_64
define KernelPackage/crypto-misc/x86
- FILES+=$(LINUX_DIR)/arch/x86/crypto/twofish-i586.ko
+ FILES+= \
+ $(LINUX_DIR)/arch/x86/crypto/twofish-i586.ko \
+ $(LINUX_DIR)/arch/x86/crypto/serpent-sse2-i586.ko \
+ $(LINUX_DIR)/arch/x86/crypto/glue_helper.ko \
+ $(LINUX_DIR)/crypto/ablk_helper.ko \
+ $(LINUX_DIR)/crypto/cryptd.ko \
+ $(LINUX_DIR)/crypto/lrw.ko
+ AUTOLOAD+= $(call AutoLoad,10,lrw cryptd ablk_helper glue_helper \
+ serpent-sse2-i586 twofish-i586 blowfish_generic)
endef
endif
+define KernelPackage/crypto-misc/x86/64
+ FILES+= \
+ $(LINUX_DIR)/arch/x86/crypto/camellia-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/blowfish-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/twofish-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/twofish-x86_64-3way.ko \
+ $(LINUX_DIR)/arch/x86/crypto/serpent-sse2-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/camellia-aesni-avx-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/cast5-avx-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/cast6-avx-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/twofish-avx-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/serpent-avx-x86_64.ko \
+ $(LINUX_DIR)/arch/x86/crypto/camellia-aesni-avx2.ko \
+ $(LINUX_DIR)/arch/x86/crypto/serpent-avx2.ko \
+ $(LINUX_DIR)/crypto/ablk_helper.ko
+ AUTOLOAD+= $(call AutoLoad,10,ablk_helper camellia-x86_64 \
+ camellia-aesni-avx-x86_64 camellia-aesni-avx2 cast5-avx-x86_64 \
+ cast6-avx-x86_64 twofish-x86_64 twofish-x86_64-3way \
+ twofish-avx-x86_64 blowfish-x86_64 serpent-avx-x86_64 serpent-avx2)
+endef
+
$(eval $(call KernelPackage,crypto-misc))