GNU Linux-libre 6.0.2-gnu
[releases.git] / lib / crypto / Kconfig
1 # SPDX-License-Identifier: GPL-2.0
2
3 menu "Crypto library routines"
4
5 config CRYPTO_LIB_AES
6         tristate
7
8 config CRYPTO_LIB_ARC4
9         tristate
10
11 config CRYPTO_ARCH_HAVE_LIB_BLAKE2S
12         bool
13         help
14           Declares whether the architecture provides an arch-specific
15           accelerated implementation of the Blake2s library interface,
16           either builtin or as a module.
17
18 config CRYPTO_LIB_BLAKE2S_GENERIC
19         def_bool !CRYPTO_ARCH_HAVE_LIB_BLAKE2S
20         help
21           This symbol can be depended upon by arch implementations of the
22           Blake2s library interface that require the generic code as a
23           fallback, e.g., for SIMD implementations. If no arch specific
24           implementation is enabled, this implementation serves the users
25           of CRYPTO_LIB_BLAKE2S.
26
27 config CRYPTO_ARCH_HAVE_LIB_CHACHA
28         tristate
29         help
30           Declares whether the architecture provides an arch-specific
31           accelerated implementation of the ChaCha library interface,
32           either builtin or as a module.
33
34 config CRYPTO_LIB_CHACHA_GENERIC
35         tristate
36         help
37           This symbol can be depended upon by arch implementations of the
38           ChaCha library interface that require the generic code as a
39           fallback, e.g., for SIMD implementations. If no arch specific
40           implementation is enabled, this implementation serves the users
41           of CRYPTO_LIB_CHACHA.
42
43 config CRYPTO_LIB_CHACHA
44         tristate "ChaCha library interface"
45         depends on CRYPTO
46         depends on CRYPTO_ARCH_HAVE_LIB_CHACHA || !CRYPTO_ARCH_HAVE_LIB_CHACHA
47         select CRYPTO_LIB_CHACHA_GENERIC if CRYPTO_ARCH_HAVE_LIB_CHACHA=n
48         help
49           Enable the ChaCha library interface. This interface may be fulfilled
50           by either the generic implementation or an arch-specific one, if one
51           is available and enabled.
52
53 config CRYPTO_ARCH_HAVE_LIB_CURVE25519
54         tristate
55         help
56           Declares whether the architecture provides an arch-specific
57           accelerated implementation of the Curve25519 library interface,
58           either builtin or as a module.
59
60 config CRYPTO_LIB_CURVE25519_GENERIC
61         tristate
62         help
63           This symbol can be depended upon by arch implementations of the
64           Curve25519 library interface that require the generic code as a
65           fallback, e.g., for SIMD implementations. If no arch specific
66           implementation is enabled, this implementation serves the users
67           of CRYPTO_LIB_CURVE25519.
68
69 config CRYPTO_LIB_CURVE25519
70         tristate "Curve25519 scalar multiplication library"
71         depends on CRYPTO_ARCH_HAVE_LIB_CURVE25519 || !CRYPTO_ARCH_HAVE_LIB_CURVE25519
72         select CRYPTO_LIB_CURVE25519_GENERIC if CRYPTO_ARCH_HAVE_LIB_CURVE25519=n
73         select LIB_MEMNEQ
74         help
75           Enable the Curve25519 library interface. This interface may be
76           fulfilled by either the generic implementation or an arch-specific
77           one, if one is available and enabled.
78
79 config CRYPTO_LIB_DES
80         tristate
81
82 config CRYPTO_LIB_POLY1305_RSIZE
83         int
84         default 2 if MIPS
85         default 11 if X86_64
86         default 9 if ARM || ARM64
87         default 1
88
89 config CRYPTO_ARCH_HAVE_LIB_POLY1305
90         tristate
91         help
92           Declares whether the architecture provides an arch-specific
93           accelerated implementation of the Poly1305 library interface,
94           either builtin or as a module.
95
96 config CRYPTO_LIB_POLY1305_GENERIC
97         tristate
98         help
99           This symbol can be depended upon by arch implementations of the
100           Poly1305 library interface that require the generic code as a
101           fallback, e.g., for SIMD implementations. If no arch specific
102           implementation is enabled, this implementation serves the users
103           of CRYPTO_LIB_POLY1305.
104
105 config CRYPTO_LIB_POLY1305
106         tristate "Poly1305 library interface"
107         depends on CRYPTO_ARCH_HAVE_LIB_POLY1305 || !CRYPTO_ARCH_HAVE_LIB_POLY1305
108         select CRYPTO_LIB_POLY1305_GENERIC if CRYPTO_ARCH_HAVE_LIB_POLY1305=n
109         help
110           Enable the Poly1305 library interface. This interface may be fulfilled
111           by either the generic implementation or an arch-specific one, if one
112           is available and enabled.
113
114 config CRYPTO_LIB_CHACHA20POLY1305
115         tristate "ChaCha20-Poly1305 AEAD support (8-byte nonce library version)"
116         depends on CRYPTO_ARCH_HAVE_LIB_CHACHA || !CRYPTO_ARCH_HAVE_LIB_CHACHA
117         depends on CRYPTO_ARCH_HAVE_LIB_POLY1305 || !CRYPTO_ARCH_HAVE_LIB_POLY1305
118         depends on CRYPTO
119         select CRYPTO_LIB_CHACHA
120         select CRYPTO_LIB_POLY1305
121         select CRYPTO_ALGAPI
122
123 config CRYPTO_LIB_SHA1
124         tristate
125
126 config CRYPTO_LIB_SHA256
127         tristate
128
129 endmenu