Lines Matching full:the
7 The concepts of the kernel crypto API visible to kernel space is fully
8 applicable to the user space interface as well. Therefore, the kernel
9 crypto API high level discussion for the in-kernel use cases applies
12 The major difference, however, is that user space can only act as a
16 The following covers the user space interface exported by the kernel
19 applications that require cryptographic services from the kernel.
21 Some details of the in-kernel kernel crypto API aspects do not apply to
22 user space, however. This includes the difference between synchronous
23 and asynchronous invocations. The user space API call is fully
31 The kernel crypto API is accessible from user space. Currently, the
42 The interface is provided via socket type using the type AF_ALG. In
43 addition, the setsockopt option type is SOL_ALG. In case the user space
44 header files do not export these flags yet, use the following macros:
56 A cipher is accessed with the same name as done for the in-kernel API
57 calls. This includes the generic vs. unique naming schema for ciphers as
58 well as the enforcement of priorities for generic names.
60 To interact with the kernel crypto API, a socket must be created by the
61 user space application. User space invokes the cipher operation with the
62 send()/write() system call family. The result of the cipher operation is
63 obtained with the read()/recv() system call family.
65 The following API calls assume that the socket descriptor is already
66 opened by the user space application and discusses only the kernel
69 To initialize the socket interface, the following sequence has to be
70 performed by the consumer:
72 1. Create a socket of type AF_ALG with the struct sockaddr_alg
73 parameter specified below for the different cipher types.
75 2. Invoke bind with the socket descriptor
77 3. Invoke accept with the socket descriptor. The accept system call
78 returns a new file descriptor that is to be used to interact with the
80 system calls to send data to the kernel or obtain data from the
81 kernel, the file descriptor returned by accept must be used.
86 Just like the in-kernel operation of the kernel crypto API, the user
87 space interface allows the cipher operation in-place. That means that
88 the input buffer used for the send/write system call and the output
89 buffer used by the read/recv system call may be one and the same. This
91 copying of the output data to its final destination can be avoided.
93 If a consumer on the other hand wants to maintain the plaintext and the
95 to provide different memory pointers for the encryption and decryption
101 The message digest type to be used for the cipher operation is selected
102 when invoking the bind syscall. bind requires the caller to provide a
110 .salg_type = "hash", /* this selects the hash logic in the kernel */
111 .salg_name = "sha1" /* this is the cipher name */
115 The salg_type value "hash" applies to message digests and keyed message
116 digests. Though, a keyed message digest is referenced by the appropriate
117 salg_name. Please see below for the setsockopt interface that explains
118 how the key can be set for a keyed message digest.
120 Using the send() system call, the application provides the data that
121 should be processed with the message digest. The send system call allows
122 the following flags to be specified:
124 - MSG_MORE: If this flag is set, the send system call acts like a
125 message digest update function where the final hash is not yet
126 calculated. If the flag is not set, the send system call calculates
127 the final message digest immediately.
129 With the recv() system call, the application can read the message digest
130 from the kernel crypto API. If the buffer is too small for the message
131 digest, the flag MSG_TRUNC is set by the kernel.
133 In order to set a message digest key, the calling application must use
134 the setsockopt() option of ALG_SET_KEY or ALG_SET_KEY_BY_KEY_SERIAL. If the
135 key is not set the HMAC operation is performed without the initial HMAC state
136 change caused by the key.
141 The operation is very similar to the message digest discussion. During
142 initialization, the struct sockaddr data structure must be filled as
149 .salg_type = "skcipher", /* this selects the symmetric cipher */
150 .salg_name = "cbc(aes)" /* this is the cipher name */
154 Before data can be sent to the kernel using the write/send system call
155 family, the consumer must set the key. The key setting is described with
156 the setsockopt invocation below.
158 Using the sendmsg() system call, the application provides the data that
159 should be processed for encryption or decryption. In addition, the IV is
160 specified with the data structure provided by the sendmsg() system call.
162 The sendmsg system call parameter of struct msghdr is embedded into the
164 information on how the cmsghdr data structure is used together with the
165 send/recv system call family. That cmsghdr data structure holds the
168 - specification of the cipher operation type with one of these flags:
174 - specification of the IV information marked with the flag ALG_SET_IV
176 The send system call family allows the following flag to be specified:
178 - MSG_MORE: If this flag is set, the send system call acts like a
180 subsequent invocation of the send system call.
182 Note: The kernel reports -EINVAL for any unexpected data. The caller
183 must make sure that all data matches the constraints given in
184 /proc/crypto for the selected cipher.
186 With the recv() system call, the application can read the result of the
187 cipher operation from the kernel crypto API. The output buffer must be
188 at least as large as to hold all blocks of the encrypted or decrypted
189 data. If the output data size is smaller, only as many blocks are
195 The operation is very similar to the symmetric cipher discussion. During
196 initialization, the struct sockaddr data structure must be filled as
203 .salg_type = "aead", /* this selects the symmetric cipher */
204 .salg_name = "gcm(aes)" /* this is the cipher name */
208 Before data can be sent to the kernel using the write/send system call
209 family, the consumer must set the key. The key setting is described with
210 the setsockopt invocation below.
212 In addition, before data can be sent to the kernel using the write/send
213 system call family, the consumer must set the authentication tag size.
214 To set the authentication tag size, the caller must use the setsockopt
217 Using the sendmsg() system call, the application provides the data that
218 should be processed for encryption or decryption. In addition, the IV is
219 specified with the data structure provided by the sendmsg() system call.
221 The sendmsg system call parameter of struct msghdr is embedded into the
223 information on how the cmsghdr data structure is used together with the
224 send/recv system call family. That cmsghdr data structure holds the
227 - specification of the cipher operation type with one of these flags:
233 - specification of the IV information marked with the flag ALG_SET_IV
235 - specification of the associated authentication data (AAD) with the
236 flag ALG_SET_AEAD_ASSOCLEN. The AAD is sent to the kernel together
237 with the plaintext / ciphertext. See below for the memory structure.
239 The send system call family allows the following flag to be specified:
241 - MSG_MORE: If this flag is set, the send system call acts like a
243 subsequent invocation of the send system call.
245 Note: The kernel reports -EINVAL for any unexpected data. The caller
246 must make sure that all data matches the constraints given in
247 /proc/crypto for the selected cipher.
249 With the recv() system call, the application can read the result of the
250 cipher operation from the kernel crypto API. The output buffer must be
251 at least as large as defined with the memory structure below. If the
252 output data size is smaller, the cipher operation is not performed.
254 The authenticated decryption operation may indicate an integrity error.
255 Such breach in integrity is marked with the -EBADMSG error code.
260 The AEAD cipher operates with the following information that is
269 The sizes of the AAD and the authentication tag are provided with the
270 sendmsg and setsockopt calls (see there). As the kernel knows the size
271 of the entire data stream, the kernel is now able to calculate the right
272 offsets of the data components in the data stream.
274 The user space caller must arrange the aforementioned information in the
281 The output buffer the user space caller provides must be at least as
282 large to hold the following data:
291 Again, the operation is very similar to the other APIs. During
292 initialization, the struct sockaddr data structure must be filled as
299 .salg_type = "rng", /* this selects the random number generator */
300 .salg_name = "drbg_nopr_sha256" /* this is the RNG name */
304 Depending on the RNG type, the RNG must be seeded. The seed is provided
305 using the setsockopt interface to set the key. For example, the
306 ansi_cprng requires a seed. The DRBGs do not require a seed, but may be
307 seeded. The seed is also known as a *Personalization String* in NIST SP 800-90A
310 Using the read()/recvmsg() system calls, random numbers can be obtained.
311 The kernel generates at most 128 bytes in one call. If user space
314 WARNING: The user space caller may invoke the initially mentioned accept
315 system call multiple times. In this case, the returned file descriptors
316 have the same state.
321 - the concatenation of *Entropy* and *Nonce* can be provided to the RNG via
322 ALG_SET_DRBG_ENTROPY setsockopt interface. Setting the entropy requires
325 - *Additional Data* can be provided using the send()/sendmsg() system calls,
326 but only after the entropy has been set.
331 In addition to the send/write/read/recv system call family, the AF_ALG
332 interface can be accessed with the zero-copy interface of
333 splice/vmsplice. As the name indicates, the kernel tries to avoid a copy
336 The zero-copy operation requires data to be aligned at the page
338 operations of the kernel which would defeat the speed gains obtained
339 from the zero-copy interface.
341 The system-inherent limit for the size of one zero-copy operation is 16
342 pages. If more data is to be sent to AF_ALG, user space must slice the
345 Zero-copy can be used with the following code example (a complete
355 /* opfd is the file descriptor returned from accept() system call */
363 In addition to the read/recv and send/write system call handling to send
364 and retrieve data subject to the cipher operation, a consumer also needs
365 to set the additional information for the cipher operation. This
366 additional information is set using the setsockopt system call that must
367 be invoked with the file descriptor of the open cipher (i.e. the file
368 descriptor returned by the accept system call).
370 Each setsockopt invocation must use the level SOL_ALG.
372 The setsockopt interface allows setting the following data using the
375 - ALG_SET_KEY -- Setting the key. Key setting is applicable to:
377 - the skcipher cipher type (symmetric ciphers)
379 - the hash cipher type (keyed message digests)
381 - the AEAD cipher type
383 - the RNG cipher type to provide the seed
385 - ALG_SET_KEY_BY_KEY_SERIAL -- Setting the key via keyring key_serial_t.
386 This operation behaves the same as ALG_SET_KEY. The decrypted
387 data is copied from a keyring key, and uses that data as the
390 The passed in key_serial_t must have the KEY_(POS|USR|GRP|OTH)_SEARCH
394 - ALG_SET_AEAD_AUTHSIZE -- Setting the authentication tag size for
395 AEAD ciphers. For a encryption operation, the authentication tag of
396 the given size will be generated. For a decryption operation, the
398 the given size (see section about AEAD memory layout below).
400 - ALG_SET_DRBG_ENTROPY -- Setting the entropy of the random number generator.
407 the aforementioned Netlink kernel interface. [1] also contains a test