2 # Copyright (C) 2006-2011 OpenWrt.org
4 # This is free software, licensed under the GNU General Public License v2.
5 # See /LICENSE for more information.
8 CRYPTO_MENU
:=Cryptographic API modules
11 ALGAPI2
=crypto_algapi \
12 BLKCIPHER2
=crypto_blkcipher
14 CRYPTO_TARGET
= $(BOARD
)/$(if
$(SUBTARGET
),$(SUBTARGET
),generic
)
16 crypto_confvar
=CONFIG_CRYPTO_
$(word 1,$(subst =,$(space
),$(1)))
17 crypto_file
=$(LINUX_DIR
)/crypto
/$(word 2,$(subst =,$(space
),$(1))).ko
18 crypto_name
=$(if
$(findstring y
,$($(call crypto_confvar
,$(1)))),,$(word 2,$(subst =,$(space
),$(1))))
20 define AddDepends
/crypto
21 SUBMENU
:=$(CRYPTO_MENU
)
26 define KernelPackage
/crypto-acompress
27 TITLE
:=Asynchronous Compression operations
29 KCONFIG
:=CONFIG_CRYPTO_ACOMP2
30 FILES
:=$(LINUX_DIR
)/crypto
/crypto_acompress.ko
31 AUTOLOAD
:=$(call AutoLoad
,09,crypto_acompress
)
32 $(call AddDepends
/crypto
)
35 $(eval
$(call KernelPackage
,crypto-acompress
))
38 define KernelPackage
/crypto-aead
39 TITLE
:=CryptoAPI AEAD support
44 $(LINUX_DIR
)/crypto
/aead.ko \
45 $(LINUX_DIR
)/crypto
/geniv.ko
46 AUTOLOAD
:=$(call AutoLoad
,09,aead
,1)
47 $(call AddDepends
/crypto
, +kmod-crypto-null
)
50 $(eval
$(call KernelPackage
,crypto-aead
))
53 define KernelPackage
/crypto-arc4
54 TITLE
:=ARC4 cipher CryptoAPI module
55 DEPENDS
:=+kmod-crypto-user
58 CONFIG_CRYPTO_USER_API_ENABLE_OBSOLETE
=y
60 $(LINUX_DIR
)/crypto
/arc4.ko \
61 $(LINUX_DIR
)/lib
/crypto
/libarc4.ko
62 AUTOLOAD
:=$(call AutoLoad
,09,arc4
)
63 $(call AddDepends
/crypto
)
66 $(eval
$(call KernelPackage
,crypto-arc4
))
69 define KernelPackage
/crypto-authenc
70 TITLE
:=Combined mode wrapper for IPsec
71 DEPENDS
:=+kmod-crypto-manager
+kmod-crypto-null
72 KCONFIG
:=CONFIG_CRYPTO_AUTHENC
74 $(LINUX_DIR
)/crypto
/authenc.ko \
75 $(LINUX_DIR
)/crypto
/authencesn.ko
76 AUTOLOAD
:=$(call AutoLoad
,09,authenc authencesn
)
77 $(call AddDepends
/crypto
)
80 $(eval
$(call KernelPackage
,crypto-authenc
))
83 define KernelPackage
/crypto-cbc
84 TITLE
:=Cipher Block Chaining CryptoAPI module
85 DEPENDS
:=+kmod-crypto-manager
86 KCONFIG
:=CONFIG_CRYPTO_CBC
87 FILES
:=$(LINUX_DIR
)/crypto
/cbc.ko
88 AUTOLOAD
:=$(call AutoLoad
,09,cbc
)
89 $(call AddDepends
/crypto
)
92 $(eval
$(call KernelPackage
,crypto-cbc
))
95 define KernelPackage
/crypto-ccm
96 TITLE
:=Support for Counter with CBC MAC
(CCM
)
97 DEPENDS
:=+kmod-crypto-ctr
+kmod-crypto-aead
98 KCONFIG
:=CONFIG_CRYPTO_CCM
99 FILES
:=$(LINUX_DIR
)/crypto
/ccm.ko
100 AUTOLOAD
:=$(call AutoLoad
,09,ccm
)
101 $(call AddDepends
/crypto
)
104 $(eval
$(call KernelPackage
,crypto-ccm
))
107 define KernelPackage
/crypto-chacha20poly1305
108 TITLE
:=ChaCha20-Poly1305 AEAD support
, RFC7539
(used by strongSwan IPsec VPN
)
109 DEPENDS
:=+kmod-crypto-aead
+kmod-crypto-manager
110 KCONFIG
:=CONFIG_CRYPTO_CHACHA20POLY1305
111 FILES
:=$(LINUX_DIR
)/crypto
/chacha20poly1305.ko
112 AUTOLOAD
:=$(call AutoLoad
,09,chacha20poly1305
)
113 $(call AddDepends
/crypto
)
116 $(eval
$(call KernelPackage
,crypto-chacha20poly1305
))
119 define KernelPackage
/crypto-cmac
120 TITLE
:=Support for Cipher-based Message Authentication Code
(CMAC
)
121 DEPENDS
:=+kmod-crypto-hash
122 KCONFIG
:=CONFIG_CRYPTO_CMAC
123 FILES
:=$(LINUX_DIR
)/crypto
/cmac.ko
124 AUTOLOAD
:=$(call AutoLoad
,09,cmac
)
125 $(call AddDepends
/crypto
)
128 $(eval
$(call KernelPackage
,crypto-cmac
))
131 define KernelPackage
/crypto-crc32
132 TITLE
:=CRC32 CRC module
133 DEPENDS
:=+kmod-crypto-hash
134 KCONFIG
:=CONFIG_CRYPTO_CRC32
136 FILES
:=$(LINUX_DIR
)/crypto
/crc32_generic.ko
137 AUTOLOAD
:=$(call AutoLoad
,04,crc32_generic
,1)
138 $(call AddDepends
/crypto
)
141 $(eval
$(call KernelPackage
,crypto-crc32
))
144 define KernelPackage
/crypto-crc32c
145 TITLE
:=CRC32c CRC module
146 DEPENDS
:=+kmod-crypto-hash
147 KCONFIG
:=CONFIG_CRYPTO_CRC32C
148 FILES
:=$(LINUX_DIR
)/crypto
/crc32c_generic.ko
149 AUTOLOAD
:=$(call AutoLoad
,04,crc32c_generic
,1)
150 $(call AddDepends
/crypto
)
153 $(eval
$(call KernelPackage
,crypto-crc32c
))
156 define KernelPackage
/crypto-ctr
157 TITLE
:=Counter Mode CryptoAPI module
158 DEPENDS
:=+kmod-crypto-manager
+kmod-crypto-seqiv
159 KCONFIG
:=CONFIG_CRYPTO_CTR
160 FILES
:=$(LINUX_DIR
)/crypto
/ctr.ko
161 AUTOLOAD
:=$(call AutoLoad
,09,ctr
)
162 $(call AddDepends
/crypto
)
165 $(eval
$(call KernelPackage
,crypto-ctr
))
168 define KernelPackage
/crypto-cts
169 TITLE
:=Cipher Text Stealing CryptoAPI module
170 DEPENDS
:=+kmod-crypto-manager
171 KCONFIG
:=CONFIG_CRYPTO_CTS
172 FILES
:=$(LINUX_DIR
)/crypto
/cts.ko
173 AUTOLOAD
:=$(call AutoLoad
,09,cts
)
174 $(call AddDepends
/crypto
)
177 $(eval
$(call KernelPackage
,crypto-cts
))
180 define KernelPackage
/crypto-deflate
181 TITLE
:=Deflate compression CryptoAPI module
182 DEPENDS
:=+kmod-lib-zlib-inflate
+kmod-lib-zlib-deflate
+kmod-crypto-acompress
183 KCONFIG
:=CONFIG_CRYPTO_DEFLATE
184 FILES
:=$(LINUX_DIR
)/crypto
/deflate.ko
185 AUTOLOAD
:=$(call AutoLoad
,09,deflate
)
186 $(call AddDepends
/crypto
)
189 $(eval
$(call KernelPackage
,crypto-deflate
))
192 define KernelPackage
/crypto-des
193 TITLE
:=DES
/3DES cipher CryptoAPI module
194 KCONFIG
:=CONFIG_CRYPTO_DES
196 $(LINUX_DIR
)/crypto
/des_generic.ko \
197 $(LINUX_DIR
)/lib
/crypto
/libdes.ko
198 AUTOLOAD
:=$(call AutoLoad
,09,des_generic
)
199 $(call AddDepends
/crypto
)
202 $(eval
$(call KernelPackage
,crypto-des
))
205 define KernelPackage
/crypto-ecb
206 TITLE
:=Electronic CodeBook CryptoAPI module
207 DEPENDS
:=+kmod-crypto-manager
208 KCONFIG
:=CONFIG_CRYPTO_ECB
209 FILES
:=$(LINUX_DIR
)/crypto
/ecb.ko
210 AUTOLOAD
:=$(call AutoLoad
,09,ecb
)
211 $(call AddDepends
/crypto
)
214 $(eval
$(call KernelPackage
,crypto-ecb
))
217 define KernelPackage
/crypto-ecdh
218 TITLE
:=ECDH algorithm
219 DEPENDS
:=+kmod-crypto-kpp
220 KCONFIG
:= CONFIG_CRYPTO_ECDH
222 $(LINUX_DIR
)/crypto
/ecdh_generic.ko \
223 $(LINUX_DIR
)/crypto
/ecc.ko
224 AUTOLOAD
:=$(call AutoLoad
,10,ecdh_generic
)
225 $(call AddDepends
/crypto
)
228 $(eval
$(call KernelPackage
,crypto-ecdh
))
231 define KernelPackage
/crypto-echainiv
232 TITLE
:=Encrypted Chain IV Generator
233 DEPENDS
:=+kmod-crypto-aead
234 KCONFIG
:=CONFIG_CRYPTO_ECHAINIV
235 FILES
:=$(LINUX_DIR
)/crypto
/echainiv.ko
236 AUTOLOAD
:=$(call AutoLoad
,09,echainiv
)
237 $(call AddDepends
/crypto
)
240 $(eval
$(call KernelPackage
,crypto-echainiv
))
243 define KernelPackage
/crypto-essiv
244 TITLE
:=ESSIV support for block encryption
245 DEPENDS
:=+kmod-crypto-authenc
246 KCONFIG
:=CONFIG_CRYPTO_ESSIV
247 FILES
:= $(LINUX_DIR
)/crypto
/essiv.ko
248 AUTOLOAD
:=$(call AutoLoad
,10,essiv
)
249 $(call AddDepends
/crypto
)
252 $(eval
$(call KernelPackage
,crypto-essiv
))
255 define KernelPackage
/crypto-fcrypt
256 TITLE
:=FCRYPT cipher CryptoAPI module
257 KCONFIG
:=CONFIG_CRYPTO_FCRYPT
258 FILES
:=$(LINUX_DIR
)/crypto
/fcrypt.ko
259 AUTOLOAD
:=$(call AutoLoad
,09,fcrypt
)
260 $(call AddDepends
/crypto
)
263 $(eval
$(call KernelPackage
,crypto-fcrypt
))
266 define KernelPackage
/crypto-gcm
267 TITLE
:=GCM
/GMAC CryptoAPI module
268 DEPENDS
:=+kmod-crypto-ctr
+kmod-crypto-ghash
+kmod-crypto-null
269 KCONFIG
:=CONFIG_CRYPTO_GCM
270 FILES
:=$(LINUX_DIR
)/crypto
/gcm.ko
271 AUTOLOAD
:=$(call AutoLoad
,09,gcm
)
272 $(call AddDepends
/crypto
)
275 $(eval
$(call KernelPackage
,crypto-gcm
))
278 define KernelPackage
/crypto-xcbc
279 TITLE
:=XCBC CryptoAPI module
280 DEPENDS
:=+kmod-crypto-hash
+kmod-crypto-manager
281 KCONFIG
:=CONFIG_CRYPTO_XCBC
282 FILES
:=$(LINUX_DIR
)/crypto
/xcbc.ko
283 AUTOLOAD
:=$(call AutoLoad
,09,xcbc
)
284 $(call AddDepends
/crypto
)
287 $(eval
$(call KernelPackage
,crypto-xcbc
))
290 define KernelPackage
/crypto-gf128
291 TITLE
:=GF
(2^
128) multiplication functions CryptoAPI module
292 KCONFIG
:=CONFIG_CRYPTO_GF128MUL
293 FILES
:=$(LINUX_DIR
)/crypto
/gf128mul.ko
294 AUTOLOAD
:=$(call AutoLoad
,09,gf128mul
)
295 $(call AddDepends
/crypto
)
298 $(eval
$(call KernelPackage
,crypto-gf128
))
301 define KernelPackage
/crypto-ghash
302 TITLE
:=GHASH digest CryptoAPI module
303 DEPENDS
:=+kmod-crypto-gf128
+kmod-crypto-hash
305 CONFIG_CRYPTO_GHASH \
306 CONFIG_CRYPTO_GHASH_ARM_CE
307 FILES
:=$(LINUX_DIR
)/crypto
/ghash-generic.ko
308 AUTOLOAD
:=$(call AutoLoad
,09,ghash-generic
)
309 $(call AddDepends
/crypto
)
312 define KernelPackage
/crypto-ghash
/arm-ce
313 FILES
+= $(LINUX_DIR
)/arch
/arm
/crypto
/ghash-arm-ce.ko
314 AUTOLOAD
+=$(call AutoLoad
,09,ghash-arm-ce
)
317 KernelPackage
/crypto-ghash
/imx
=$(KernelPackage
/crypto-ghash
/arm-ce
)
318 KernelPackage
/crypto-ghash
/ipq40xx
=$(KernelPackage
/crypto-ghash
/arm-ce
)
319 KernelPackage
/crypto-ghash
/mvebu
/cortexa9
=$(KernelPackage
/crypto-ghash
/arm-ce
)
321 $(eval
$(call KernelPackage
,crypto-ghash
))
324 define KernelPackage
/crypto-hash
325 TITLE
:=CryptoAPI hash support
326 KCONFIG
:=CONFIG_CRYPTO_HASH
327 FILES
:=$(LINUX_DIR
)/crypto
/crypto_hash.ko
328 AUTOLOAD
:=$(call AutoLoad
,02,crypto_hash
,1)
329 $(call AddDepends
/crypto
)
332 $(eval
$(call KernelPackage
,crypto-hash
))
335 define KernelPackage
/crypto-hmac
336 TITLE
:=HMAC digest CryptoAPI module
337 DEPENDS
:=+kmod-crypto-hash
+kmod-crypto-manager
338 KCONFIG
:=CONFIG_CRYPTO_HMAC
339 FILES
:=$(LINUX_DIR
)/crypto
/hmac.ko
340 AUTOLOAD
:=$(call AutoLoad
,09,hmac
)
341 $(call AddDepends
/crypto
)
344 $(eval
$(call KernelPackage
,crypto-hmac
))
347 define KernelPackage
/crypto-hw-ccp
348 TITLE
:=AMD Cryptographic Coprocessor
351 +kmod-crypto-authenc \
353 +kmod-crypto-manager \
356 +kmod-crypto-sha256 \
360 CONFIG_CRYPTO_DEV_CCP
=y \
361 CONFIG_CRYPTO_DEV_CCP_CRYPTO \
362 CONFIG_CRYPTO_DEV_CCP_DD \
363 CONFIG_CRYPTO_DEV_SP_CCP
=y
365 $(LINUX_DIR
)/drivers
/crypto
/ccp
/ccp.ko \
366 $(LINUX_DIR
)/drivers
/crypto
/ccp
/ccp-crypto.ko
367 AUTOLOAD
:=$(call AutoLoad
,09,ccp ccp-crypto
)
368 $(call AddDepends
/crypto
)
371 $(eval
$(call KernelPackage
,crypto-hw-ccp
))
374 define KernelPackage
/crypto-hw-geode
375 TITLE
:=AMD Geode hardware crypto module
376 DEPENDS
:=@TARGET_x86_geode
+kmod-crypto-manager
379 CONFIG_CRYPTO_DEV_GEODE
380 FILES
:=$(LINUX_DIR
)/drivers
/crypto
/geode-aes.ko
381 AUTOLOAD
:=$(call AutoLoad
,09,geode-aes
)
382 $(call AddDepends
/crypto
)
385 $(eval
$(call KernelPackage
,crypto-hw-geode
))
388 define KernelPackage
/crypto-hw-hifn-795x
389 TITLE
:=HIFN
795x crypto accelerator
390 DEPENDS
:=@PCI_SUPPORT
+kmod-random-core
+kmod-crypto-manager
393 CONFIG_CRYPTO_DEV_HIFN_795X \
394 CONFIG_CRYPTO_DEV_HIFN_795X_RNG
=y
395 FILES
:=$(LINUX_DIR
)/drivers
/crypto
/hifn_795x.ko
396 AUTOLOAD
:=$(call AutoLoad
,09,hifn_795x
)
397 $(call AddDepends
/crypto
,+kmod-crypto-des
)
400 $(eval
$(call KernelPackage
,crypto-hw-hifn-795x
))
402 define KernelPackage
/crypto-hw-ixp4xx
403 TITLE
:=Intel IXP4xx crypto accelerator
404 DEPENDS
:=@TARGET_ixp4xx
+kmod-random-core
+kmod-crypto-manager
+kmod-crypto-authenc
+kmod-crypto-des
407 CONFIG_CRYPTO_DEV_IXP4XX
408 FILES
:=$(LINUX_DIR
)/drivers
/crypto
/ixp4xx_crypto.ko
409 AUTOLOAD
:=$(call AutoProbe
,ixp4xx_crypto
)
410 $(call AddDepends
/crypto
)
413 $(eval
$(call KernelPackage
,crypto-hw-ixp4xx
))
416 define KernelPackage
/crypto-hw-padlock
417 TITLE
:=VIA PadLock ACE with AES
/SHA hw crypto module
418 DEPENDS
:=+kmod-crypto-manager
421 CONFIG_CRYPTO_DEV_PADLOCK \
422 CONFIG_CRYPTO_DEV_PADLOCK_AES \
423 CONFIG_CRYPTO_DEV_PADLOCK_SHA
425 $(LINUX_DIR
)/drivers
/crypto
/padlock-aes.ko \
426 $(LINUX_DIR
)/drivers
/crypto
/padlock-sha.ko
427 AUTOLOAD
:=$(call AutoLoad
,09,padlock-aes padlock-sha
)
428 $(call AddDepends
/crypto
)
431 $(eval
$(call KernelPackage
,crypto-hw-padlock
))
434 define KernelPackage
/crypto-hw-safexcel
435 TITLE
:= MVEBU SafeXcel Crypto Engine module
436 DEPENDS
:=@
(TARGET_mvebu_cortexa53||TARGET_mvebu_cortexa72||TARGET_mediatek_filogic||TARGET_mediatek_mt7623
) \
437 +eip197-mini-firmware
+kmod-crypto-authenc
+kmod-crypto-des
+kmod-crypto-md5
+kmod-crypto-hmac \
438 +kmod-crypto-sha1
+kmod-crypto-sha256
+kmod-crypto-sha512
441 CONFIG_CRYPTO_DEV_SAFEXCEL
442 FILES
:=$(LINUX_DIR
)/drivers
/crypto
/inside-secure
/crypto_safexcel.ko
443 AUTOLOAD
:=$(call AutoLoad
,90,crypto_safexcel
)
444 $(call AddDepends
/crypto
)
447 define KernelPackage
/crypto-hw-safexcel
/description
448 MVEBU
's EIP97 and EIP197 Cryptographic Engine driver designed by
449 Inside Secure. This is found on Marvell Armada 37xx/7k/8k SoCs.
451 Particular version of these IP (EIP197B and EIP197D) require firmware.
452 The mini firmware package provides limited functionality, for most operations
453 a full-featured firmware is required. Unfortunately the "full" firmware is not
454 freely available and needs signed Non-Disclosure Agreement (NDA) with Marvell.
455 For those who have signed NDA the firmware can be obtained at
456 https://extranet.marvell.com.
459 $(eval $(call KernelPackage,crypto-hw-safexcel))
462 define KernelPackage/crypto-hw-talitos
463 TITLE:=Freescale integrated security engine (SEC) driver
464 DEPENDS:=@(TARGET_mpc85xx||TARGET_layerscape) +kmod-crypto-manager \
465 +kmod-crypto-hash +kmod-random-core +kmod-crypto-authenc +kmod-crypto-des
468 CONFIG_CRYPTO_DEV_TALITOS \
469 CONFIG_CRYPTO_DEV_TALITOS1=y \
470 CONFIG_CRYPTO_DEV_TALITOS2=y
472 $(LINUX_DIR)/drivers/crypto/talitos.ko
473 AUTOLOAD:=$(call AutoLoad,09,talitos)
474 $(call AddDepends/crypto)
477 $(eval $(call KernelPackage,crypto-hw-talitos))
479 define KernelPackage/crypto-hw-eip93
480 TITLE:=MTK EIP93 crypto module
481 DEPENDS:=@TARGET_ramips_mt7621 \
482 +kmod-crypto-authenc \
489 CONFIG_CRYPTO_DEV_EIP93 \
490 CONFIG_CRYPTO_DEV_EIP93_AES=y \
491 CONFIG_CRYPTO_DEV_EIP93_DES=y \
492 CONFIG_CRYPTO_DEV_EIP93_AEAD=y \
493 CONFIG_CRYPTO_DEV_EIP93_GENERIC_SW_MAX_LEN=256 \
494 CONFIG_CRYPTO_DEV_EIP93_AES_128_SW_MAX_LEN=512
495 FILES:=$(LINUX_DIR)/drivers/crypto/mtk-eip93/crypto-hw-eip93.ko
496 AUTOLOAD:=$(call AutoLoad,09,crypto-hw-eip93)
497 $(call AddDepends/crypto)
500 define KernelPackage/crypto-hw-eip93/description
501 Kernel module to enable EIP-93 Crypto engine as found
502 in the Mediatek MT7621 SoC.
503 It enables DES/3DES/AES ECB/CBC/CTR and
504 IPSEC offload with authenc(hmac(sha1/sha256), aes/cbc/rfc3686)
507 $(eval $(call KernelPackage,crypto-hw-eip93))
509 define KernelPackage/crypto-kpp
510 TITLE:=Key-agreement Protocol Primitives
511 KCONFIG:=CONFIG_CRYPTO_KPP
512 FILES:=$(LINUX_DIR)/crypto/kpp.ko
513 AUTOLOAD:=$(call AutoLoad,09,kpp)
514 $(call AddDepends/crypto)
517 $(eval $(call KernelPackage,crypto-kpp))
519 define KernelPackage/crypto-lib-chacha20
520 TITLE:=ChaCha library interface
521 KCONFIG:=CONFIG_CRYPTO_LIB_CHACHA
523 FILES:=$(LINUX_DIR)/lib/crypto/libchacha.ko
524 $(call AddDepends/crypto)
527 define KernelPackage/crypto-lib-chacha20/x86_64
528 KCONFIG+=CONFIG_CRYPTO_CHACHA20_X86_64
529 FILES+=$(LINUX_DIR)/arch/x86/crypto/chacha-x86_64.ko
532 # Note that a non-neon fallback implementation is available on arm32 when
533 # NEON is not supported, hence all arm targets can utilize lib-chacha20/arm
534 define KernelPackage/crypto-lib-chacha20/arm
535 KCONFIG+=CONFIG_CRYPTO_CHACHA20_NEON
536 FILES:=$(LINUX_DIR)/arch/arm/crypto/chacha-neon.ko
539 KernelPackage/crypto-lib-chacha20/armeb=$(KernelPackage/crypto-lib-chacha20/arm)
541 define KernelPackage/crypto-lib-chacha20/aarch64
542 KCONFIG+=CONFIG_CRYPTO_CHACHA20_NEON
543 FILES+=$(LINUX_DIR)/arch/arm64/crypto/chacha-neon.ko
546 define KernelPackage/crypto-lib-chacha20/mips32r2
547 KCONFIG+=CONFIG_CRYPTO_CHACHA_MIPS
548 FILES:=$(LINUX_DIR)/arch/mips/crypto/chacha-mips.ko
551 ifeq ($(CONFIG_CPU_MIPS32_R2),y)
552 KernelPackage/crypto-lib-chacha20/$(ARCH)=\
553 $(KernelPackage/crypto-lib-chacha20/mips32r2)
556 ifdef KernelPackage/crypto-lib-chacha20/$(ARCH)
557 KernelPackage/crypto-lib-chacha20/$(CRYPTO_TARGET)=\
558 $(KernelPackage/crypto-lib-chacha20/$(ARCH))
561 $(eval $(call KernelPackage,crypto-lib-chacha20))
564 define KernelPackage/crypto-lib-chacha20poly1305
565 TITLE:=ChaCha20-Poly1305 AEAD support (8-byte nonce library version)
566 KCONFIG:=CONFIG_CRYPTO_LIB_CHACHA20POLY1305
568 FILES:=$(LINUX_DIR)/lib/crypto/libchacha20poly1305.ko
569 $(call AddDepends/crypto, +kmod-crypto-lib-chacha20 +kmod-crypto-lib-poly1305)
572 $(eval $(call KernelPackage,crypto-lib-chacha20poly1305))
575 define KernelPackage/crypto-lib-curve25519
576 TITLE:=Curve25519 scalar multiplication library
577 KCONFIG:=CONFIG_CRYPTO_LIB_CURVE25519
580 $(LINUX_DIR)/lib/crypto/libcurve25519.ko \
581 $(LINUX_DIR)/lib/crypto/libcurve25519-generic.ko
582 $(call AddDepends/crypto,+PACKAGE_kmod-crypto-kpp:kmod-crypto-kpp)
585 define KernelPackage/crypto-lib-curve25519/config
586 imply PACKAGE_kmod-crypto-kpp
589 define KernelPackage/crypto-lib-curve25519/x86_64
590 KCONFIG+=CONFIG_CRYPTO_CURVE25519_X86
591 FILES+=$(LINUX_DIR)/arch/x86/crypto/curve25519-x86_64.ko
594 define KernelPackage/crypto-lib-curve25519/arm-neon
595 KCONFIG+=CONFIG_CRYPTO_CURVE25519_NEON
596 FILES+=$(LINUX_DIR)/arch/arm/crypto/curve25519-neon.ko
599 ifeq ($(ARCH)-$(CONFIG_KERNEL_MODE_NEON),arm-y)
600 KernelPackage/crypto-lib-curve25519/$(CRYPTO_TARGET)=\
601 $(KernelPackage/crypto-lib-curve25519/arm-neon)
604 ifdef KernelPackage/crypto-lib-curve25519/$(ARCH)
605 KernelPackage/crypto-lib-curve25519/$(CRYPTO_TARGET)=\
606 $(KernelPackage/crypto-lib-curve25519/$(ARCH))
609 $(eval $(call KernelPackage,crypto-lib-curve25519))
612 define KernelPackage/crypto-lib-poly1305
613 TITLE:=Poly1305 library interface
614 KCONFIG:=CONFIG_CRYPTO_LIB_POLY1305
616 FILES:=$(LINUX_DIR)/lib/crypto/libpoly1305.ko
617 $(call AddDepends/crypto,+PACKAGE_kmod-crypto-hash:kmod-crypto-hash)
620 define KernelPackage/crypto-lib-poly1305/config
621 imply PACKAGE_kmod-crypto-hash
624 define KernelPackage/crypto-lib-poly1305/x86_64
625 KCONFIG+=CONFIG_CRYPTO_POLY1305_X86_64
626 FILES+=$(LINUX_DIR)/arch/x86/crypto/poly1305-x86_64.ko
629 define KernelPackage/crypto-lib-poly1305/arm
630 KCONFIG+=CONFIG_CRYPTO_POLY1305_ARM
631 FILES:=$(LINUX_DIR)/arch/arm/crypto/poly1305-arm.ko
634 KernelPackage/crypto-lib-poly1305/armeb=$(KernelPackage/crypto-lib-poly1305/arm)
636 define KernelPackage/crypto-lib-poly1305/aarch64
637 KCONFIG+=CONFIG_CRYPTO_POLY1305_NEON
638 FILES:=$(LINUX_DIR)/arch/arm64/crypto/poly1305-neon.ko
641 define KernelPackage/crypto-lib-poly1305/mips
642 KCONFIG+=CONFIG_CRYPTO_POLY1305_MIPS
643 FILES:=$(LINUX_DIR)/arch/mips/crypto/poly1305-mips.ko
646 KernelPackage/crypto-lib-poly1305/mipsel=$(KernelPackage/crypto-lib-poly1305/mips)
647 KernelPackage/crypto-lib-poly1305/mips64=$(KernelPackage/crypto-lib-poly1305/mips)
648 KernelPackage/crypto-lib-poly1305/mips64el=$(KernelPackage/crypto-lib-poly1305/mips)
650 ifdef KernelPackage/crypto-lib-poly1305/$(ARCH)
651 KernelPackage/crypto-lib-poly1305/$(CRYPTO_TARGET)=\
652 $(KernelPackage/crypto-lib-poly1305/$(ARCH))
655 $(eval $(call KernelPackage,crypto-lib-poly1305))
658 define KernelPackage/crypto-manager
659 TITLE:=CryptoAPI algorithm manager
660 DEPENDS:=+kmod-crypto-aead +kmod-crypto-hash
662 CONFIG_CRYPTO_MANAGER \
663 CONFIG_CRYPTO_MANAGER2
664 FILES:=$(LINUX_DIR)/crypto/cryptomgr.ko
665 AUTOLOAD:=$(call AutoLoad,09,cryptomgr,1)
666 $(call AddDepends/crypto)
669 $(eval $(call KernelPackage,crypto-manager))
672 define KernelPackage/crypto-md4
673 TITLE:=MD4 digest CryptoAPI module
674 DEPENDS:=+kmod-crypto-hash
675 KCONFIG:=CONFIG_CRYPTO_MD4
676 FILES:=$(LINUX_DIR)/crypto/md4.ko
677 AUTOLOAD:=$(call AutoLoad,09,md4)
678 $(call AddDepends/crypto)
681 $(eval $(call KernelPackage,crypto-md4))
684 define KernelPackage/crypto-md5
685 TITLE:=MD5 digest CryptoAPI module
686 DEPENDS:=+kmod-crypto-hash
689 CONFIG_CRYPTO_MD5_OCTEON \
690 CONFIG_CRYPTO_MD5_PPC
691 FILES:=$(LINUX_DIR)/crypto/md5.ko
692 AUTOLOAD:=$(call AutoLoad,09,md5)
693 $(call AddDepends/crypto)
696 define KernelPackage/crypto-md5/octeon
697 FILES+=$(LINUX_DIR)/arch/mips/cavium-octeon/crypto/octeon-md5.ko
698 AUTOLOAD+=$(call AutoLoad,09,octeon-md5)
701 define KernelPackage/crypto-md5/powerpc
702 FILES+=$(LINUX_DIR)/arch/powerpc/crypto/md5-ppc.ko
703 AUTOLOAD+=$(call AutoLoad,09,md5-ppc)
706 ifdef KernelPackage/crypto-md5/$(ARCH)
707 KernelPackage/crypto-md5/$(CRYPTO_TARGET)=\
708 $(KernelPackage/crypto-md5/$(ARCH))
711 $(eval $(call KernelPackage,crypto-md5))
714 define KernelPackage/crypto-michael-mic
715 TITLE:=Michael MIC keyed digest CryptoAPI module
716 DEPENDS:=+kmod-crypto-hash
717 KCONFIG:=CONFIG_CRYPTO_MICHAEL_MIC
718 FILES:=$(LINUX_DIR)/crypto/michael_mic.ko
719 AUTOLOAD:=$(call AutoLoad,09,michael_mic)
720 $(call AddDepends/crypto)
723 $(eval $(call KernelPackage,crypto-michael-mic))
726 define KernelPackage/crypto-misc
727 TITLE:=Other CryptoAPI modules
728 DEPENDS:=+kmod-crypto-xts +kmod-crypto-user
730 CONFIG_CRYPTO_USER_API_ENABLE_OBSOLETE=y \
731 CONFIG_CRYPTO_CAMELLIA_X86_64 \
732 CONFIG_CRYPTO_BLOWFISH_X86_64 \
733 CONFIG_CRYPTO_TWOFISH_X86_64 \
734 CONFIG_CRYPTO_TWOFISH_X86_64_3WAY \
735 CONFIG_CRYPTO_SERPENT_SSE2_X86_64 \
736 CONFIG_CRYPTO_CAMELLIA_AESNI_AVX_X86_64 \
737 CONFIG_CRYPTO_CAST5_AVX_X86_64 \
738 CONFIG_CRYPTO_CAST6_AVX_X86_64 \
739 CONFIG_CRYPTO_TWOFISH_AVX_X86_64 \
740 CONFIG_CRYPTO_SERPENT_AVX_X86_64 \
741 CONFIG_CRYPTO_CAMELLIA_AESNI_AVX2_X86_64 \
742 CONFIG_CRYPTO_SERPENT_AVX2_X86_64 \
743 CONFIG_CRYPTO_SERPENT_SSE2_586 \
744 CONFIG_CRYPTO_ANUBIS \
745 CONFIG_CRYPTO_BLOWFISH \
746 CONFIG_CRYPTO_CAMELLIA \
747 CONFIG_CRYPTO_CAST5 \
748 CONFIG_CRYPTO_CAST6 \
749 CONFIG_CRYPTO_FCRYPT \
750 CONFIG_CRYPTO_KHAZAD \
751 CONFIG_CRYPTO_SERPENT \
753 CONFIG_CRYPTO_TWOFISH \
754 CONFIG_CRYPTO_TWOFISH_COMMON \
755 CONFIG_CRYPTO_TWOFISH_586 \
758 $(LINUX_DIR)/crypto/anubis.ko \
759 $(LINUX_DIR)/crypto/camellia_generic.ko \
760 $(LINUX_DIR)/crypto/cast_common.ko \
761 $(LINUX_DIR)/crypto/cast5_generic.ko \
762 $(LINUX_DIR)/crypto/cast6_generic.ko \
763 $(LINUX_DIR)/crypto/khazad.ko \
764 $(LINUX_DIR)/crypto/tea.ko \
765 $(LINUX_DIR)/crypto/twofish_common.ko \
766 $(LINUX_DIR)/crypto/wp512.ko \
767 $(LINUX_DIR)/crypto/twofish_generic.ko \
768 $(LINUX_DIR)/crypto/blowfish_common.ko \
769 $(LINUX_DIR)/crypto/blowfish_generic.ko \
770 $(LINUX_DIR)/crypto/serpent_generic.ko
771 AUTOLOAD:=$(call AutoLoad,10,anubis camellia_generic cast_common \
772 cast5_generic cast6_generic khazad tea twofish_common \
773 wp512 blowfish_common serpent_generic)
774 ifndef CONFIG_TARGET_x86
775 AUTOLOAD+= $(call AutoLoad,10,twofish_generic blowfish_generic)
777 $(call AddDepends/crypto)
780 ifndef CONFIG_TARGET_x86_64
781 define KernelPackage/crypto-misc/x86
783 $(LINUX_DIR)/arch/x86/crypto/twofish-i586.ko \
784 $(LINUX_DIR)/arch/x86/crypto/serpent-sse2-i586.ko \
785 $(LINUX_DIR)/crypto/cryptd.ko \
786 $(LINUX_DIR)/crypto/crypto_simd.ko
787 AUTOLOAD+= $(call AutoLoad,10,cryptd \
788 serpent-sse2-i586 twofish-i586 blowfish_generic)
792 define KernelPackage/crypto-misc/x86_64
794 $(LINUX_DIR)/arch/x86/crypto/camellia-x86_64.ko \
795 $(LINUX_DIR)/arch/x86/crypto/blowfish-x86_64.ko \
796 $(LINUX_DIR)/arch/x86/crypto/twofish-x86_64.ko \
797 $(LINUX_DIR)/arch/x86/crypto/twofish-x86_64-3way.ko \
798 $(LINUX_DIR)/arch/x86/crypto/serpent-sse2-x86_64.ko \
799 $(LINUX_DIR)/arch/x86/crypto/camellia-aesni-avx-x86_64.ko \
800 $(LINUX_DIR)/arch/x86/crypto/cast5-avx-x86_64.ko \
801 $(LINUX_DIR)/arch/x86/crypto/cast6-avx-x86_64.ko \
802 $(LINUX_DIR)/arch/x86/crypto/twofish-avx-x86_64.ko \
803 $(LINUX_DIR)/arch/x86/crypto/serpent-avx-x86_64.ko \
804 $(LINUX_DIR)/arch/x86/crypto/camellia-aesni-avx2.ko \
805 $(LINUX_DIR)/arch/x86/crypto/serpent-avx2.ko
806 AUTOLOAD+= $(call AutoLoad,10,camellia-x86_64 \
807 camellia-aesni-avx-x86_64 camellia-aesni-avx2 cast5-avx-x86_64 \
808 cast6-avx-x86_64 twofish-x86_64 twofish-x86_64-3way \
809 twofish-avx-x86_64 blowfish-x86_64 serpent-avx-x86_64 serpent-avx2)
812 ifdef KernelPackage/crypto-misc/$(ARCH)
813 KernelPackage/crypto-misc/$(CRYPTO_TARGET)=\
814 $(KernelPackage/crypto-misc/$(ARCH))
817 $(eval $(call KernelPackage,crypto-misc))
820 define KernelPackage/crypto-null
821 TITLE:=Null CryptoAPI module
822 KCONFIG:=CONFIG_CRYPTO_NULL
823 FILES:=$(LINUX_DIR)/crypto/crypto_null.ko
824 AUTOLOAD:=$(call AutoLoad,09,crypto_null)
825 $(call AddDepends/crypto, +kmod-crypto-hash)
828 $(eval $(call KernelPackage,crypto-null))
831 define KernelPackage/crypto-pcbc
832 TITLE:=Propagating Cipher Block Chaining CryptoAPI module
833 DEPENDS:=+kmod-crypto-manager
834 KCONFIG:=CONFIG_CRYPTO_PCBC
835 FILES:=$(LINUX_DIR)/crypto/pcbc.ko
836 AUTOLOAD:=$(call AutoLoad,09,pcbc)
837 $(call AddDepends/crypto)
840 $(eval $(call KernelPackage,crypto-pcbc))
843 define KernelPackage/crypto-rsa
845 DEPENDS:=+kmod-crypto-manager +kmod-asn1-decoder
846 KCONFIG:= CONFIG_CRYPTO_RSA
849 $(LINUX_DIR)/lib/mpi/mpi.ko \
850 $(LINUX_DIR)/crypto/akcipher.ko \
851 $(LINUX_DIR)/crypto/rsa_generic.ko
852 AUTOLOAD:=$(call AutoLoad,10,rsa_generic)
853 $(call AddDepends/crypto)
856 $(eval $(call KernelPackage,crypto-rsa))
859 define KernelPackage/crypto-rmd160
860 TITLE:=RIPEMD160 digest CryptoAPI module
861 DEPENDS:=+kmod-crypto-hash
862 KCONFIG:=CONFIG_CRYPTO_RMD160
863 FILES:=$(LINUX_DIR)/crypto/rmd160.ko
864 AUTOLOAD:=$(call AutoLoad,09,rmd160)
865 $(call AddDepends/crypto)
868 $(eval $(call KernelPackage,crypto-rmd160))
871 define KernelPackage/crypto-rng
872 TITLE:=CryptoAPI random number generation
873 DEPENDS:=+kmod-crypto-hash +kmod-crypto-hmac +kmod-crypto-sha512
876 CONFIG_CRYPTO_DRBG_HMAC=y \
877 CONFIG_CRYPTO_DRBG_HASH=n \
878 CONFIG_CRYPTO_DRBG_MENU \
879 CONFIG_CRYPTO_JITTERENTROPY \
882 $(LINUX_DIR)/crypto/drbg.ko \
883 $(LINUX_DIR)/crypto/jitterentropy_rng.ko \
884 $(LINUX_DIR)/crypto/rng.ko
885 AUTOLOAD:=$(call AutoLoad,09,drbg jitterentropy_rng rng)
886 $(call AddDepends/crypto)
889 $(eval $(call KernelPackage,crypto-rng))
892 define KernelPackage/crypto-seqiv
893 TITLE:=CryptoAPI Sequence Number IV Generator
894 DEPENDS:=+kmod-crypto-aead +kmod-crypto-rng
895 KCONFIG:=CONFIG_CRYPTO_SEQIV
896 FILES:=$(LINUX_DIR)/crypto/seqiv.ko
897 AUTOLOAD:=$(call AutoLoad,09,seqiv)
898 $(call AddDepends/crypto)
901 $(eval $(call KernelPackage,crypto-seqiv))
904 define KernelPackage/crypto-sha1
905 TITLE:=SHA1 digest CryptoAPI module
906 DEPENDS:=+kmod-crypto-hash
909 CONFIG_CRYPTO_SHA1_ARM \
910 CONFIG_CRYPTO_SHA1_ARM_NEON \
911 CONFIG_CRYPTO_SHA1_OCTEON \
912 CONFIG_CRYPTO_SHA1_PPC_SPE \
913 CONFIG_CRYPTO_SHA1_SSSE3
914 FILES:=$(LINUX_DIR)/crypto/sha1_generic.ko
915 AUTOLOAD:=$(call AutoLoad,09,sha1_generic)
916 $(call AddDepends/crypto)
919 define KernelPackage/crypto-sha1/arm
920 FILES+=$(LINUX_DIR)/arch/arm/crypto/sha1-arm.ko
921 AUTOLOAD+=$(call AutoLoad,09,sha1-arm)
924 define KernelPackage/crypto-sha1/arm-neon
925 $(call KernelPackage/crypto-sha1/arm)
926 FILES+=$(LINUX_DIR)/arch/arm/crypto/sha1-arm-neon.ko
927 AUTOLOAD+=$(call AutoLoad,09,sha1-arm-neon)
930 KernelPackage/crypto-sha1/imx=$(KernelPackage/crypto-sha1/arm-neon)
931 KernelPackage/crypto-sha1/ipq40xx=$(KernelPackage/crypto-sha1/arm-neon)
932 KernelPackage/crypto-sha1/mvebu/cortexa9=$(KernelPackage/crypto-sha1/arm-neon)
934 define KernelPackage/crypto-sha1/octeon
935 FILES+=$(LINUX_DIR)/arch/mips/cavium-octeon/crypto/octeon-sha1.ko
936 AUTOLOAD+=$(call AutoLoad,09,octeon-sha1)
939 KernelPackage/crypto-sha1/tegra=$(KernelPackage/crypto-sha1/arm)
941 define KernelPackage/crypto-sha1/mpc85xx
942 FILES+=$(LINUX_DIR)/arch/powerpc/crypto/sha1-ppc-spe.ko
943 AUTOLOAD+=$(call AutoLoad,09,sha1-ppc-spe)
946 ifndef CONFIG_TARGET_uml
947 define KernelPackage/crypto-sha1/x86_64
948 FILES+=$(LINUX_DIR)/arch/x86/crypto/sha1-ssse3.ko
949 AUTOLOAD+=$(call AutoLoad,09,sha1-ssse3)
953 ifdef KernelPackage/crypto-sha1/$(ARCH)
954 KernelPackage/crypto-sha1/$(CRYPTO_TARGET)=\
955 $(KernelPackage/crypto-sha1/$(ARCH))
958 $(eval $(call KernelPackage,crypto-sha1))
961 define KernelPackage/crypto-sha256
962 TITLE:=SHA224 SHA256 digest CryptoAPI module
963 DEPENDS:=+kmod-crypto-hash
965 CONFIG_CRYPTO_SHA256 \
966 CONFIG_CRYPTO_SHA256_OCTEON \
967 CONFIG_CRYPTO_SHA256_PPC_SPE \
968 CONFIG_CRYPTO_SHA256_SSSE3
970 $(LINUX_DIR)/crypto/sha256_generic.ko \
971 $(LINUX_DIR)/lib/crypto/libsha256.ko
972 AUTOLOAD:=$(call AutoLoad,09,sha256_generic)
973 $(call AddDepends/crypto)
976 define KernelPackage/crypto-sha256/octeon
977 FILES+=$(LINUX_DIR)/arch/mips/cavium-octeon/crypto/octeon-sha256.ko
978 AUTOLOAD+=$(call AutoLoad,09,octeon-sha256)
981 define KernelPackage/crypto-sha256/mpc85xx
982 FILES+=$(LINUX_DIR)/arch/powerpc/crypto/sha256-ppc-spe.ko
983 AUTOLOAD+=$(call AutoLoad,09,sha256-ppc-spe)
986 ifndef CONFIG_TARGET_uml
987 define KernelPackage/crypto-sha256/x86_64
988 FILES+=$(LINUX_DIR)/arch/x86/crypto/sha256-ssse3.ko
989 AUTOLOAD+=$(call AutoLoad,09,sha256-ssse3)
993 ifdef KernelPackage/crypto-sha256/$(ARCH)
994 KernelPackage/crypto-sha256/$(CRYPTO_TARGET)=\
995 $(KernelPackage/crypto-sha256/$(ARCH))
998 $(eval $(call KernelPackage,crypto-sha256))
1001 define KernelPackage/crypto-sha512
1002 TITLE:=SHA512 digest CryptoAPI module
1003 DEPENDS:=+kmod-crypto-hash
1005 CONFIG_CRYPTO_SHA512 \
1006 CONFIG_CRYPTO_SHA512_ARM \
1007 CONFIG_CRYPTO_SHA512_OCTEON \
1008 CONFIG_CRYPTO_SHA512_SSSE3
1009 FILES:=$(LINUX_DIR)/crypto/sha512_generic.ko
1010 AUTOLOAD:=$(call AutoLoad,09,sha512_generic)
1011 $(call AddDepends/crypto)
1014 define KernelPackage/crypto-sha512/arm
1015 FILES+=$(LINUX_DIR)/arch/arm/crypto/sha512-arm.ko
1016 AUTOLOAD+=$(call AutoLoad,09,sha512-arm)
1019 KernelPackage/crypto-sha512/imx=$(KernelPackage/crypto-sha512/arm)
1020 KernelPackage/crypto-sha512/ipq40xx=$(KernelPackage/crypto-sha512/arm)
1021 KernelPackage/crypto-sha512/mvebu/cortexa9=$(KernelPackage/crypto-sha512/arm)
1023 define KernelPackage/crypto-sha512/octeon
1024 FILES+=$(LINUX_DIR)/arch/mips/cavium-octeon/crypto/octeon-sha512.ko
1025 AUTOLOAD+=$(call AutoLoad,09,octeon-sha512)
1028 KernelPackage/crypto-sha512/tegra=$(KernelPackage/crypto-sha512/arm)
1030 ifndef CONFIG_TARGET_uml
1031 define KernelPackage/crypto-sha512/x86_64
1032 FILES+=$(LINUX_DIR)/arch/x86/crypto/sha512-ssse3.ko
1033 AUTOLOAD+=$(call AutoLoad,09,sha512-ssse3)
1037 ifdef KernelPackage/crypto-sha512/$(ARCH)
1038 KernelPackage/crypto-sha512/$(CRYPTO_TARGET)=\
1039 $(KernelPackage/crypto-sha512/$(ARCH))
1042 $(eval $(call KernelPackage,crypto-sha512))
1045 define KernelPackage/crypto-test
1046 TITLE:=Test CryptoAPI module
1047 KCONFIG:=CONFIG_CRYPTO_TEST
1048 FILES:=$(LINUX_DIR)/crypto/tcrypt.ko
1049 $(call AddDepends/crypto,+kmod-crypto-manager)
1052 $(eval $(call KernelPackage,crypto-test))
1055 define KernelPackage/crypto-user
1056 TITLE:=CryptoAPI userspace interface
1057 DEPENDS:=+kmod-crypto-hash +kmod-crypto-manager
1059 CONFIG_CRYPTO_USER \
1060 CONFIG_CRYPTO_USER_API \
1061 CONFIG_CRYPTO_USER_API_AEAD \
1062 CONFIG_CRYPTO_USER_API_HASH \
1063 CONFIG_CRYPTO_USER_API_RNG \
1064 CONFIG_CRYPTO_USER_API_SKCIPHER
1066 $(LINUX_DIR)/crypto/af_alg.ko \
1067 $(LINUX_DIR)/crypto/algif_aead.ko \
1068 $(LINUX_DIR)/crypto/algif_hash.ko \
1069 $(LINUX_DIR)/crypto/algif_rng.ko \
1070 $(LINUX_DIR)/crypto/algif_skcipher.ko \
1071 $(LINUX_DIR)/crypto/crypto_user.ko
1072 AUTOLOAD:=$(call AutoLoad,09,af_alg algif_aead algif_hash algif_rng algif_skcipher crypto_user)
1073 $(call AddDepends/crypto)
1076 $(eval $(call KernelPackage,crypto-user))
1079 define KernelPackage/crypto-xts
1080 TITLE:=XTS cipher CryptoAPI module
1081 DEPENDS:=+kmod-crypto-gf128 +kmod-crypto-manager
1082 KCONFIG:=CONFIG_CRYPTO_XTS
1083 FILES:=$(LINUX_DIR)/crypto/xts.ko
1084 AUTOLOAD:=$(call AutoLoad,09,xts)
1085 $(call AddDepends/crypto)
1088 $(eval $(call KernelPackage,crypto-xts))