Thomas Gleixner | ec8f24b | 2019-05-19 13:07:45 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0-only |
David Howells | f089494 | 2012-05-11 10:56:56 +0100 | [diff] [blame] | 2 | # |
| 3 | # Key management configuration |
| 4 | # |
| 5 | |
| 6 | config KEYS |
| 7 | bool "Enable access key retention support" |
David Howells | b2a4df2 | 2013-09-24 10:35:18 +0100 | [diff] [blame] | 8 | select ASSOCIATIVE_ARRAY |
David Howells | f089494 | 2012-05-11 10:56:56 +0100 | [diff] [blame] | 9 | help |
| 10 | This option provides support for retaining authentication tokens and |
| 11 | access keys in the kernel. |
| 12 | |
| 13 | It also includes provision of methods by which such keys might be |
| 14 | associated with a process so that network filesystems, encryption |
| 15 | support and the like can find them. |
| 16 | |
| 17 | Furthermore, a special type of key is available that acts as keyring: |
| 18 | a searchable sequence of keys. Each process is equipped with access |
| 19 | to five standard keyrings: UID-specific, GID-specific, session, |
| 20 | process and thread. |
| 21 | |
| 22 | If you are unsure as to whether this is required, answer N. |
| 23 | |
David Howells | 7743c48 | 2019-06-19 16:10:15 +0100 | [diff] [blame] | 24 | config KEYS_REQUEST_CACHE |
| 25 | bool "Enable temporary caching of the last request_key() result" |
| 26 | depends on KEYS |
| 27 | help |
| 28 | This option causes the result of the last successful request_key() |
| 29 | call that didn't upcall to the kernel to be cached temporarily in the |
| 30 | task_struct. The cache is cleared by exit and just prior to the |
| 31 | resumption of userspace. |
| 32 | |
| 33 | This allows the key used for multiple step processes where each step |
| 34 | wants to request a key that is likely the same as the one requested |
| 35 | by the last step to save on the searching. |
| 36 | |
| 37 | An example of such a process is a pathwalk through a network |
| 38 | filesystem in which each method needs to request an authentication |
| 39 | key. Pathwalk will call multiple methods for each dentry traversed |
| 40 | (permission, d_revalidate, lookup, getxattr, getacl, ...). |
| 41 | |
David Howells | f36f8c7 | 2013-09-24 10:35:19 +0100 | [diff] [blame] | 42 | config PERSISTENT_KEYRINGS |
| 43 | bool "Enable register of persistent per-UID keyrings" |
| 44 | depends on KEYS |
| 45 | help |
| 46 | This option provides a register of persistent per-UID keyrings, |
| 47 | primarily aimed at Kerberos key storage. The keyrings are persistent |
| 48 | in the sense that they stay around after all processes of that UID |
| 49 | have exited, not that they survive the machine being rebooted. |
| 50 | |
| 51 | A particular keyring may be accessed by either the user whose keyring |
| 52 | it is or by a process with administrative privileges. The active |
| 53 | LSMs gets to rule on which admin-level processes get to access the |
| 54 | cache. |
| 55 | |
| 56 | Keyrings are created and added into the register upon demand and get |
| 57 | removed if they expire (a default timeout is set upon creation). |
| 58 | |
David Howells | ab3c358 | 2013-09-24 10:35:18 +0100 | [diff] [blame] | 59 | config BIG_KEYS |
Josh Boyer | 2eaf6b5 | 2013-10-30 11:15:23 +0000 | [diff] [blame] | 60 | bool "Large payload keys" |
David Howells | ab3c358 | 2013-09-24 10:35:18 +0100 | [diff] [blame] | 61 | depends on KEYS |
| 62 | depends on TMPFS |
Jason A. Donenfeld | 521fd61 | 2020-05-11 15:51:01 -0600 | [diff] [blame] | 63 | depends on CRYPTO_LIB_CHACHA20POLY1305 = y |
David Howells | ab3c358 | 2013-09-24 10:35:18 +0100 | [diff] [blame] | 64 | help |
| 65 | This option provides support for holding large keys within the kernel |
| 66 | (for example Kerberos ticket caches). The data may be stored out to |
| 67 | swapspace by tmpfs. |
| 68 | |
| 69 | If you are unsure as to whether this is required, answer N. |
| 70 | |
David Howells | f089494 | 2012-05-11 10:56:56 +0100 | [diff] [blame] | 71 | config TRUSTED_KEYS |
| 72 | tristate "TRUSTED KEYS" |
| 73 | depends on KEYS && TCG_TPM |
| 74 | select CRYPTO |
| 75 | select CRYPTO_HMAC |
| 76 | select CRYPTO_SHA1 |
Jarkko Sakkinen | 5ca4c20 | 2015-11-05 21:43:06 +0200 | [diff] [blame] | 77 | select CRYPTO_HASH_INFO |
James Bottomley | f221974 | 2021-01-27 11:06:16 -0800 | [diff] [blame] | 78 | select ASN1_ENCODER |
| 79 | select OID_REGISTRY |
| 80 | select ASN1 |
David Howells | f089494 | 2012-05-11 10:56:56 +0100 | [diff] [blame] | 81 | help |
| 82 | This option provides support for creating, sealing, and unsealing |
| 83 | keys in the kernel. Trusted keys are random number symmetric keys, |
| 84 | generated and RSA-sealed by the TPM. The TPM only unseals the keys, |
| 85 | if the boot PCRs and other criteria match. Userspace will only ever |
| 86 | see encrypted blobs. |
| 87 | |
| 88 | If you are unsure as to whether this is required, answer N. |
| 89 | |
| 90 | config ENCRYPTED_KEYS |
| 91 | tristate "ENCRYPTED KEYS" |
| 92 | depends on KEYS |
| 93 | select CRYPTO |
| 94 | select CRYPTO_HMAC |
| 95 | select CRYPTO_AES |
| 96 | select CRYPTO_CBC |
| 97 | select CRYPTO_SHA256 |
| 98 | select CRYPTO_RNG |
| 99 | help |
| 100 | This option provides support for create/encrypting/decrypting keys |
| 101 | in the kernel. Encrypted keys are kernel generated random numbers, |
| 102 | which are encrypted/decrypted with a 'master' symmetric key. The |
| 103 | 'master' key can be either a trusted-key or user-key type. |
| 104 | Userspace only ever sees/stores encrypted blobs. |
| 105 | |
| 106 | If you are unsure as to whether this is required, answer N. |
Mat Martineau | ddbb411 | 2016-04-12 19:54:58 +0100 | [diff] [blame] | 107 | |
| 108 | config KEY_DH_OPERATIONS |
| 109 | bool "Diffie-Hellman operations on retained keys" |
| 110 | depends on KEYS |
Stephan Müller | 4cd4ca7 | 2017-04-11 13:07:07 +0200 | [diff] [blame] | 111 | select CRYPTO |
Stephan Müller | d3b04a4 | 2021-11-19 07:59:09 +0100 | [diff] [blame] | 112 | select CRYPTO_KDF800108_CTR |
Mat Martineau | 7cbe093 | 2017-06-08 14:50:11 +0100 | [diff] [blame] | 113 | select CRYPTO_DH |
Mat Martineau | ddbb411 | 2016-04-12 19:54:58 +0100 | [diff] [blame] | 114 | help |
| 115 | This option provides support for calculating Diffie-Hellman |
| 116 | public keys and shared secrets using values stored as keys |
| 117 | in the kernel. |
| 118 | |
| 119 | If you are unsure as to whether this is required, answer N. |
David Howells | f7e4767 | 2020-01-14 17:07:11 +0000 | [diff] [blame] | 120 | |
| 121 | config KEY_NOTIFICATIONS |
| 122 | bool "Provide key/keyring change notifications" |
| 123 | depends on KEYS && WATCH_QUEUE |
| 124 | help |
Gabriel Krisman Bertazi | 8fe62e0 | 2020-11-24 15:28:02 -0500 | [diff] [blame] | 125 | This option provides support for getting change notifications |
| 126 | on keys and keyrings on which the caller has View permission. |
| 127 | This makes use of pipes to handle the notification buffer and |
| 128 | provides KEYCTL_WATCH_KEY to enable/disable watches. |