kernel: crypto: add kmod-crypto-chacha20poly1305
[openwrt/staging/ansuel.git] / package / kernel / linux / modules / crypto.mk
1 #
2 # Copyright (C) 2006-2011 OpenWrt.org
3 #
4 # This is free software, licensed under the GNU General Public License v2.
5 # See /LICENSE for more information.
6 #
7
8 CRYPTO_MENU:=Cryptographic API modules
9
10 CRYPTO_MODULES = \
11 ALGAPI2=crypto_algapi \
12 BLKCIPHER2=crypto_blkcipher
13
14 CRYPTO_TARGET = $(BOARD)/$(if $(SUBTARGET),$(SUBTARGET),generic)
15
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))))
19
20 define AddDepends/crypto
21 SUBMENU:=$(CRYPTO_MENU)
22 DEPENDS+= $(1)
23 endef
24
25
26 define KernelPackage/crypto-acompress
27 TITLE:=Asynchronous Compression operations
28 HIDDEN:=1
29 KCONFIG:=CONFIG_CRYPTO_ACOMP2
30 FILES:=$(LINUX_DIR)/crypto/crypto_acompress.ko
31 AUTOLOAD:=$(call AutoLoad,09,crypto_acompress)
32 $(call AddDepends/crypto)
33 endef
34
35 $(eval $(call KernelPackage,crypto-acompress))
36
37
38 define KernelPackage/crypto-aead
39 TITLE:=CryptoAPI AEAD support
40 KCONFIG:= \
41 CONFIG_CRYPTO_AEAD \
42 CONFIG_CRYPTO_AEAD2
43 FILES:= \
44 $(LINUX_DIR)/crypto/aead.ko \
45 $(LINUX_DIR)/crypto/geniv.ko@ge5.10
46 AUTOLOAD:=$(call AutoLoad,09,aead,1)
47 $(call AddDepends/crypto, +kmod-crypto-null)
48 endef
49
50 $(eval $(call KernelPackage,crypto-aead))
51
52
53 define KernelPackage/crypto-arc4
54 TITLE:=ARC4 cipher CryptoAPI module
55 KCONFIG:= \
56 CONFIG_CRYPTO_ARC4 \
57 CONFIG_CRYPTO_USER_API_ENABLE_OBSOLETE=y
58 FILES:= \
59 $(LINUX_DIR)/crypto/arc4.ko \
60 $(LINUX_DIR)/lib/crypto/libarc4.ko
61 AUTOLOAD:=$(call AutoLoad,09,arc4)
62 $(call AddDepends/crypto)
63 endef
64
65 $(eval $(call KernelPackage,crypto-arc4))
66
67
68 define KernelPackage/crypto-authenc
69 TITLE:=Combined mode wrapper for IPsec
70 DEPENDS:=+kmod-crypto-manager +kmod-crypto-null
71 KCONFIG:=CONFIG_CRYPTO_AUTHENC
72 FILES:=$(LINUX_DIR)/crypto/authenc.ko
73 AUTOLOAD:=$(call AutoLoad,09,authenc)
74 $(call AddDepends/crypto)
75 endef
76
77 $(eval $(call KernelPackage,crypto-authenc))
78
79
80 define KernelPackage/crypto-cbc
81 TITLE:=Cipher Block Chaining CryptoAPI module
82 DEPENDS:=+kmod-crypto-manager
83 KCONFIG:=CONFIG_CRYPTO_CBC
84 FILES:=$(LINUX_DIR)/crypto/cbc.ko
85 AUTOLOAD:=$(call AutoLoad,09,cbc)
86 $(call AddDepends/crypto)
87 endef
88
89 $(eval $(call KernelPackage,crypto-cbc))
90
91
92 define KernelPackage/crypto-ccm
93 TITLE:=Support for Counter with CBC MAC (CCM)
94 DEPENDS:=+kmod-crypto-ctr +kmod-crypto-aead
95 KCONFIG:=CONFIG_CRYPTO_CCM
96 FILES:=$(LINUX_DIR)/crypto/ccm.ko
97 AUTOLOAD:=$(call AutoLoad,09,ccm)
98 $(call AddDepends/crypto)
99 endef
100
101 $(eval $(call KernelPackage,crypto-ccm))
102
103
104 define KernelPackage/crypto-chacha20poly1305
105 TITLE:=ChaCha20-Poly1305 AEAD support, RFC7539 (used by strongSwan IPsec VPN)
106 DEPENDS:=+kmod-crypto-aead +kmod-crypto-manager
107 KCONFIG:=CONFIG_CRYPTO_CHACHA20POLY1305
108 FILES:=$(LINUX_DIR)/crypto/chacha20poly1305.ko
109 AUTOLOAD:=$(call AutoLoad,09,chacha20poly1305)
110 $(call AddDepends/crypto)
111 endef
112
113 $(eval $(call KernelPackage,crypto-chacha20poly1305))
114
115
116 define KernelPackage/crypto-cmac
117 TITLE:=Support for Cipher-based Message Authentication Code (CMAC)
118 DEPENDS:=+kmod-crypto-hash
119 KCONFIG:=CONFIG_CRYPTO_CMAC
120 FILES:=$(LINUX_DIR)/crypto/cmac.ko
121 AUTOLOAD:=$(call AutoLoad,09,cmac)
122 $(call AddDepends/crypto)
123 endef
124
125 $(eval $(call KernelPackage,crypto-cmac))
126
127
128 define KernelPackage/crypto-crc32
129 TITLE:=CRC32 CRC module
130 DEPENDS:=+kmod-crypto-hash
131 KCONFIG:=CONFIG_CRYPTO_CRC32
132 HIDDEN:=1
133 FILES:=$(LINUX_DIR)/crypto/crc32_generic.ko
134 AUTOLOAD:=$(call AutoLoad,04,crc32_generic,1)
135 $(call AddDepends/crypto)
136 endef
137
138 $(eval $(call KernelPackage,crypto-crc32))
139
140
141 define KernelPackage/crypto-crc32c
142 TITLE:=CRC32c CRC module
143 DEPENDS:=+kmod-crypto-hash
144 KCONFIG:=CONFIG_CRYPTO_CRC32C
145 FILES:=$(LINUX_DIR)/crypto/crc32c_generic.ko
146 AUTOLOAD:=$(call AutoLoad,04,crc32c_generic,1)
147 $(call AddDepends/crypto)
148 endef
149
150 $(eval $(call KernelPackage,crypto-crc32c))
151
152
153 define KernelPackage/crypto-ctr
154 TITLE:=Counter Mode CryptoAPI module
155 DEPENDS:=+kmod-crypto-manager +kmod-crypto-seqiv
156 KCONFIG:=CONFIG_CRYPTO_CTR
157 FILES:=$(LINUX_DIR)/crypto/ctr.ko
158 AUTOLOAD:=$(call AutoLoad,09,ctr)
159 $(call AddDepends/crypto)
160 endef
161
162 $(eval $(call KernelPackage,crypto-ctr))
163
164
165 define KernelPackage/crypto-cts
166 TITLE:=Cipher Text Stealing CryptoAPI module
167 DEPENDS:=+kmod-crypto-manager
168 KCONFIG:=CONFIG_CRYPTO_CTS
169 FILES:=$(LINUX_DIR)/crypto/cts.ko
170 AUTOLOAD:=$(call AutoLoad,09,cts)
171 $(call AddDepends/crypto)
172 endef
173
174 $(eval $(call KernelPackage,crypto-cts))
175
176
177 define KernelPackage/crypto-deflate
178 TITLE:=Deflate compression CryptoAPI module
179 DEPENDS:=+kmod-lib-zlib-inflate +kmod-lib-zlib-deflate +kmod-crypto-acompress
180 KCONFIG:=CONFIG_CRYPTO_DEFLATE
181 FILES:=$(LINUX_DIR)/crypto/deflate.ko
182 AUTOLOAD:=$(call AutoLoad,09,deflate)
183 $(call AddDepends/crypto)
184 endef
185
186 $(eval $(call KernelPackage,crypto-deflate))
187
188
189 define KernelPackage/crypto-des
190 TITLE:=DES/3DES cipher CryptoAPI module
191 KCONFIG:=CONFIG_CRYPTO_DES
192 FILES:= \
193 $(LINUX_DIR)/crypto/des_generic.ko \
194 $(LINUX_DIR)/lib/crypto/libdes.ko
195 AUTOLOAD:=$(call AutoLoad,09,des_generic)
196 $(call AddDepends/crypto)
197 endef
198
199 $(eval $(call KernelPackage,crypto-des))
200
201
202 define KernelPackage/crypto-ecb
203 TITLE:=Electronic CodeBook CryptoAPI module
204 DEPENDS:=+kmod-crypto-manager
205 KCONFIG:=CONFIG_CRYPTO_ECB
206 FILES:=$(LINUX_DIR)/crypto/ecb.ko
207 AUTOLOAD:=$(call AutoLoad,09,ecb)
208 $(call AddDepends/crypto)
209 endef
210
211 $(eval $(call KernelPackage,crypto-ecb))
212
213
214 define KernelPackage/crypto-ecdh
215 TITLE:=ECDH algorithm
216 DEPENDS:=+kmod-crypto-kpp
217 KCONFIG:= CONFIG_CRYPTO_ECDH
218 FILES:= \
219 $(LINUX_DIR)/crypto/ecdh_generic.ko \
220 $(LINUX_DIR)/crypto/ecc.ko
221 AUTOLOAD:=$(call AutoLoad,10,ecdh_generic)
222 $(call AddDepends/crypto)
223 endef
224
225 $(eval $(call KernelPackage,crypto-ecdh))
226
227
228 define KernelPackage/crypto-echainiv
229 TITLE:=Encrypted Chain IV Generator
230 DEPENDS:=+kmod-crypto-aead
231 KCONFIG:=CONFIG_CRYPTO_ECHAINIV
232 FILES:=$(LINUX_DIR)/crypto/echainiv.ko
233 AUTOLOAD:=$(call AutoLoad,09,echainiv)
234 $(call AddDepends/crypto)
235 endef
236
237 $(eval $(call KernelPackage,crypto-echainiv))
238
239
240 define KernelPackage/crypto-fcrypt
241 TITLE:=FCRYPT cipher CryptoAPI module
242 KCONFIG:=CONFIG_CRYPTO_FCRYPT
243 FILES:=$(LINUX_DIR)/crypto/fcrypt.ko
244 AUTOLOAD:=$(call AutoLoad,09,fcrypt)
245 $(call AddDepends/crypto)
246 endef
247
248 $(eval $(call KernelPackage,crypto-fcrypt))
249
250
251 define KernelPackage/crypto-gcm
252 TITLE:=GCM/GMAC CryptoAPI module
253 DEPENDS:=+kmod-crypto-ctr +kmod-crypto-ghash +kmod-crypto-null
254 KCONFIG:=CONFIG_CRYPTO_GCM
255 FILES:=$(LINUX_DIR)/crypto/gcm.ko
256 AUTOLOAD:=$(call AutoLoad,09,gcm)
257 $(call AddDepends/crypto)
258 endef
259
260 $(eval $(call KernelPackage,crypto-gcm))
261
262
263 define KernelPackage/crypto-xcbc
264 TITLE:=XCBC CryptoAPI module
265 DEPENDS:=+kmod-crypto-hash +kmod-crypto-manager
266 KCONFIG:=CONFIG_CRYPTO_XCBC
267 FILES:=$(LINUX_DIR)/crypto/xcbc.ko
268 AUTOLOAD:=$(call AutoLoad,09,xcbc)
269 $(call AddDepends/crypto)
270 endef
271
272 $(eval $(call KernelPackage,crypto-xcbc))
273
274
275 define KernelPackage/crypto-gf128
276 TITLE:=GF(2^128) multiplication functions CryptoAPI module
277 KCONFIG:=CONFIG_CRYPTO_GF128MUL
278 FILES:=$(LINUX_DIR)/crypto/gf128mul.ko
279 AUTOLOAD:=$(call AutoLoad,09,gf128mul)
280 $(call AddDepends/crypto)
281 endef
282
283 $(eval $(call KernelPackage,crypto-gf128))
284
285
286 define KernelPackage/crypto-ghash
287 TITLE:=GHASH digest CryptoAPI module
288 DEPENDS:=+kmod-crypto-gf128 +kmod-crypto-hash
289 KCONFIG:= \
290 CONFIG_CRYPTO_GHASH \
291 CONFIG_CRYPTO_GHASH_ARM_CE
292 FILES:=$(LINUX_DIR)/crypto/ghash-generic.ko
293 AUTOLOAD:=$(call AutoLoad,09,ghash-generic)
294 $(call AddDepends/crypto)
295 endef
296
297 define KernelPackage/crypto-ghash/arm-ce
298 FILES+= $(LINUX_DIR)/arch/arm/crypto/ghash-arm-ce.ko
299 AUTOLOAD+=$(call AutoLoad,09,ghash-arm-ce)
300 endef
301
302 KernelPackage/crypto-ghash/imx=$(KernelPackage/crypto-ghash/arm-ce)
303 KernelPackage/crypto-ghash/ipq40xx=$(KernelPackage/crypto-ghash/arm-ce)
304 KernelPackage/crypto-ghash/mvebu/cortexa9=$(KernelPackage/crypto-ghash/arm-ce)
305
306 $(eval $(call KernelPackage,crypto-ghash))
307
308
309 define KernelPackage/crypto-hash
310 TITLE:=CryptoAPI hash support
311 KCONFIG:=CONFIG_CRYPTO_HASH
312 FILES:=$(LINUX_DIR)/crypto/crypto_hash.ko
313 AUTOLOAD:=$(call AutoLoad,02,crypto_hash,1)
314 $(call AddDepends/crypto)
315 endef
316
317 $(eval $(call KernelPackage,crypto-hash))
318
319
320 define KernelPackage/crypto-hmac
321 TITLE:=HMAC digest CryptoAPI module
322 DEPENDS:=+kmod-crypto-hash +kmod-crypto-manager
323 KCONFIG:=CONFIG_CRYPTO_HMAC
324 FILES:=$(LINUX_DIR)/crypto/hmac.ko
325 AUTOLOAD:=$(call AutoLoad,09,hmac)
326 $(call AddDepends/crypto)
327 endef
328
329 $(eval $(call KernelPackage,crypto-hmac))
330
331
332 define KernelPackage/crypto-hw-ccp
333 TITLE:=AMD Cryptographic Coprocessor
334 DEPENDS:= \
335 @TARGET_x86 \
336 +kmod-crypto-authenc \
337 +kmod-crypto-hash \
338 +kmod-crypto-manager \
339 +kmod-crypto-rsa \
340 +kmod-crypto-sha1 \
341 +kmod-crypto-sha256 \
342 +kmod-random-core
343 KCONFIG:= \
344 CONFIG_CRYPTO_HW=y \
345 CONFIG_CRYPTO_DEV_CCP=y \
346 CONFIG_CRYPTO_DEV_CCP_CRYPTO \
347 CONFIG_CRYPTO_DEV_CCP_DD \
348 CONFIG_CRYPTO_DEV_SP_CCP=y
349 FILES:= \
350 $(LINUX_DIR)/drivers/crypto/ccp/ccp.ko \
351 $(LINUX_DIR)/drivers/crypto/ccp/ccp-crypto.ko
352 AUTOLOAD:=$(call AutoLoad,09,ccp ccp-crypto)
353 $(call AddDepends/crypto)
354 endef
355
356 $(eval $(call KernelPackage,crypto-hw-ccp))
357
358
359 define KernelPackage/crypto-hw-geode
360 TITLE:=AMD Geode hardware crypto module
361 DEPENDS:=@TARGET_x86_geode +kmod-crypto-manager
362 KCONFIG:= \
363 CONFIG_CRYPTO_HW=y \
364 CONFIG_CRYPTO_DEV_GEODE
365 FILES:=$(LINUX_DIR)/drivers/crypto/geode-aes.ko
366 AUTOLOAD:=$(call AutoLoad,09,geode-aes)
367 $(call AddDepends/crypto)
368 endef
369
370 $(eval $(call KernelPackage,crypto-hw-geode))
371
372
373 define KernelPackage/crypto-hw-hifn-795x
374 TITLE:=HIFN 795x crypto accelerator
375 DEPENDS:=@PCI_SUPPORT +kmod-random-core +kmod-crypto-manager
376 KCONFIG:= \
377 CONFIG_CRYPTO_HW=y \
378 CONFIG_CRYPTO_DEV_HIFN_795X \
379 CONFIG_CRYPTO_DEV_HIFN_795X_RNG=y
380 FILES:=$(LINUX_DIR)/drivers/crypto/hifn_795x.ko
381 AUTOLOAD:=$(call AutoLoad,09,hifn_795x)
382 $(call AddDepends/crypto,+kmod-crypto-des)
383 endef
384
385 $(eval $(call KernelPackage,crypto-hw-hifn-795x))
386
387
388 define KernelPackage/crypto-hw-padlock
389 TITLE:=VIA PadLock ACE with AES/SHA hw crypto module
390 DEPENDS:=+kmod-crypto-manager
391 KCONFIG:= \
392 CONFIG_CRYPTO_HW=y \
393 CONFIG_CRYPTO_DEV_PADLOCK \
394 CONFIG_CRYPTO_DEV_PADLOCK_AES \
395 CONFIG_CRYPTO_DEV_PADLOCK_SHA
396 FILES:= \
397 $(LINUX_DIR)/drivers/crypto/padlock-aes.ko \
398 $(LINUX_DIR)/drivers/crypto/padlock-sha.ko
399 AUTOLOAD:=$(call AutoLoad,09,padlock-aes padlock-sha)
400 $(call AddDepends/crypto)
401 endef
402
403 $(eval $(call KernelPackage,crypto-hw-padlock))
404
405
406 define KernelPackage/crypto-hw-safexcel
407 TITLE:= MVEBU SafeXcel Crypto Engine module
408 DEPENDS:=@(TARGET_mvebu_cortexa53||TARGET_mvebu_cortexa72) +eip197-mini-firmware \
409 +kmod-crypto-authenc +kmod-crypto-md5 +kmod-crypto-hmac +kmod-crypto-sha256 +kmod-crypto-sha512
410 KCONFIG:= \
411 CONFIG_CRYPTO_HW=y \
412 CONFIG_CRYPTO_DEV_SAFEXCEL
413 FILES:=$(LINUX_DIR)/drivers/crypto/inside-secure/crypto_safexcel.ko
414 AUTOLOAD:=$(call AutoLoad,90,crypto_safexcel)
415 $(call AddDepends/crypto)
416 endef
417
418 define KernelPackage/crypto-hw-safexcel/description
419 MVEBU's EIP97 and EIP197 Cryptographic Engine driver designed by
420 Inside Secure. This is found on Marvell Armada 37xx/7k/8k SoCs.
421
422 Particular version of these IP (EIP197B and EIP197D) require firmware.
423 The mini firmware package provides limited functionality, for most operations
424 a full-featured firmware is required. Unfortunately the "full" firmware is not
425 freely available and needs signed Non-Disclosure Agreement (NDA) with Marvell.
426 For those who have signed NDA the firmware can be obtained at
427 https://extranet.marvell.com.
428 endef
429
430 $(eval $(call KernelPackage,crypto-hw-safexcel))
431
432
433 define KernelPackage/crypto-hw-talitos
434 TITLE:=Freescale integrated security engine (SEC) driver
435 DEPENDS:=@(TARGET_mpc85xx||TARGET_layerscape) +kmod-crypto-manager \
436 +kmod-crypto-hash +kmod-random-core +kmod-crypto-authenc +kmod-crypto-des
437 KCONFIG:= \
438 CONFIG_CRYPTO_HW=y \
439 CONFIG_CRYPTO_DEV_TALITOS \
440 CONFIG_CRYPTO_DEV_TALITOS1=y \
441 CONFIG_CRYPTO_DEV_TALITOS2=y
442 FILES:= \
443 $(LINUX_DIR)/drivers/crypto/talitos.ko
444 AUTOLOAD:=$(call AutoLoad,09,talitos)
445 $(call AddDepends/crypto)
446 endef
447
448 $(eval $(call KernelPackage,crypto-hw-talitos))
449
450
451 define KernelPackage/crypto-kpp
452 TITLE:=Key-agreement Protocol Primitives
453 KCONFIG:=CONFIG_CRYPTO_KPP
454 FILES:=$(LINUX_DIR)/crypto/kpp.ko
455 AUTOLOAD:=$(call AutoLoad,09,kpp)
456 $(call AddDepends/crypto)
457 endef
458
459 $(eval $(call KernelPackage,crypto-kpp))
460
461
462 define KernelPackage/crypto-lib-blake2s
463 TITLE:=BLAKE2s hash function library
464 KCONFIG:=CONFIG_CRYPTO_LIB_BLAKE2S
465 HIDDEN:=1
466 FILES:=$(LINUX_DIR)/lib/crypto/libblake2s.ko
467 $(call AddDepends/crypto,+PACKAGE_kmod-crypto-hash:kmod-crypto-hash)
468 endef
469
470 define KernelPackage/crypto-lib-blake2s/config
471 imply PACKAGE_kmod-crypto-hash
472 endef
473
474 define KernelPackage/crypto-lib-blake2s/x86/64
475 KCONFIG+=CONFIG_CRYPTO_BLAKE2S_X86
476 FILES+=\
477 $(LINUX_DIR)/lib/crypto/libblake2s-generic.ko \
478 $(LINUX_DIR)/arch/x86/crypto/blake2s-x86_64.ko
479 endef
480
481 define KernelPackage/crypto-lib-blake2s/arm
482 KCONFIG+=CONFIG_CRYPTO_BLAKE2S_ARM
483 FILES+=\
484 $(LINUX_DIR)/lib/crypto/libblake2s-generic.ko@lt5.12 \
485 $(LINUX_DIR)/arch/arm/crypto/blake2s-arm.ko@ge5.12
486 endef
487
488 ifndef KernelPackage/crypto-lib-blake2s/$(CRYPTO_TARGET)
489 define KernelPackage/crypto-lib-blake2s/$(CRYPTO_TARGET)
490 KCONFIG+=CONFIG_CRYPTO_LIB_BLAKE2S_GENERIC
491 FILES+=$(LINUX_DIR)/lib/crypto/libblake2s-generic.ko
492 endef
493 endif
494
495 ifdef KernelPackage/crypto-lib-blake2s/$(ARCH)
496 KernelPackage/crypto-lib-blake2s/$(CRYPTO_TARGET)=\
497 $(KernelPackage/crypto-lib-blake2s/$(ARCH))
498 endif
499
500 $(eval $(call KernelPackage,crypto-lib-blake2s))
501
502
503 define KernelPackage/crypto-lib-chacha20
504 TITLE:=ChaCha library interface
505 KCONFIG:=CONFIG_CRYPTO_LIB_CHACHA
506 HIDDEN:=1
507 FILES:=$(LINUX_DIR)/lib/crypto/libchacha.ko
508 $(call AddDepends/crypto)
509 endef
510
511 define KernelPackage/crypto-lib-chacha20/x86_64
512 KCONFIG+=CONFIG_CRYPTO_CHACHA20_X86_64
513 FILES+=$(LINUX_DIR)/arch/x86/crypto/chacha-x86_64.ko
514 endef
515
516 # Note that a non-neon fallback implementation is available on arm32 when
517 # NEON is not supported, hence all arm targets can utilize lib-chacha20/arm
518 define KernelPackage/crypto-lib-chacha20/arm
519 KCONFIG+=CONFIG_CRYPTO_CHACHA20_NEON
520 FILES:=$(LINUX_DIR)/arch/arm/crypto/chacha-neon.ko
521 endef
522
523 define KernelPackage/crypto-lib-chacha20/aarch64
524 KCONFIG+=CONFIG_CRYPTO_CHACHA20_NEON
525 FILES+=$(LINUX_DIR)/arch/arm64/crypto/chacha-neon.ko
526 endef
527
528 define KernelPackage/crypto-lib-chacha20/mips32r2
529 KCONFIG+=CONFIG_CRYPTO_CHACHA_MIPS
530 FILES:=$(LINUX_DIR)/arch/mips/crypto/chacha-mips.ko
531 endef
532
533 ifeq ($(CONFIG_CPU_MIPS32_R2),y)
534 KernelPackage/crypto-lib-chacha20/$(ARCH)=\
535 $(KernelPackage/crypto-lib-chacha20/mips32r2)
536 endif
537
538 ifdef KernelPackage/crypto-lib-chacha20/$(ARCH)
539 KernelPackage/crypto-lib-chacha20/$(CRYPTO_TARGET)=\
540 $(KernelPackage/crypto-lib-chacha20/$(ARCH))
541 endif
542
543 $(eval $(call KernelPackage,crypto-lib-chacha20))
544
545
546 define KernelPackage/crypto-lib-chacha20poly1305
547 TITLE:=ChaCha20-Poly1305 AEAD support (8-byte nonce library version)
548 KCONFIG:=CONFIG_CRYPTO_LIB_CHACHA20POLY1305
549 HIDDEN:=1
550 FILES:=$(LINUX_DIR)/lib/crypto/libchacha20poly1305.ko
551 $(call AddDepends/crypto, +kmod-crypto-lib-chacha20 +kmod-crypto-lib-poly1305)
552 endef
553
554 $(eval $(call KernelPackage,crypto-lib-chacha20poly1305))
555
556
557 define KernelPackage/crypto-lib-curve25519
558 TITLE:=Curve25519 scalar multiplication library
559 KCONFIG:=CONFIG_CRYPTO_LIB_CURVE25519
560 HIDDEN:=1
561 FILES:= \
562 $(LINUX_DIR)/lib/crypto/libcurve25519.ko \
563 $(LINUX_DIR)/lib/crypto/libcurve25519-generic.ko
564 $(call AddDepends/crypto,+PACKAGE_kmod-crypto-kpp:kmod-crypto-kpp)
565 endef
566
567 define KernelPackage/crypto-lib-curve25519/config
568 imply PACKAGE_kmod-crypto-kpp
569 endef
570
571 define KernelPackage/crypto-lib-curve25519/x86/64
572 KCONFIG+=CONFIG_CRYPTO_CURVE25519_X86
573 FILES+=$(LINUX_DIR)/arch/x86/crypto/curve25519-x86_64.ko
574 endef
575
576 define KernelPackage/crypto-lib-curve25519/arm-neon
577 KCONFIG+=CONFIG_CRYPTO_CURVE25519_NEON
578 FILES+=$(LINUX_DIR)/arch/arm/crypto/curve25519-neon.ko
579 endef
580
581 ifeq ($(ARCH)-$(CONFIG_KERNEL_MODE_NEON),arm-y)
582 KernelPackage/crypto-lib-curve25519/$(CRYPTO_TARGET)=\
583 $(KernelPackage/crypto-lib-curve25519/arm-neon)
584 endif
585
586 $(eval $(call KernelPackage,crypto-lib-curve25519))
587
588
589 define KernelPackage/crypto-lib-poly1305
590 TITLE:=Poly1305 library interface
591 KCONFIG:=CONFIG_CRYPTO_LIB_POLY1305
592 HIDDEN:=1
593 FILES:=$(LINUX_DIR)/lib/crypto/libpoly1305.ko
594 $(call AddDepends/crypto,+PACKAGE_kmod-crypto-hash:kmod-crypto-hash)
595 endef
596
597 define KernelPackage/crypto-lib-poly1305/config
598 imply PACKAGE_kmod-crypto-hash
599 endef
600
601 define KernelPackage/crypto-lib-poly1305/x86_64
602 KCONFIG+=CONFIG_CRYPTO_POLY1305_X86_64
603 FILES+=$(LINUX_DIR)/arch/x86/crypto/poly1305-x86_64.ko
604 endef
605
606 define KernelPackage/crypto-lib-poly1305/arm
607 KCONFIG+=CONFIG_CRYPTO_POLY1305_ARM
608 FILES:=$(LINUX_DIR)/arch/arm/crypto/poly1305-arm.ko
609 endef
610
611 define KernelPackage/crypto-lib-poly1305/aarch64
612 KCONFIG+=CONFIG_CRYPTO_POLY1305_NEON
613 FILES:=$(LINUX_DIR)/arch/arm64/crypto/poly1305-neon.ko
614 endef
615
616 define KernelPackage/crypto-lib-poly1305/mips
617 KCONFIG+=CONFIG_CRYPTO_POLY1305_MIPS
618 FILES:=$(LINUX_DIR)/arch/mips/crypto/poly1305-mips.ko
619 endef
620
621 KernelPackage/crypto-lib-poly1305/mipsel=$(KernelPackage/crypto-lib-poly1305/mips)
622 KernelPackage/crypto-lib-poly1305/mips64=$(KernelPackage/crypto-lib-poly1305/mips)
623 KernelPackage/crypto-lib-poly1305/mips64el=$(KernelPackage/crypto-lib-poly1305/mips)
624
625 ifdef KernelPackage/crypto-lib-poly1305/$(ARCH)
626 KernelPackage/crypto-lib-poly1305/$(CRYPTO_TARGET)=\
627 $(KernelPackage/crypto-lib-poly1305/$(ARCH))
628 endif
629
630 $(eval $(call KernelPackage,crypto-lib-poly1305))
631
632
633 define KernelPackage/crypto-manager
634 TITLE:=CryptoAPI algorithm manager
635 DEPENDS:=+kmod-crypto-aead +kmod-crypto-hash
636 KCONFIG:= \
637 CONFIG_CRYPTO_MANAGER \
638 CONFIG_CRYPTO_MANAGER2
639 FILES:=$(LINUX_DIR)/crypto/cryptomgr.ko
640 AUTOLOAD:=$(call AutoLoad,09,cryptomgr,1)
641 $(call AddDepends/crypto)
642 endef
643
644 $(eval $(call KernelPackage,crypto-manager))
645
646
647 define KernelPackage/crypto-md4
648 TITLE:=MD4 digest CryptoAPI module
649 DEPENDS:=+kmod-crypto-hash
650 KCONFIG:=CONFIG_CRYPTO_MD4
651 FILES:=$(LINUX_DIR)/crypto/md4.ko
652 AUTOLOAD:=$(call AutoLoad,09,md4)
653 $(call AddDepends/crypto)
654 endef
655
656 $(eval $(call KernelPackage,crypto-md4))
657
658
659 define KernelPackage/crypto-md5
660 TITLE:=MD5 digest CryptoAPI module
661 DEPENDS:=+kmod-crypto-hash
662 KCONFIG:= \
663 CONFIG_CRYPTO_MD5 \
664 CONFIG_CRYPTO_MD5_OCTEON
665 FILES:=$(LINUX_DIR)/crypto/md5.ko
666 AUTOLOAD:=$(call AutoLoad,09,md5)
667 $(call AddDepends/crypto)
668 endef
669
670 define KernelPackage/crypto-md5/octeon
671 FILES+=$(LINUX_DIR)/arch/mips/cavium-octeon/crypto/octeon-md5.ko
672 AUTOLOAD+=$(call AutoLoad,09,octeon-md5)
673 endef
674
675 $(eval $(call KernelPackage,crypto-md5))
676
677
678 define KernelPackage/crypto-michael-mic
679 TITLE:=Michael MIC keyed digest CryptoAPI module
680 DEPENDS:=+kmod-crypto-hash
681 KCONFIG:=CONFIG_CRYPTO_MICHAEL_MIC
682 FILES:=$(LINUX_DIR)/crypto/michael_mic.ko
683 AUTOLOAD:=$(call AutoLoad,09,michael_mic)
684 $(call AddDepends/crypto)
685 endef
686
687 $(eval $(call KernelPackage,crypto-michael-mic))
688
689
690 define KernelPackage/crypto-misc
691 TITLE:=Other CryptoAPI modules
692 DEPENDS:=+kmod-crypto-xts
693 KCONFIG:= \
694 CONFIG_CRYPTO_USER_API_ENABLE_OBSOLETE=y \
695 CONFIG_CRYPTO_CAMELLIA_X86_64 \
696 CONFIG_CRYPTO_BLOWFISH_X86_64 \
697 CONFIG_CRYPTO_TWOFISH_X86_64 \
698 CONFIG_CRYPTO_TWOFISH_X86_64_3WAY \
699 CONFIG_CRYPTO_SERPENT_SSE2_X86_64 \
700 CONFIG_CRYPTO_CAMELLIA_AESNI_AVX_X86_64 \
701 CONFIG_CRYPTO_CAST5_AVX_X86_64 \
702 CONFIG_CRYPTO_CAST6_AVX_X86_64 \
703 CONFIG_CRYPTO_TWOFISH_AVX_X86_64 \
704 CONFIG_CRYPTO_SERPENT_AVX_X86_64 \
705 CONFIG_CRYPTO_CAMELLIA_AESNI_AVX2_X86_64 \
706 CONFIG_CRYPTO_SERPENT_AVX2_X86_64 \
707 CONFIG_CRYPTO_SERPENT_SSE2_586 \
708 CONFIG_CRYPTO_ANUBIS \
709 CONFIG_CRYPTO_BLOWFISH \
710 CONFIG_CRYPTO_CAMELLIA \
711 CONFIG_CRYPTO_CAST5 \
712 CONFIG_CRYPTO_CAST6 \
713 CONFIG_CRYPTO_FCRYPT \
714 CONFIG_CRYPTO_KHAZAD \
715 CONFIG_CRYPTO_SERPENT \
716 CONFIG_CRYPTO_TEA \
717 CONFIG_CRYPTO_TGR192@lt5.12 \
718 CONFIG_CRYPTO_TWOFISH \
719 CONFIG_CRYPTO_TWOFISH_COMMON \
720 CONFIG_CRYPTO_TWOFISH_586 \
721 CONFIG_CRYPTO_WP512
722 FILES:= \
723 $(LINUX_DIR)/crypto/anubis.ko \
724 $(LINUX_DIR)/crypto/camellia_generic.ko \
725 $(LINUX_DIR)/crypto/cast_common.ko \
726 $(LINUX_DIR)/crypto/cast5_generic.ko \
727 $(LINUX_DIR)/crypto/cast6_generic.ko \
728 $(LINUX_DIR)/crypto/khazad.ko \
729 $(LINUX_DIR)/crypto/tea.ko \
730 $(LINUX_DIR)/crypto/tgr192.ko@lt5.12 \
731 $(LINUX_DIR)/crypto/twofish_common.ko \
732 $(LINUX_DIR)/crypto/wp512.ko \
733 $(LINUX_DIR)/crypto/twofish_generic.ko \
734 $(LINUX_DIR)/crypto/blowfish_common.ko \
735 $(LINUX_DIR)/crypto/blowfish_generic.ko \
736 $(LINUX_DIR)/crypto/serpent_generic.ko
737 AUTOLOAD:=$(call AutoLoad,10,anubis camellia_generic cast_common \
738 cast5_generic cast6_generic khazad tea tgr192@lt5.12 twofish_common \
739 wp512 blowfish_common serpent_generic)
740 ifndef CONFIG_TARGET_x86
741 AUTOLOAD+= $(call AutoLoad,10,twofish_generic blowfish_generic)
742 endif
743 $(call AddDepends/crypto)
744 endef
745
746 ifndef CONFIG_TARGET_x86_64
747 define KernelPackage/crypto-misc/x86
748 FILES+= \
749 $(LINUX_DIR)/arch/x86/crypto/twofish-i586.ko \
750 $(LINUX_DIR)/arch/x86/crypto/serpent-sse2-i586.ko \
751 $(LINUX_DIR)/arch/x86/crypto/glue_helper.ko \
752 $(LINUX_DIR)/crypto/cryptd.ko \
753 $(LINUX_DIR)/crypto/crypto_simd.ko
754 AUTOLOAD+= $(call AutoLoad,10,cryptd glue_helper \
755 serpent-sse2-i586 twofish-i586 blowfish_generic)
756 endef
757 endif
758
759 define KernelPackage/crypto-misc/x86/64
760 FILES+= \
761 $(LINUX_DIR)/arch/x86/crypto/camellia-x86_64.ko \
762 $(LINUX_DIR)/arch/x86/crypto/blowfish-x86_64.ko \
763 $(LINUX_DIR)/arch/x86/crypto/twofish-x86_64.ko \
764 $(LINUX_DIR)/arch/x86/crypto/twofish-x86_64-3way.ko \
765 $(LINUX_DIR)/arch/x86/crypto/serpent-sse2-x86_64.ko \
766 $(LINUX_DIR)/arch/x86/crypto/camellia-aesni-avx-x86_64.ko \
767 $(LINUX_DIR)/arch/x86/crypto/cast5-avx-x86_64.ko \
768 $(LINUX_DIR)/arch/x86/crypto/cast6-avx-x86_64.ko \
769 $(LINUX_DIR)/arch/x86/crypto/twofish-avx-x86_64.ko \
770 $(LINUX_DIR)/arch/x86/crypto/serpent-avx-x86_64.ko \
771 $(LINUX_DIR)/arch/x86/crypto/camellia-aesni-avx2.ko \
772 $(LINUX_DIR)/arch/x86/crypto/serpent-avx2.ko
773 AUTOLOAD+= $(call AutoLoad,10,camellia-x86_64 \
774 camellia-aesni-avx-x86_64 camellia-aesni-avx2 cast5-avx-x86_64 \
775 cast6-avx-x86_64 twofish-x86_64 twofish-x86_64-3way \
776 twofish-avx-x86_64 blowfish-x86_64 serpent-avx-x86_64 serpent-avx2)
777 endef
778
779 $(eval $(call KernelPackage,crypto-misc))
780
781
782 define KernelPackage/crypto-null
783 TITLE:=Null CryptoAPI module
784 KCONFIG:=CONFIG_CRYPTO_NULL
785 FILES:=$(LINUX_DIR)/crypto/crypto_null.ko
786 AUTOLOAD:=$(call AutoLoad,09,crypto_null)
787 $(call AddDepends/crypto, +kmod-crypto-hash)
788 endef
789
790 $(eval $(call KernelPackage,crypto-null))
791
792
793 define KernelPackage/crypto-pcbc
794 TITLE:=Propagating Cipher Block Chaining CryptoAPI module
795 DEPENDS:=+kmod-crypto-manager
796 KCONFIG:=CONFIG_CRYPTO_PCBC
797 FILES:=$(LINUX_DIR)/crypto/pcbc.ko
798 AUTOLOAD:=$(call AutoLoad,09,pcbc)
799 $(call AddDepends/crypto)
800 endef
801
802 $(eval $(call KernelPackage,crypto-pcbc))
803
804
805 define KernelPackage/crypto-rsa
806 TITLE:=RSA algorithm
807 DEPENDS:=+kmod-crypto-manager +kmod-asn1-decoder
808 KCONFIG:= CONFIG_CRYPTO_RSA
809 HIDDEN:=1
810 FILES:= \
811 $(LINUX_DIR)/lib/mpi/mpi.ko \
812 $(LINUX_DIR)/crypto/akcipher.ko \
813 $(LINUX_DIR)/crypto/rsa_generic.ko
814 AUTOLOAD:=$(call AutoLoad,10,rsa_generic)
815 $(call AddDepends/crypto)
816 endef
817
818 $(eval $(call KernelPackage,crypto-rsa))
819
820
821 define KernelPackage/crypto-rmd160
822 TITLE:=RIPEMD160 digest CryptoAPI module
823 DEPENDS:=+kmod-crypto-hash
824 KCONFIG:=CONFIG_CRYPTO_RMD160
825 FILES:=$(LINUX_DIR)/crypto/rmd160.ko
826 AUTOLOAD:=$(call AutoLoad,09,rmd160)
827 $(call AddDepends/crypto)
828 endef
829
830 $(eval $(call KernelPackage,crypto-rmd160))
831
832
833 define KernelPackage/crypto-rng
834 TITLE:=CryptoAPI random number generation
835 DEPENDS:=+kmod-crypto-hash +kmod-crypto-hmac +kmod-crypto-sha256
836 KCONFIG:= \
837 CONFIG_CRYPTO_DRBG \
838 CONFIG_CRYPTO_DRBG_HMAC=y \
839 CONFIG_CRYPTO_DRBG_HASH=n \
840 CONFIG_CRYPTO_DRBG_MENU \
841 CONFIG_CRYPTO_JITTERENTROPY \
842 CONFIG_CRYPTO_RNG2
843 FILES:= \
844 $(LINUX_DIR)/crypto/drbg.ko \
845 $(LINUX_DIR)/crypto/jitterentropy_rng.ko \
846 $(LINUX_DIR)/crypto/rng.ko
847 AUTOLOAD:=$(call AutoLoad,09,drbg jitterentropy_rng rng)
848 $(call AddDepends/crypto)
849 endef
850
851 $(eval $(call KernelPackage,crypto-rng))
852
853
854 define KernelPackage/crypto-seqiv
855 TITLE:=CryptoAPI Sequence Number IV Generator
856 DEPENDS:=+kmod-crypto-aead +kmod-crypto-rng
857 KCONFIG:=CONFIG_CRYPTO_SEQIV
858 FILES:=$(LINUX_DIR)/crypto/seqiv.ko
859 AUTOLOAD:=$(call AutoLoad,09,seqiv)
860 $(call AddDepends/crypto)
861 endef
862
863 $(eval $(call KernelPackage,crypto-seqiv))
864
865
866 define KernelPackage/crypto-sha1
867 TITLE:=SHA1 digest CryptoAPI module
868 DEPENDS:=+kmod-crypto-hash
869 KCONFIG:= \
870 CONFIG_CRYPTO_SHA1 \
871 CONFIG_CRYPTO_SHA1_ARM \
872 CONFIG_CRYPTO_SHA1_ARM_NEON \
873 CONFIG_CRYPTO_SHA1_OCTEON \
874 CONFIG_CRYPTO_SHA1_SSSE3
875 FILES:=$(LINUX_DIR)/crypto/sha1_generic.ko
876 AUTOLOAD:=$(call AutoLoad,09,sha1_generic)
877 $(call AddDepends/crypto)
878 endef
879
880 define KernelPackage/crypto-sha1/arm
881 FILES+=$(LINUX_DIR)/arch/arm/crypto/sha1-arm.ko
882 AUTOLOAD+=$(call AutoLoad,09,sha1-arm)
883 endef
884
885 define KernelPackage/crypto-sha1/arm-neon
886 $(call KernelPackage/crypto-sha1/arm)
887 FILES+=$(LINUX_DIR)/arch/arm/crypto/sha1-arm-neon.ko
888 AUTOLOAD+=$(call AutoLoad,09,sha1-arm-neon)
889 endef
890
891 KernelPackage/crypto-sha1/imx=$(KernelPackage/crypto-sha1/arm-neon)
892 KernelPackage/crypto-sha1/ipq40xx=$(KernelPackage/crypto-sha1/arm-neon)
893 KernelPackage/crypto-sha1/mvebu/cortexa9=$(KernelPackage/crypto-sha1/arm-neon)
894
895 define KernelPackage/crypto-sha1/octeon
896 FILES+=$(LINUX_DIR)/arch/mips/cavium-octeon/crypto/octeon-sha1.ko
897 AUTOLOAD+=$(call AutoLoad,09,octeon-sha1)
898 endef
899
900 KernelPackage/crypto-sha1/tegra=$(KernelPakcage/crypto-sha1/arm)
901
902 define KernelPackage/crypto-sha1/x86/64
903 FILES+=$(LINUX_DIR)/arch/x86/crypto/sha1-ssse3.ko
904 AUTOLOAD+=$(call AutoLoad,09,sha1-ssse3)
905 endef
906
907 $(eval $(call KernelPackage,crypto-sha1))
908
909
910 define KernelPackage/crypto-sha256
911 TITLE:=SHA224 SHA256 digest CryptoAPI module
912 DEPENDS:=+kmod-crypto-hash
913 KCONFIG:= \
914 CONFIG_CRYPTO_SHA256 \
915 CONFIG_CRYPTO_SHA256_OCTEON \
916 CONFIG_CRYPTO_SHA256_SSSE3
917 FILES:= \
918 $(LINUX_DIR)/crypto/sha256_generic.ko \
919 $(LINUX_DIR)/lib/crypto/libsha256.ko
920 AUTOLOAD:=$(call AutoLoad,09,sha256_generic)
921 $(call AddDepends/crypto)
922 endef
923
924 define KernelPackage/crypto-sha256/octeon
925 FILES+=$(LINUX_DIR)/arch/mips/cavium-octeon/crypto/octeon-sha256.ko
926 AUTOLOAD+=$(call AutoLoad,09,octeon-sha256)
927 endef
928
929 define KernelPackage/crypto-sha256/x86/64
930 FILES+=$(LINUX_DIR)/arch/x86/crypto/sha256-ssse3.ko
931 AUTOLOAD+=$(call AutoLoad,09,sha256-ssse3)
932 endef
933
934 $(eval $(call KernelPackage,crypto-sha256))
935
936
937 define KernelPackage/crypto-sha512
938 TITLE:=SHA512 digest CryptoAPI module
939 DEPENDS:=+kmod-crypto-hash
940 KCONFIG:= \
941 CONFIG_CRYPTO_SHA512 \
942 CONFIG_CRYPTO_SHA512_ARM \
943 CONFIG_CRYPTO_SHA512_OCTEON \
944 CONFIG_CRYPTO_SHA512_SSSE3
945 FILES:=$(LINUX_DIR)/crypto/sha512_generic.ko
946 AUTOLOAD:=$(call AutoLoad,09,sha512_generic)
947 $(call AddDepends/crypto)
948 endef
949
950 define KernelPackage/crypto-sha512/arm
951 FILES+=$(LINUX_DIR)/arch/arm/crypto/sha512-arm.ko
952 AUTOLOAD+=$(call AutoLoad,09,sha512-arm)
953 endef
954
955 KernelPackage/crypto-sha512/imx=$(KernelPackage/crypto-sha512/arm)
956 KernelPackage/crypto-sha512/ipq40xx=$(KernelPackage/crypto-sha512/arm)
957 KernelPackage/crypto-sha512/mvebu/cortexa9=$(KernelPackage/crypto-sha512/arm)
958
959 define KernelPackage/crypto-sha512/octeon
960 FILES+=$(LINUX_DIR)/arch/mips/cavium-octeon/crypto/octeon-sha512.ko
961 AUTOLOAD+=$(call AutoLoad,09,octeon-sha512)
962 endef
963
964 KernelPackage/crypto-sha512/tegra=$(KernelPackage/crypto-sha512/arm)
965
966 define KernelPackage/crypto-sha512/x86/64
967 FILES+=$(LINUX_DIR)/arch/x86/crypto/sha512-ssse3.ko
968 AUTOLOAD+=$(call AutoLoad,09,sha512-ssse3)
969 endef
970
971 $(eval $(call KernelPackage,crypto-sha512))
972
973
974 define KernelPackage/crypto-test
975 TITLE:=Test CryptoAPI module
976 KCONFIG:=CONFIG_CRYPTO_TEST
977 FILES:=$(LINUX_DIR)/crypto/tcrypt.ko
978 $(call AddDepends/crypto,+kmod-crypto-manager)
979 endef
980
981 $(eval $(call KernelPackage,crypto-test))
982
983
984 define KernelPackage/crypto-user
985 TITLE:=CryptoAPI userspace interface
986 DEPENDS:=+kmod-crypto-hash +kmod-crypto-manager
987 KCONFIG:= \
988 CONFIG_CRYPTO_USER \
989 CONFIG_CRYPTO_USER_API \
990 CONFIG_CRYPTO_USER_API_AEAD \
991 CONFIG_CRYPTO_USER_API_HASH \
992 CONFIG_CRYPTO_USER_API_RNG \
993 CONFIG_CRYPTO_USER_API_SKCIPHER
994 FILES:= \
995 $(LINUX_DIR)/crypto/af_alg.ko \
996 $(LINUX_DIR)/crypto/algif_aead.ko \
997 $(LINUX_DIR)/crypto/algif_hash.ko \
998 $(LINUX_DIR)/crypto/algif_rng.ko \
999 $(LINUX_DIR)/crypto/algif_skcipher.ko \
1000 $(LINUX_DIR)/crypto/crypto_user.ko
1001 AUTOLOAD:=$(call AutoLoad,09,af_alg algif_aead algif_hash algif_rng algif_skcipher crypto_user)
1002 $(call AddDepends/crypto)
1003 endef
1004
1005 $(eval $(call KernelPackage,crypto-user))
1006
1007
1008 define KernelPackage/crypto-xts
1009 TITLE:=XTS cipher CryptoAPI module
1010 DEPENDS:=+kmod-crypto-gf128 +kmod-crypto-manager
1011 KCONFIG:=CONFIG_CRYPTO_XTS
1012 FILES:=$(LINUX_DIR)/crypto/xts.ko
1013 AUTOLOAD:=$(call AutoLoad,09,xts)
1014 $(call AddDepends/crypto)
1015 endef
1016
1017 $(eval $(call KernelPackage,crypto-xts))
1018