xref: /freebsd/sys/opencrypto/cryptodev.c (revision 8ecd87a3e7f5503951d37eab034cb330a1c6ec86)
1 /*	$OpenBSD: cryptodev.c,v 1.52 2002/06/19 07:22:46 deraadt Exp $	*/
2 
3 /*-
4  * Copyright (c) 2001 Theo de Raadt
5  * Copyright (c) 2002-2006 Sam Leffler, Errno Consulting
6  * Copyright (c) 2014 The FreeBSD Foundation
7  * All rights reserved.
8  *
9  * Portions of this software were developed by John-Mark Gurney
10  * under sponsorship of the FreeBSD Foundation and
11  * Rubicon Communications, LLC (Netgate).
12  *
13  * Redistribution and use in source and binary forms, with or without
14  * modification, are permitted provided that the following conditions
15  * are met:
16  *
17  * 1. Redistributions of source code must retain the above copyright
18  *   notice, this list of conditions and the following disclaimer.
19  * 2. Redistributions in binary form must reproduce the above copyright
20  *   notice, this list of conditions and the following disclaimer in the
21  *   documentation and/or other materials provided with the distribution.
22  * 3. The name of the author may not be used to endorse or promote products
23  *   derived from this software without specific prior written permission.
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
26  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
27  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
28  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
29  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
30  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
31  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
32  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
33  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
34  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35  *
36  * Effort sponsored in part by the Defense Advanced Research Projects
37  * Agency (DARPA) and Air Force Research Laboratory, Air Force
38  * Materiel Command, USAF, under agreement number F30602-01-2-0537.
39  */
40 
41 #include <sys/cdefs.h>
42 __FBSDID("$FreeBSD$");
43 
44 #include <sys/param.h>
45 #include <sys/systm.h>
46 #include <sys/malloc.h>
47 #include <sys/mbuf.h>
48 #include <sys/lock.h>
49 #include <sys/mutex.h>
50 #include <sys/sysctl.h>
51 #include <sys/file.h>
52 #include <sys/filedesc.h>
53 #include <sys/errno.h>
54 #include <sys/random.h>
55 #include <sys/conf.h>
56 #include <sys/kernel.h>
57 #include <sys/module.h>
58 #include <sys/fcntl.h>
59 #include <sys/bus.h>
60 #include <sys/user.h>
61 #include <sys/sdt.h>
62 
63 #include <opencrypto/cryptodev.h>
64 #include <opencrypto/xform.h>
65 
66 SDT_PROVIDER_DECLARE(opencrypto);
67 
68 SDT_PROBE_DEFINE1(opencrypto, dev, ioctl, error, "int"/*line number*/);
69 
70 #ifdef COMPAT_FREEBSD32
71 #include <sys/mount.h>
72 #include <compat/freebsd32/freebsd32.h>
73 
74 struct session_op32 {
75 	u_int32_t	cipher;
76 	u_int32_t	mac;
77 	u_int32_t	keylen;
78 	u_int32_t	key;
79 	int		mackeylen;
80 	u_int32_t	mackey;
81 	u_int32_t	ses;
82 };
83 
84 struct session2_op32 {
85 	u_int32_t	cipher;
86 	u_int32_t	mac;
87 	u_int32_t	keylen;
88 	u_int32_t	key;
89 	int		mackeylen;
90 	u_int32_t	mackey;
91 	u_int32_t	ses;
92 	int		crid;
93 	int		pad[4];
94 };
95 
96 struct crypt_op32 {
97 	u_int32_t	ses;
98 	u_int16_t	op;
99 	u_int16_t	flags;
100 	u_int		len;
101 	u_int32_t	src, dst;
102 	u_int32_t	mac;
103 	u_int32_t	iv;
104 };
105 
106 struct crypt_aead32 {
107 	u_int32_t	ses;
108 	u_int16_t	op;
109 	u_int16_t	flags;
110 	u_int		len;
111 	u_int		aadlen;
112 	u_int		ivlen;
113 	u_int32_t	src;
114 	u_int32_t	dst;
115 	u_int32_t	aad;
116 	u_int32_t	tag;
117 	u_int32_t	iv;
118 };
119 
120 struct crparam32 {
121 	u_int32_t	crp_p;
122 	u_int		crp_nbits;
123 };
124 
125 struct crypt_kop32 {
126 	u_int		crk_op;
127 	u_int		crk_status;
128 	u_short		crk_iparams;
129 	u_short		crk_oparams;
130 	u_int		crk_crid;
131 	struct crparam32	crk_param[CRK_MAXPARAM];
132 };
133 
134 #define	CIOCGSESSION32	_IOWR('c', 101, struct session_op32)
135 #define	CIOCCRYPT32	_IOWR('c', 103, struct crypt_op32)
136 #define	CIOCKEY32	_IOWR('c', 104, struct crypt_kop32)
137 #define	CIOCGSESSION232	_IOWR('c', 106, struct session2_op32)
138 #define	CIOCKEY232	_IOWR('c', 107, struct crypt_kop32)
139 #define	CIOCCRYPTAEAD32	_IOWR('c', 109, struct crypt_aead32)
140 
141 static void
142 session_op_from_32(const struct session_op32 *from, struct session2_op *to)
143 {
144 
145 	memset(to, 0, sizeof(*to));
146 	CP(*from, *to, cipher);
147 	CP(*from, *to, mac);
148 	CP(*from, *to, keylen);
149 	PTRIN_CP(*from, *to, key);
150 	CP(*from, *to, mackeylen);
151 	PTRIN_CP(*from, *to, mackey);
152 	CP(*from, *to, ses);
153 	to->crid = CRYPTOCAP_F_HARDWARE;
154 }
155 
156 static void
157 session2_op_from_32(const struct session2_op32 *from, struct session2_op *to)
158 {
159 
160 	session_op_from_32((const struct session_op32 *)from, to);
161 	CP(*from, *to, crid);
162 }
163 
164 static void
165 session_op_to_32(const struct session2_op *from, struct session_op32 *to)
166 {
167 
168 	CP(*from, *to, cipher);
169 	CP(*from, *to, mac);
170 	CP(*from, *to, keylen);
171 	PTROUT_CP(*from, *to, key);
172 	CP(*from, *to, mackeylen);
173 	PTROUT_CP(*from, *to, mackey);
174 	CP(*from, *to, ses);
175 }
176 
177 static void
178 session2_op_to_32(const struct session2_op *from, struct session2_op32 *to)
179 {
180 
181 	session_op_to_32(from, (struct session_op32 *)to);
182 	CP(*from, *to, crid);
183 }
184 
185 static void
186 crypt_op_from_32(const struct crypt_op32 *from, struct crypt_op *to)
187 {
188 
189 	CP(*from, *to, ses);
190 	CP(*from, *to, op);
191 	CP(*from, *to, flags);
192 	CP(*from, *to, len);
193 	PTRIN_CP(*from, *to, src);
194 	PTRIN_CP(*from, *to, dst);
195 	PTRIN_CP(*from, *to, mac);
196 	PTRIN_CP(*from, *to, iv);
197 }
198 
199 static void
200 crypt_op_to_32(const struct crypt_op *from, struct crypt_op32 *to)
201 {
202 
203 	CP(*from, *to, ses);
204 	CP(*from, *to, op);
205 	CP(*from, *to, flags);
206 	CP(*from, *to, len);
207 	PTROUT_CP(*from, *to, src);
208 	PTROUT_CP(*from, *to, dst);
209 	PTROUT_CP(*from, *to, mac);
210 	PTROUT_CP(*from, *to, iv);
211 }
212 
213 static void
214 crypt_aead_from_32(const struct crypt_aead32 *from, struct crypt_aead *to)
215 {
216 
217 	CP(*from, *to, ses);
218 	CP(*from, *to, op);
219 	CP(*from, *to, flags);
220 	CP(*from, *to, len);
221 	CP(*from, *to, aadlen);
222 	CP(*from, *to, ivlen);
223 	PTRIN_CP(*from, *to, src);
224 	PTRIN_CP(*from, *to, dst);
225 	PTRIN_CP(*from, *to, aad);
226 	PTRIN_CP(*from, *to, tag);
227 	PTRIN_CP(*from, *to, iv);
228 }
229 
230 static void
231 crypt_aead_to_32(const struct crypt_aead *from, struct crypt_aead32 *to)
232 {
233 
234 	CP(*from, *to, ses);
235 	CP(*from, *to, op);
236 	CP(*from, *to, flags);
237 	CP(*from, *to, len);
238 	CP(*from, *to, aadlen);
239 	CP(*from, *to, ivlen);
240 	PTROUT_CP(*from, *to, src);
241 	PTROUT_CP(*from, *to, dst);
242 	PTROUT_CP(*from, *to, aad);
243 	PTROUT_CP(*from, *to, tag);
244 	PTROUT_CP(*from, *to, iv);
245 }
246 
247 static void
248 crparam_from_32(const struct crparam32 *from, struct crparam *to)
249 {
250 
251 	PTRIN_CP(*from, *to, crp_p);
252 	CP(*from, *to, crp_nbits);
253 }
254 
255 static void
256 crparam_to_32(const struct crparam *from, struct crparam32 *to)
257 {
258 
259 	PTROUT_CP(*from, *to, crp_p);
260 	CP(*from, *to, crp_nbits);
261 }
262 
263 static void
264 crypt_kop_from_32(const struct crypt_kop32 *from, struct crypt_kop *to)
265 {
266 	int i;
267 
268 	CP(*from, *to, crk_op);
269 	CP(*from, *to, crk_status);
270 	CP(*from, *to, crk_iparams);
271 	CP(*from, *to, crk_oparams);
272 	CP(*from, *to, crk_crid);
273 	for (i = 0; i < CRK_MAXPARAM; i++)
274 		crparam_from_32(&from->crk_param[i], &to->crk_param[i]);
275 }
276 
277 static void
278 crypt_kop_to_32(const struct crypt_kop *from, struct crypt_kop32 *to)
279 {
280 	int i;
281 
282 	CP(*from, *to, crk_op);
283 	CP(*from, *to, crk_status);
284 	CP(*from, *to, crk_iparams);
285 	CP(*from, *to, crk_oparams);
286 	CP(*from, *to, crk_crid);
287 	for (i = 0; i < CRK_MAXPARAM; i++)
288 		crparam_to_32(&from->crk_param[i], &to->crk_param[i]);
289 }
290 #endif
291 
292 static void
293 session2_op_from_op(const struct session_op *from, struct session2_op *to)
294 {
295 
296 	memset(to, 0, sizeof(*to));
297 	memcpy(to, from, sizeof(*from));
298 	to->crid = CRYPTOCAP_F_HARDWARE;
299 }
300 
301 static void
302 session2_op_to_op(const struct session2_op *from, struct session_op *to)
303 {
304 
305 	memcpy(to, from, sizeof(*to));
306 }
307 
308 struct csession {
309 	TAILQ_ENTRY(csession) next;
310 	crypto_session_t cses;
311 	volatile u_int	refs;
312 	u_int32_t	ses;
313 	struct mtx	lock;		/* for op submission */
314 
315 	struct enc_xform *txform;
316 	int		hashsize;
317 	int		ivsize;
318 	int		mode;
319 
320 	void		*key;
321 	void		*mackey;
322 };
323 
324 struct cryptop_data {
325 	struct csession *cse;
326 
327 	char		*buf;
328 	char		*obuf;
329 	char		*aad;
330 	bool		done;
331 };
332 
333 struct fcrypt {
334 	TAILQ_HEAD(csessionlist, csession) csessions;
335 	int		sesn;
336 	struct mtx	lock;
337 };
338 
339 static bool use_outputbuffers;
340 SYSCTL_BOOL(_kern_crypto, OID_AUTO, cryptodev_use_output, CTLFLAG_RW,
341     &use_outputbuffers, 0,
342     "Use separate output buffers for /dev/crypto requests.");
343 
344 static bool use_separate_aad;
345 SYSCTL_BOOL(_kern_crypto, OID_AUTO, cryptodev_separate_aad, CTLFLAG_RW,
346     &use_separate_aad, 0,
347     "Use separate AAD buffer for /dev/crypto requests.");
348 
349 static struct timeval warninterval = { .tv_sec = 60, .tv_usec = 0 };
350 SYSCTL_TIMEVAL_SEC(_kern, OID_AUTO, cryptodev_warn_interval, CTLFLAG_RW,
351     &warninterval,
352     "Delay in seconds between warnings of deprecated /dev/crypto algorithms");
353 
354 static	int cryptof_ioctl(struct file *, u_long, void *,
355 		    struct ucred *, struct thread *);
356 static	int cryptof_stat(struct file *, struct stat *,
357 		    struct ucred *, struct thread *);
358 static	int cryptof_close(struct file *, struct thread *);
359 static	int cryptof_fill_kinfo(struct file *, struct kinfo_file *,
360 		    struct filedesc *);
361 
362 static struct fileops cryptofops = {
363     .fo_read = invfo_rdwr,
364     .fo_write = invfo_rdwr,
365     .fo_truncate = invfo_truncate,
366     .fo_ioctl = cryptof_ioctl,
367     .fo_poll = invfo_poll,
368     .fo_kqfilter = invfo_kqfilter,
369     .fo_stat = cryptof_stat,
370     .fo_close = cryptof_close,
371     .fo_chmod = invfo_chmod,
372     .fo_chown = invfo_chown,
373     .fo_sendfile = invfo_sendfile,
374     .fo_fill_kinfo = cryptof_fill_kinfo,
375 };
376 
377 static struct csession *csefind(struct fcrypt *, u_int);
378 static bool csedelete(struct fcrypt *, u_int);
379 static struct csession *csecreate(struct fcrypt *, crypto_session_t,
380     struct crypto_session_params *, struct enc_xform *, void *,
381     struct auth_hash *, void *);
382 static void csefree(struct csession *);
383 
384 static	int cryptodev_op(struct csession *, struct crypt_op *,
385 			struct ucred *, struct thread *td);
386 static	int cryptodev_aead(struct csession *, struct crypt_aead *,
387 			struct ucred *, struct thread *);
388 static	int cryptodev_key(struct crypt_kop *);
389 static	int cryptodev_find(struct crypt_find_op *);
390 
391 /*
392  * Check a crypto identifier to see if it requested
393  * a software device/driver.  This can be done either
394  * by device name/class or through search constraints.
395  */
396 static int
397 checkforsoftware(int *cridp)
398 {
399 	int crid;
400 
401 	crid = *cridp;
402 
403 	if (!crypto_devallowsoft) {
404 		if (crid & CRYPTOCAP_F_SOFTWARE) {
405 			if (crid & CRYPTOCAP_F_HARDWARE) {
406 				*cridp = CRYPTOCAP_F_HARDWARE;
407 				return 0;
408 			}
409 			return EINVAL;
410 		}
411 		if ((crid & CRYPTOCAP_F_HARDWARE) == 0 &&
412 		    (crypto_getcaps(crid) & CRYPTOCAP_F_HARDWARE) == 0)
413 			return EINVAL;
414 	}
415 	return 0;
416 }
417 
418 /* ARGSUSED */
419 static int
420 cryptof_ioctl(
421 	struct file *fp,
422 	u_long cmd,
423 	void *data,
424 	struct ucred *active_cred,
425 	struct thread *td)
426 {
427 	static struct timeval keywarn, featwarn;
428 	struct crypto_session_params csp;
429 	struct fcrypt *fcr = fp->f_data;
430 	struct csession *cse;
431 	struct session2_op *sop;
432 	struct crypt_op *cop;
433 	struct crypt_aead *caead;
434 	struct enc_xform *txform = NULL;
435 	struct auth_hash *thash = NULL;
436 	void *key = NULL;
437 	void *mackey = NULL;
438 	struct crypt_kop *kop;
439 	crypto_session_t cses;
440 	u_int32_t ses;
441 	int error = 0, crid;
442 	union {
443 		struct session2_op sopc;
444 #ifdef COMPAT_FREEBSD32
445 		struct crypt_op copc;
446 		struct crypt_aead aeadc;
447 		struct crypt_kop kopc;
448 #endif
449 	} thunk;
450 #ifdef COMPAT_FREEBSD32
451 	u_long cmd32;
452 	void *data32;
453 
454 	cmd32 = 0;
455 	data32 = NULL;
456 	switch (cmd) {
457 	case CIOCGSESSION32:
458 		cmd32 = cmd;
459 		data32 = data;
460 		cmd = CIOCGSESSION;
461 		data = &thunk.sopc;
462 		session_op_from_32((struct session_op32 *)data32, &thunk.sopc);
463 		break;
464 	case CIOCGSESSION232:
465 		cmd32 = cmd;
466 		data32 = data;
467 		cmd = CIOCGSESSION2;
468 		data = &thunk.sopc;
469 		session2_op_from_32((struct session2_op32 *)data32,
470 		    &thunk.sopc);
471 		break;
472 	case CIOCCRYPT32:
473 		cmd32 = cmd;
474 		data32 = data;
475 		cmd = CIOCCRYPT;
476 		data = &thunk.copc;
477 		crypt_op_from_32((struct crypt_op32 *)data32, &thunk.copc);
478 		break;
479 	case CIOCCRYPTAEAD32:
480 		cmd32 = cmd;
481 		data32 = data;
482 		cmd = CIOCCRYPTAEAD;
483 		data = &thunk.aeadc;
484 		crypt_aead_from_32((struct crypt_aead32 *)data32, &thunk.aeadc);
485 		break;
486 	case CIOCKEY32:
487 	case CIOCKEY232:
488 		cmd32 = cmd;
489 		data32 = data;
490 		if (cmd == CIOCKEY32)
491 			cmd = CIOCKEY;
492 		else
493 			cmd = CIOCKEY2;
494 		data = &thunk.kopc;
495 		crypt_kop_from_32((struct crypt_kop32 *)data32, &thunk.kopc);
496 		break;
497 	}
498 #endif
499 
500 	switch (cmd) {
501 	case CIOCGSESSION:
502 	case CIOCGSESSION2:
503 		if (cmd == CIOCGSESSION) {
504 			session2_op_from_op(data, &thunk.sopc);
505 			sop = &thunk.sopc;
506 		} else
507 			sop = (struct session2_op *)data;
508 
509 		switch (sop->cipher) {
510 		case 0:
511 			break;
512 		case CRYPTO_AES_CBC:
513 			txform = &enc_xform_rijndael128;
514 			break;
515 		case CRYPTO_AES_XTS:
516 			txform = &enc_xform_aes_xts;
517 			break;
518 		case CRYPTO_NULL_CBC:
519 			txform = &enc_xform_null;
520 			break;
521  		case CRYPTO_CAMELLIA_CBC:
522  			txform = &enc_xform_camellia;
523  			break;
524 		case CRYPTO_AES_ICM:
525 			txform = &enc_xform_aes_icm;
526  			break;
527 		case CRYPTO_AES_NIST_GCM_16:
528 			txform = &enc_xform_aes_nist_gcm;
529  			break;
530 		case CRYPTO_CHACHA20:
531 			txform = &enc_xform_chacha20;
532 			break;
533 		case CRYPTO_AES_CCM_16:
534 			txform = &enc_xform_ccm;
535 			break;
536 
537 		default:
538 			CRYPTDEB("invalid cipher");
539 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
540 			return (EINVAL);
541 		}
542 
543 		switch (sop->mac) {
544 		case 0:
545 			break;
546 		case CRYPTO_POLY1305:
547 			thash = &auth_hash_poly1305;
548 			break;
549 		case CRYPTO_SHA1_HMAC:
550 			thash = &auth_hash_hmac_sha1;
551 			break;
552 		case CRYPTO_SHA2_224_HMAC:
553 			thash = &auth_hash_hmac_sha2_224;
554 			break;
555 		case CRYPTO_SHA2_256_HMAC:
556 			thash = &auth_hash_hmac_sha2_256;
557 			break;
558 		case CRYPTO_SHA2_384_HMAC:
559 			thash = &auth_hash_hmac_sha2_384;
560 			break;
561 		case CRYPTO_SHA2_512_HMAC:
562 			thash = &auth_hash_hmac_sha2_512;
563 			break;
564 		case CRYPTO_RIPEMD160_HMAC:
565 			thash = &auth_hash_hmac_ripemd_160;
566 			break;
567 #ifdef COMPAT_FREEBSD12
568 		case CRYPTO_AES_128_NIST_GMAC:
569 		case CRYPTO_AES_192_NIST_GMAC:
570 		case CRYPTO_AES_256_NIST_GMAC:
571 			/* Should always be paired with GCM. */
572 			if (sop->cipher != CRYPTO_AES_NIST_GCM_16) {
573 				CRYPTDEB("GMAC without GCM");
574 				SDT_PROBE1(opencrypto, dev, ioctl, error,
575 				    __LINE__);
576 				return (EINVAL);
577 			}
578 			break;
579 #endif
580 		case CRYPTO_AES_NIST_GMAC:
581 			switch (sop->mackeylen * 8) {
582 			case 128:
583 				thash = &auth_hash_nist_gmac_aes_128;
584 				break;
585 			case 192:
586 				thash = &auth_hash_nist_gmac_aes_192;
587 				break;
588 			case 256:
589 				thash = &auth_hash_nist_gmac_aes_256;
590 				break;
591 			default:
592 				CRYPTDEB("invalid GMAC key length");
593 				SDT_PROBE1(opencrypto, dev, ioctl, error,
594 				    __LINE__);
595 				return (EINVAL);
596 			}
597 			break;
598 		case CRYPTO_AES_CCM_CBC_MAC:
599 			switch (sop->mackeylen) {
600 			case 16:
601 				thash = &auth_hash_ccm_cbc_mac_128;
602 				break;
603 			case 24:
604 				thash = &auth_hash_ccm_cbc_mac_192;
605 				break;
606 			case 32:
607 				thash = &auth_hash_ccm_cbc_mac_256;
608 				break;
609 			default:
610 				CRYPTDEB("Invalid CBC MAC key size %d",
611 				    sop->keylen);
612 				SDT_PROBE1(opencrypto, dev, ioctl,
613 				    error, __LINE__);
614 				return (EINVAL);
615 			}
616 			break;
617 		case CRYPTO_SHA1:
618 			thash = &auth_hash_sha1;
619 			break;
620 		case CRYPTO_SHA2_224:
621 			thash = &auth_hash_sha2_224;
622 			break;
623 		case CRYPTO_SHA2_256:
624 			thash = &auth_hash_sha2_256;
625 			break;
626 		case CRYPTO_SHA2_384:
627 			thash = &auth_hash_sha2_384;
628 			break;
629 		case CRYPTO_SHA2_512:
630 			thash = &auth_hash_sha2_512;
631 			break;
632 
633 		case CRYPTO_NULL_HMAC:
634 			thash = &auth_hash_null;
635 			break;
636 
637 		case CRYPTO_BLAKE2B:
638 			thash = &auth_hash_blake2b;
639 			break;
640 		case CRYPTO_BLAKE2S:
641 			thash = &auth_hash_blake2s;
642 			break;
643 
644 		default:
645 			CRYPTDEB("invalid mac");
646 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
647 			return (EINVAL);
648 		}
649 
650 		if (txform == NULL && thash == NULL) {
651 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
652 			return (EINVAL);
653 		}
654 
655 		memset(&csp, 0, sizeof(csp));
656 		if (use_outputbuffers)
657 			csp.csp_flags |= CSP_F_SEPARATE_OUTPUT;
658 
659 		if (sop->cipher == CRYPTO_AES_NIST_GCM_16) {
660 			switch (sop->mac) {
661 #ifdef COMPAT_FREEBSD12
662 			case CRYPTO_AES_128_NIST_GMAC:
663 			case CRYPTO_AES_192_NIST_GMAC:
664 			case CRYPTO_AES_256_NIST_GMAC:
665 				if (sop->keylen != sop->mackeylen) {
666 					SDT_PROBE1(opencrypto, dev, ioctl,
667 					    error, __LINE__);
668 					return (EINVAL);
669 				}
670 				break;
671 #endif
672 			case 0:
673 				break;
674 			default:
675 				SDT_PROBE1(opencrypto, dev, ioctl, error,
676 				    __LINE__);
677 				return (EINVAL);
678 			}
679 			csp.csp_mode = CSP_MODE_AEAD;
680 		} else if (sop->cipher == CRYPTO_AES_CCM_16) {
681 			switch (sop->mac) {
682 #ifdef COMPAT_FREEBSD12
683 			case CRYPTO_AES_CCM_CBC_MAC:
684 				if (sop->keylen != sop->mackeylen) {
685 					SDT_PROBE1(opencrypto, dev, ioctl,
686 					    error, __LINE__);
687 					return (EINVAL);
688 				}
689 				thash = NULL;
690 				break;
691 #endif
692 			case 0:
693 				break;
694 			default:
695 				SDT_PROBE1(opencrypto, dev, ioctl, error,
696 				    __LINE__);
697 				return (EINVAL);
698 			}
699 			csp.csp_mode = CSP_MODE_AEAD;
700 		} else if (txform && thash)
701 			csp.csp_mode = CSP_MODE_ETA;
702 		else if (txform)
703 			csp.csp_mode = CSP_MODE_CIPHER;
704 		else
705 			csp.csp_mode = CSP_MODE_DIGEST;
706 
707 		switch (csp.csp_mode) {
708 		case CSP_MODE_AEAD:
709 		case CSP_MODE_ETA:
710 			if (use_separate_aad)
711 				csp.csp_flags |= CSP_F_SEPARATE_AAD;
712 			break;
713 		}
714 
715 		if (txform) {
716 			csp.csp_cipher_alg = txform->type;
717 			csp.csp_cipher_klen = sop->keylen;
718 			if (sop->keylen > txform->maxkey ||
719 			    sop->keylen < txform->minkey) {
720 				CRYPTDEB("invalid cipher parameters");
721 				error = EINVAL;
722 				SDT_PROBE1(opencrypto, dev, ioctl, error,
723 				    __LINE__);
724 				goto bail;
725 			}
726 
727 			key = malloc(csp.csp_cipher_klen, M_XDATA, M_WAITOK);
728 			error = copyin(sop->key, key, csp.csp_cipher_klen);
729 			if (error) {
730 				CRYPTDEB("invalid key");
731 				SDT_PROBE1(opencrypto, dev, ioctl, error,
732 				    __LINE__);
733 				goto bail;
734 			}
735 			csp.csp_cipher_key = key;
736 			csp.csp_ivlen = txform->ivsize;
737 		}
738 
739 		if (thash) {
740 			csp.csp_auth_alg = thash->type;
741 			csp.csp_auth_klen = sop->mackeylen;
742 			if (sop->mackeylen > thash->keysize ||
743 			    sop->mackeylen < 0) {
744 				CRYPTDEB("invalid mac key length");
745 				error = EINVAL;
746 				SDT_PROBE1(opencrypto, dev, ioctl, error,
747 				    __LINE__);
748 				goto bail;
749 			}
750 
751 			if (csp.csp_auth_klen) {
752 				mackey = malloc(csp.csp_auth_klen, M_XDATA,
753 				    M_WAITOK);
754 				error = copyin(sop->mackey, mackey,
755 				    csp.csp_auth_klen);
756 				if (error) {
757 					CRYPTDEB("invalid mac key");
758 					SDT_PROBE1(opencrypto, dev, ioctl,
759 					    error, __LINE__);
760 					goto bail;
761 				}
762 				csp.csp_auth_key = mackey;
763 			}
764 
765 			if (csp.csp_auth_alg == CRYPTO_AES_NIST_GMAC)
766 				csp.csp_ivlen = AES_GCM_IV_LEN;
767 			if (csp.csp_auth_alg == CRYPTO_AES_CCM_CBC_MAC)
768 				csp.csp_ivlen = AES_CCM_IV_LEN;
769 		}
770 
771 		crid = sop->crid;
772 		error = checkforsoftware(&crid);
773 		if (error) {
774 			CRYPTDEB("checkforsoftware");
775 			SDT_PROBE1(opencrypto, dev, ioctl, error,
776 			    __LINE__);
777 			goto bail;
778 		}
779 		error = crypto_newsession(&cses, &csp, crid);
780 		if (error) {
781 			CRYPTDEB("crypto_newsession");
782 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
783 			goto bail;
784 		}
785 
786 		cse = csecreate(fcr, cses, &csp, txform, key, thash, mackey);
787 
788 		if (cse == NULL) {
789 			crypto_freesession(cses);
790 			error = EINVAL;
791 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
792 			CRYPTDEB("csecreate");
793 			goto bail;
794 		}
795 		sop->ses = cse->ses;
796 
797 		/* return hardware/driver id */
798 		sop->crid = crypto_ses2hid(cse->cses);
799 bail:
800 		if (error) {
801 			free(key, M_XDATA);
802 			free(mackey, M_XDATA);
803 		}
804 
805 		if (cmd == CIOCGSESSION && error == 0)
806 			session2_op_to_op(sop, data);
807 		break;
808 	case CIOCFSESSION:
809 		ses = *(u_int32_t *)data;
810 		if (!csedelete(fcr, ses)) {
811 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
812 			return (EINVAL);
813 		}
814 		break;
815 	case CIOCCRYPT:
816 		cop = (struct crypt_op *)data;
817 		cse = csefind(fcr, cop->ses);
818 		if (cse == NULL) {
819 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
820 			return (EINVAL);
821 		}
822 		error = cryptodev_op(cse, cop, active_cred, td);
823 		csefree(cse);
824 		break;
825 	case CIOCKEY:
826 	case CIOCKEY2:
827 		if (ratecheck(&keywarn, &warninterval))
828 			gone_in(14,
829 			    "Asymmetric crypto operations via /dev/crypto");
830 
831 		if (!crypto_userasymcrypto) {
832 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
833 			return (EPERM);		/* XXX compat? */
834 		}
835 		kop = (struct crypt_kop *)data;
836 		if (cmd == CIOCKEY) {
837 			/* NB: crypto core enforces s/w driver use */
838 			kop->crk_crid =
839 			    CRYPTOCAP_F_HARDWARE | CRYPTOCAP_F_SOFTWARE;
840 		}
841 		mtx_lock(&Giant);
842 		error = cryptodev_key(kop);
843 		mtx_unlock(&Giant);
844 		break;
845 	case CIOCASYMFEAT:
846 		if (ratecheck(&featwarn, &warninterval))
847 			gone_in(14,
848 			    "Asymmetric crypto features via /dev/crypto");
849 
850 		if (!crypto_userasymcrypto) {
851 			/*
852 			 * NB: if user asym crypto operations are
853 			 * not permitted return "no algorithms"
854 			 * so well-behaved applications will just
855 			 * fallback to doing them in software.
856 			 */
857 			*(int *)data = 0;
858 		} else {
859 			error = crypto_getfeat((int *)data);
860 			if (error)
861 				SDT_PROBE1(opencrypto, dev, ioctl, error,
862 				    __LINE__);
863 		}
864 		break;
865 	case CIOCFINDDEV:
866 		error = cryptodev_find((struct crypt_find_op *)data);
867 		break;
868 	case CIOCCRYPTAEAD:
869 		caead = (struct crypt_aead *)data;
870 		cse = csefind(fcr, caead->ses);
871 		if (cse == NULL) {
872 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
873 			return (EINVAL);
874 		}
875 		error = cryptodev_aead(cse, caead, active_cred, td);
876 		csefree(cse);
877 		break;
878 	default:
879 		error = EINVAL;
880 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
881 		break;
882 	}
883 
884 #ifdef COMPAT_FREEBSD32
885 	switch (cmd32) {
886 	case CIOCGSESSION32:
887 		if (error == 0)
888 			session_op_to_32(data, data32);
889 		break;
890 	case CIOCGSESSION232:
891 		if (error == 0)
892 			session2_op_to_32(data, data32);
893 		break;
894 	case CIOCCRYPT32:
895 		if (error == 0)
896 			crypt_op_to_32(data, data32);
897 		break;
898 	case CIOCCRYPTAEAD32:
899 		if (error == 0)
900 			crypt_aead_to_32(data, data32);
901 		break;
902 	case CIOCKEY32:
903 	case CIOCKEY232:
904 		crypt_kop_to_32(data, data32);
905 		break;
906 	}
907 #endif
908 	return (error);
909 }
910 
911 static int cryptodev_cb(struct cryptop *);
912 
913 static struct cryptop_data *
914 cod_alloc(struct csession *cse, size_t aad_len, size_t len, struct thread *td)
915 {
916 	struct cryptop_data *cod;
917 
918 	cod = malloc(sizeof(struct cryptop_data), M_XDATA, M_WAITOK | M_ZERO);
919 
920 	cod->cse = cse;
921 	if (crypto_get_params(cse->cses)->csp_flags & CSP_F_SEPARATE_AAD) {
922 		if (aad_len != 0)
923 			cod->aad = malloc(aad_len, M_XDATA, M_WAITOK);
924 		cod->buf = malloc(len, M_XDATA, M_WAITOK);
925 	} else
926 		cod->buf = malloc(aad_len + len, M_XDATA, M_WAITOK);
927 	if (crypto_get_params(cse->cses)->csp_flags & CSP_F_SEPARATE_OUTPUT)
928 		cod->obuf = malloc(len, M_XDATA, M_WAITOK);
929 	return (cod);
930 }
931 
932 static void
933 cod_free(struct cryptop_data *cod)
934 {
935 
936 	free(cod->aad, M_XDATA);
937 	free(cod->obuf, M_XDATA);
938 	free(cod->buf, M_XDATA);
939 	free(cod, M_XDATA);
940 }
941 
942 static int
943 cryptodev_op(
944 	struct csession *cse,
945 	struct crypt_op *cop,
946 	struct ucred *active_cred,
947 	struct thread *td)
948 {
949 	struct cryptop_data *cod = NULL;
950 	struct cryptop *crp = NULL;
951 	int error;
952 
953 	if (cop->len > 256*1024-4) {
954 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
955 		return (E2BIG);
956 	}
957 
958 	if (cse->txform) {
959 		if (cop->len == 0 || (cop->len % cse->txform->blocksize) != 0) {
960 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
961 			return (EINVAL);
962 		}
963 	}
964 
965 	if (cop->mac && cse->hashsize == 0) {
966 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
967 		return (EINVAL);
968 	}
969 
970 	/*
971 	 * The COP_F_CIPHER_FIRST flag predates explicit session
972 	 * modes, but the only way it was used was for EtA so allow it
973 	 * as long as it is consistent with EtA.
974 	 */
975 	if (cop->flags & COP_F_CIPHER_FIRST) {
976 		if (cop->op != COP_ENCRYPT) {
977 			SDT_PROBE1(opencrypto, dev, ioctl, error,  __LINE__);
978 			return (EINVAL);
979 		}
980 	}
981 
982 	cod = cod_alloc(cse, 0, cop->len + cse->hashsize, td);
983 
984 	crp = crypto_getreq(cse->cses, M_WAITOK);
985 
986 	error = copyin(cop->src, cod->buf, cop->len);
987 	if (error) {
988 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
989 		goto bail;
990 	}
991 	crp->crp_payload_start = 0;
992 	crp->crp_payload_length = cop->len;
993 	if (cse->hashsize)
994 		crp->crp_digest_start = cop->len;
995 
996 	switch (cse->mode) {
997 	case CSP_MODE_COMPRESS:
998 		switch (cop->op) {
999 		case COP_ENCRYPT:
1000 			crp->crp_op = CRYPTO_OP_COMPRESS;
1001 			break;
1002 		case COP_DECRYPT:
1003 			crp->crp_op = CRYPTO_OP_DECOMPRESS;
1004 			break;
1005 		default:
1006 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1007 			error = EINVAL;
1008 			goto bail;
1009 		}
1010 		break;
1011 	case CSP_MODE_CIPHER:
1012 		switch (cop->op) {
1013 		case COP_ENCRYPT:
1014 			crp->crp_op = CRYPTO_OP_ENCRYPT;
1015 			break;
1016 		case COP_DECRYPT:
1017 			crp->crp_op = CRYPTO_OP_DECRYPT;
1018 			break;
1019 		default:
1020 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1021 			error = EINVAL;
1022 			goto bail;
1023 		}
1024 		break;
1025 	case CSP_MODE_DIGEST:
1026 		switch (cop->op) {
1027 		case 0:
1028 		case COP_ENCRYPT:
1029 		case COP_DECRYPT:
1030 			crp->crp_op = CRYPTO_OP_COMPUTE_DIGEST;
1031 			if (cod->obuf != NULL)
1032 				crp->crp_digest_start = 0;
1033 			break;
1034 		default:
1035 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1036 			error = EINVAL;
1037 			goto bail;
1038 		}
1039 		break;
1040 	case CSP_MODE_ETA:
1041 		switch (cop->op) {
1042 		case COP_ENCRYPT:
1043 			crp->crp_op = CRYPTO_OP_ENCRYPT |
1044 			    CRYPTO_OP_COMPUTE_DIGEST;
1045 			break;
1046 		case COP_DECRYPT:
1047 			crp->crp_op = CRYPTO_OP_DECRYPT |
1048 			    CRYPTO_OP_VERIFY_DIGEST;
1049 			break;
1050 		default:
1051 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1052 			error = EINVAL;
1053 			goto bail;
1054 		}
1055 		break;
1056 	default:
1057 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1058 		error = EINVAL;
1059 		goto bail;
1060 	}
1061 
1062 	crp->crp_flags = CRYPTO_F_CBIMM | (cop->flags & COP_F_BATCH);
1063 	crypto_use_buf(crp, cod->buf, cop->len + cse->hashsize);
1064 	if (cod->obuf)
1065 		crypto_use_output_buf(crp, cod->obuf, cop->len + cse->hashsize);
1066 	crp->crp_callback = cryptodev_cb;
1067 	crp->crp_opaque = cod;
1068 
1069 	if (cop->iv) {
1070 		if (cse->ivsize == 0) {
1071 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1072 			error = EINVAL;
1073 			goto bail;
1074 		}
1075 		error = copyin(cop->iv, crp->crp_iv, cse->ivsize);
1076 		if (error) {
1077 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1078 			goto bail;
1079 		}
1080 		crp->crp_flags |= CRYPTO_F_IV_SEPARATE;
1081 	} else if (cse->ivsize != 0) {
1082 		crp->crp_iv_start = 0;
1083 		crp->crp_payload_start += cse->ivsize;
1084 		crp->crp_payload_length -= cse->ivsize;
1085 		cop->dst += cse->ivsize;
1086 	}
1087 
1088 	if (cop->mac != NULL && crp->crp_op & CRYPTO_OP_VERIFY_DIGEST) {
1089 		error = copyin(cop->mac, cod->buf + crp->crp_digest_start,
1090 		    cse->hashsize);
1091 		if (error) {
1092 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1093 			goto bail;
1094 		}
1095 	}
1096 again:
1097 	/*
1098 	 * Let the dispatch run unlocked, then, interlock against the
1099 	 * callback before checking if the operation completed and going
1100 	 * to sleep.  This insures drivers don't inherit our lock which
1101 	 * results in a lock order reversal between crypto_dispatch forced
1102 	 * entry and the crypto_done callback into us.
1103 	 */
1104 	error = crypto_dispatch(crp);
1105 	if (error != 0) {
1106 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1107 		goto bail;
1108 	}
1109 
1110 	mtx_lock(&cse->lock);
1111 	while (!cod->done)
1112 		mtx_sleep(cod, &cse->lock, PWAIT, "crydev", 0);
1113 	mtx_unlock(&cse->lock);
1114 
1115 	if (crp->crp_etype == EAGAIN) {
1116 		crp->crp_etype = 0;
1117 		crp->crp_flags &= ~CRYPTO_F_DONE;
1118 		cod->done = false;
1119 		goto again;
1120 	}
1121 
1122 	if (crp->crp_etype != 0) {
1123 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1124 		error = crp->crp_etype;
1125 		goto bail;
1126 	}
1127 
1128 	if (cop->dst != NULL) {
1129 		error = copyout(cod->obuf != NULL ? cod->obuf :
1130 		    cod->buf + crp->crp_payload_start, cop->dst,
1131 		    crp->crp_payload_length);
1132 		if (error) {
1133 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1134 			goto bail;
1135 		}
1136 	}
1137 
1138 	if (cop->mac != NULL && (crp->crp_op & CRYPTO_OP_VERIFY_DIGEST) == 0) {
1139 		error = copyout((cod->obuf != NULL ? cod->obuf : cod->buf) +
1140 		    crp->crp_digest_start, cop->mac, cse->hashsize);
1141 		if (error) {
1142 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1143 			goto bail;
1144 		}
1145 	}
1146 
1147 bail:
1148 	crypto_freereq(crp);
1149 	cod_free(cod);
1150 
1151 	return (error);
1152 }
1153 
1154 static int
1155 cryptodev_aead(
1156 	struct csession *cse,
1157 	struct crypt_aead *caead,
1158 	struct ucred *active_cred,
1159 	struct thread *td)
1160 {
1161 	struct cryptop_data *cod = NULL;
1162 	struct cryptop *crp = NULL;
1163 	int error;
1164 
1165 	if (caead->len > 256*1024-4 || caead->aadlen > 256*1024-4) {
1166 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1167 		return (E2BIG);
1168 	}
1169 
1170 	if (cse->txform == NULL || cse->hashsize == 0 || caead->tag == NULL ||
1171 	    (caead->len % cse->txform->blocksize) != 0) {
1172 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1173 		return (EINVAL);
1174 	}
1175 
1176 	/*
1177 	 * The COP_F_CIPHER_FIRST flag predates explicit session
1178 	 * modes, but the only way it was used was for EtA so allow it
1179 	 * as long as it is consistent with EtA.
1180 	 */
1181 	if (caead->flags & COP_F_CIPHER_FIRST) {
1182 		if (caead->op != COP_ENCRYPT) {
1183 			SDT_PROBE1(opencrypto, dev, ioctl, error,  __LINE__);
1184 			return (EINVAL);
1185 		}
1186 	}
1187 
1188 	cod = cod_alloc(cse, caead->aadlen, caead->len + cse->hashsize, td);
1189 
1190 	crp = crypto_getreq(cse->cses, M_WAITOK);
1191 
1192 	if (cod->aad != NULL)
1193 		error = copyin(caead->aad, cod->aad, caead->aadlen);
1194 	else
1195 		error = copyin(caead->aad, cod->buf, caead->aadlen);
1196 	if (error) {
1197 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1198 		goto bail;
1199 	}
1200 	crp->crp_aad = cod->aad;
1201 	crp->crp_aad_start = 0;
1202 	crp->crp_aad_length = caead->aadlen;
1203 
1204 	if (cod->aad != NULL)
1205 		crp->crp_payload_start = 0;
1206 	else
1207 		crp->crp_payload_start = caead->aadlen;
1208 	error = copyin(caead->src, cod->buf + crp->crp_payload_start,
1209 	    caead->len);
1210 	if (error) {
1211 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1212 		goto bail;
1213 	}
1214 	crp->crp_payload_length = caead->len;
1215 	if (caead->op == COP_ENCRYPT && cod->obuf != NULL)
1216 		crp->crp_digest_start = crp->crp_payload_output_start +
1217 		    caead->len;
1218 	else
1219 		crp->crp_digest_start = crp->crp_payload_start + caead->len;
1220 
1221 	switch (cse->mode) {
1222 	case CSP_MODE_AEAD:
1223 	case CSP_MODE_ETA:
1224 		switch (caead->op) {
1225 		case COP_ENCRYPT:
1226 			crp->crp_op = CRYPTO_OP_ENCRYPT |
1227 			    CRYPTO_OP_COMPUTE_DIGEST;
1228 			break;
1229 		case COP_DECRYPT:
1230 			crp->crp_op = CRYPTO_OP_DECRYPT |
1231 			    CRYPTO_OP_VERIFY_DIGEST;
1232 			break;
1233 		default:
1234 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1235 			error = EINVAL;
1236 			goto bail;
1237 		}
1238 		break;
1239 	default:
1240 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1241 		error = EINVAL;
1242 		goto bail;
1243 	}
1244 
1245 	crp->crp_flags = CRYPTO_F_CBIMM | (caead->flags & COP_F_BATCH);
1246 	crypto_use_buf(crp, cod->buf, crp->crp_payload_start + caead->len +
1247 	    cse->hashsize);
1248 	if (cod->obuf != NULL)
1249 		crypto_use_output_buf(crp, cod->obuf, caead->len +
1250 		    cse->hashsize);
1251 	crp->crp_callback = cryptodev_cb;
1252 	crp->crp_opaque = cod;
1253 
1254 	if (caead->iv) {
1255 		/*
1256 		 * Permit a 16-byte IV for AES-XTS, but only use the
1257 		 * first 8 bytes as a block number.
1258 		 */
1259 		if (cse->mode == CSP_MODE_ETA &&
1260 		    caead->ivlen == AES_BLOCK_LEN &&
1261 		    cse->ivsize == AES_XTS_IV_LEN)
1262 			caead->ivlen = AES_XTS_IV_LEN;
1263 
1264 		if (caead->ivlen != cse->ivsize) {
1265 			error = EINVAL;
1266 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1267 			goto bail;
1268 		}
1269 
1270 		error = copyin(caead->iv, crp->crp_iv, cse->ivsize);
1271 		if (error) {
1272 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1273 			goto bail;
1274 		}
1275 		crp->crp_flags |= CRYPTO_F_IV_SEPARATE;
1276 	} else {
1277 		crp->crp_iv_start = crp->crp_payload_start;
1278 		crp->crp_payload_start += cse->ivsize;
1279 		crp->crp_payload_length -= cse->ivsize;
1280 		caead->dst += cse->ivsize;
1281 	}
1282 
1283 	if (crp->crp_op & CRYPTO_OP_VERIFY_DIGEST) {
1284 		error = copyin(caead->tag, cod->buf + crp->crp_digest_start,
1285 		    cse->hashsize);
1286 		if (error) {
1287 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1288 			goto bail;
1289 		}
1290 	}
1291 again:
1292 	/*
1293 	 * Let the dispatch run unlocked, then, interlock against the
1294 	 * callback before checking if the operation completed and going
1295 	 * to sleep.  This insures drivers don't inherit our lock which
1296 	 * results in a lock order reversal between crypto_dispatch forced
1297 	 * entry and the crypto_done callback into us.
1298 	 */
1299 	error = crypto_dispatch(crp);
1300 	if (error != 0) {
1301 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1302 		goto bail;
1303 	}
1304 
1305 	mtx_lock(&cse->lock);
1306 	while (!cod->done)
1307 		mtx_sleep(cod, &cse->lock, PWAIT, "crydev", 0);
1308 	mtx_unlock(&cse->lock);
1309 
1310 	if (crp->crp_etype == EAGAIN) {
1311 		crp->crp_etype = 0;
1312 		crp->crp_flags &= ~CRYPTO_F_DONE;
1313 		cod->done = false;
1314 		goto again;
1315 	}
1316 
1317 	if (crp->crp_etype != 0) {
1318 		error = crp->crp_etype;
1319 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1320 		goto bail;
1321 	}
1322 
1323 	if (caead->dst != NULL) {
1324 		error = copyout(cod->obuf != NULL ? cod->obuf :
1325 		    cod->buf + crp->crp_payload_start, caead->dst,
1326 		    crp->crp_payload_length);
1327 		if (error) {
1328 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1329 			goto bail;
1330 		}
1331 	}
1332 
1333 	if ((crp->crp_op & CRYPTO_OP_VERIFY_DIGEST) == 0) {
1334 		error = copyout((cod->obuf != NULL ? cod->obuf : cod->buf) +
1335 		    crp->crp_digest_start, caead->tag, cse->hashsize);
1336 		if (error) {
1337 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1338 			goto bail;
1339 		}
1340 	}
1341 
1342 bail:
1343 	crypto_freereq(crp);
1344 	cod_free(cod);
1345 
1346 	return (error);
1347 }
1348 
1349 static int
1350 cryptodev_cb(struct cryptop *crp)
1351 {
1352 	struct cryptop_data *cod = crp->crp_opaque;
1353 
1354 	/*
1355 	 * Lock to ensure the wakeup() is not missed by the loops
1356 	 * waiting on cod->done in cryptodev_op() and
1357 	 * cryptodev_aead().
1358 	 */
1359 	mtx_lock(&cod->cse->lock);
1360 	cod->done = true;
1361 	mtx_unlock(&cod->cse->lock);
1362 	wakeup(cod);
1363 	return (0);
1364 }
1365 
1366 static void
1367 cryptodevkey_cb(struct cryptkop *krp)
1368 {
1369 
1370 	wakeup_one(krp);
1371 }
1372 
1373 static int
1374 cryptodev_key(struct crypt_kop *kop)
1375 {
1376 	struct cryptkop *krp = NULL;
1377 	int error = EINVAL;
1378 	int in, out, size, i;
1379 
1380 	if (kop->crk_iparams + kop->crk_oparams > CRK_MAXPARAM) {
1381 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1382 		return (EFBIG);
1383 	}
1384 
1385 	in = kop->crk_iparams;
1386 	out = kop->crk_oparams;
1387 	switch (kop->crk_op) {
1388 	case CRK_MOD_EXP:
1389 		if (in == 3 && out == 1)
1390 			break;
1391 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1392 		return (EINVAL);
1393 	case CRK_MOD_EXP_CRT:
1394 		if (in == 6 && out == 1)
1395 			break;
1396 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1397 		return (EINVAL);
1398 	case CRK_DSA_SIGN:
1399 		if (in == 5 && out == 2)
1400 			break;
1401 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1402 		return (EINVAL);
1403 	case CRK_DSA_VERIFY:
1404 		if (in == 7 && out == 0)
1405 			break;
1406 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1407 		return (EINVAL);
1408 	case CRK_DH_COMPUTE_KEY:
1409 		if (in == 3 && out == 1)
1410 			break;
1411 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1412 		return (EINVAL);
1413 	default:
1414 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1415 		return (EINVAL);
1416 	}
1417 
1418 	krp = malloc(sizeof(*krp), M_XDATA, M_WAITOK | M_ZERO);
1419 	krp->krp_op = kop->crk_op;
1420 	krp->krp_status = kop->crk_status;
1421 	krp->krp_iparams = kop->crk_iparams;
1422 	krp->krp_oparams = kop->crk_oparams;
1423 	krp->krp_crid = kop->crk_crid;
1424 	krp->krp_status = 0;
1425 	krp->krp_callback = cryptodevkey_cb;
1426 
1427 	for (i = 0; i < CRK_MAXPARAM; i++) {
1428 		if (kop->crk_param[i].crp_nbits > 65536) {
1429 			/* Limit is the same as in OpenBSD */
1430 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1431 			goto fail;
1432 		}
1433 		krp->krp_param[i].crp_nbits = kop->crk_param[i].crp_nbits;
1434 	}
1435 	for (i = 0; i < krp->krp_iparams + krp->krp_oparams; i++) {
1436 		size = (krp->krp_param[i].crp_nbits + 7) / 8;
1437 		if (size == 0)
1438 			continue;
1439 		krp->krp_param[i].crp_p = malloc(size, M_XDATA, M_WAITOK);
1440 		if (i >= krp->krp_iparams)
1441 			continue;
1442 		error = copyin(kop->crk_param[i].crp_p, krp->krp_param[i].crp_p, size);
1443 		if (error) {
1444 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1445 			goto fail;
1446 		}
1447 	}
1448 
1449 	error = crypto_kdispatch(krp);
1450 	if (error) {
1451 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1452 		goto fail;
1453 	}
1454 	error = tsleep(krp, PSOCK, "crydev", 0);
1455 	if (error) {
1456 		/* XXX can this happen?  if so, how do we recover? */
1457 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1458 		goto fail;
1459 	}
1460 
1461 	kop->crk_crid = krp->krp_hid;		/* device that did the work */
1462 	if (krp->krp_status != 0) {
1463 		error = krp->krp_status;
1464 		SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1465 		goto fail;
1466 	}
1467 
1468 	for (i = krp->krp_iparams; i < krp->krp_iparams + krp->krp_oparams; i++) {
1469 		size = (krp->krp_param[i].crp_nbits + 7) / 8;
1470 		if (size == 0)
1471 			continue;
1472 		error = copyout(krp->krp_param[i].crp_p, kop->crk_param[i].crp_p, size);
1473 		if (error) {
1474 			SDT_PROBE1(opencrypto, dev, ioctl, error, __LINE__);
1475 			goto fail;
1476 		}
1477 	}
1478 
1479 fail:
1480 	if (krp) {
1481 		kop->crk_status = krp->krp_status;
1482 		for (i = 0; i < CRK_MAXPARAM; i++) {
1483 			if (krp->krp_param[i].crp_p)
1484 				free(krp->krp_param[i].crp_p, M_XDATA);
1485 		}
1486 		free(krp, M_XDATA);
1487 	}
1488 	return (error);
1489 }
1490 
1491 static int
1492 cryptodev_find(struct crypt_find_op *find)
1493 {
1494 	device_t dev;
1495 	size_t fnlen = sizeof find->name;
1496 
1497 	if (find->crid != -1) {
1498 		dev = crypto_find_device_byhid(find->crid);
1499 		if (dev == NULL)
1500 			return (ENOENT);
1501 		strncpy(find->name, device_get_nameunit(dev), fnlen);
1502 		find->name[fnlen - 1] = '\x0';
1503 	} else {
1504 		find->name[fnlen - 1] = '\x0';
1505 		find->crid = crypto_find_driver(find->name);
1506 		if (find->crid == -1)
1507 			return (ENOENT);
1508 	}
1509 	return (0);
1510 }
1511 
1512 /* ARGSUSED */
1513 static int
1514 cryptof_stat(
1515 	struct file *fp,
1516 	struct stat *sb,
1517 	struct ucred *active_cred,
1518 	struct thread *td)
1519 {
1520 
1521 	return (EOPNOTSUPP);
1522 }
1523 
1524 /* ARGSUSED */
1525 static int
1526 cryptof_close(struct file *fp, struct thread *td)
1527 {
1528 	struct fcrypt *fcr = fp->f_data;
1529 	struct csession *cse;
1530 
1531 	while ((cse = TAILQ_FIRST(&fcr->csessions))) {
1532 		TAILQ_REMOVE(&fcr->csessions, cse, next);
1533 		KASSERT(cse->refs == 1,
1534 		    ("%s: crypto session %p with %d refs", __func__, cse,
1535 		    cse->refs));
1536 		csefree(cse);
1537 	}
1538 	free(fcr, M_XDATA);
1539 	fp->f_data = NULL;
1540 	return 0;
1541 }
1542 
1543 static int
1544 cryptof_fill_kinfo(struct file *fp, struct kinfo_file *kif, struct filedesc *fdp)
1545 {
1546 
1547 	kif->kf_type = KF_TYPE_CRYPTO;
1548 	return (0);
1549 }
1550 
1551 static struct csession *
1552 csefind(struct fcrypt *fcr, u_int ses)
1553 {
1554 	struct csession *cse;
1555 
1556 	mtx_lock(&fcr->lock);
1557 	TAILQ_FOREACH(cse, &fcr->csessions, next) {
1558 		if (cse->ses == ses) {
1559 			refcount_acquire(&cse->refs);
1560 			mtx_unlock(&fcr->lock);
1561 			return (cse);
1562 		}
1563 	}
1564 	mtx_unlock(&fcr->lock);
1565 	return (NULL);
1566 }
1567 
1568 static bool
1569 csedelete(struct fcrypt *fcr, u_int ses)
1570 {
1571 	struct csession *cse;
1572 
1573 	mtx_lock(&fcr->lock);
1574 	TAILQ_FOREACH(cse, &fcr->csessions, next) {
1575 		if (cse->ses == ses) {
1576 			TAILQ_REMOVE(&fcr->csessions, cse, next);
1577 			mtx_unlock(&fcr->lock);
1578 			csefree(cse);
1579 			return (true);
1580 		}
1581 	}
1582 	mtx_unlock(&fcr->lock);
1583 	return (false);
1584 }
1585 
1586 struct csession *
1587 csecreate(struct fcrypt *fcr, crypto_session_t cses,
1588     struct crypto_session_params *csp, struct enc_xform *txform,
1589     void *key, struct auth_hash *thash, void *mackey)
1590 {
1591 	struct csession *cse;
1592 
1593 	cse = malloc(sizeof(struct csession), M_XDATA, M_NOWAIT | M_ZERO);
1594 	if (cse == NULL)
1595 		return NULL;
1596 	mtx_init(&cse->lock, "cryptodev", "crypto session lock", MTX_DEF);
1597 	refcount_init(&cse->refs, 1);
1598 	cse->key = key;
1599 	cse->mackey = mackey;
1600 	cse->mode = csp->csp_mode;
1601 	cse->cses = cses;
1602 	cse->txform = txform;
1603 	if (thash != NULL)
1604 		cse->hashsize = thash->hashsize;
1605 	else if (csp->csp_cipher_alg == CRYPTO_AES_NIST_GCM_16)
1606 		cse->hashsize = AES_GMAC_HASH_LEN;
1607 	else if (csp->csp_cipher_alg == CRYPTO_AES_CCM_16)
1608 		cse->hashsize = AES_CBC_MAC_HASH_LEN;
1609 	cse->ivsize = csp->csp_ivlen;
1610 	mtx_lock(&fcr->lock);
1611 	TAILQ_INSERT_TAIL(&fcr->csessions, cse, next);
1612 	cse->ses = fcr->sesn++;
1613 	mtx_unlock(&fcr->lock);
1614 	return (cse);
1615 }
1616 
1617 static void
1618 csefree(struct csession *cse)
1619 {
1620 
1621 	if (!refcount_release(&cse->refs))
1622 		return;
1623 	crypto_freesession(cse->cses);
1624 	mtx_destroy(&cse->lock);
1625 	if (cse->key)
1626 		free(cse->key, M_XDATA);
1627 	if (cse->mackey)
1628 		free(cse->mackey, M_XDATA);
1629 	free(cse, M_XDATA);
1630 }
1631 
1632 static int
1633 cryptoioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td)
1634 {
1635 	struct file *f;
1636 	struct fcrypt *fcr;
1637 	int fd, error;
1638 
1639 	switch (cmd) {
1640 	case CRIOGET:
1641 		error = falloc_noinstall(td, &f);
1642 		if (error)
1643 			break;
1644 
1645 		fcr = malloc(sizeof(struct fcrypt), M_XDATA, M_WAITOK | M_ZERO);
1646 		TAILQ_INIT(&fcr->csessions);
1647 		mtx_init(&fcr->lock, "fcrypt", NULL, MTX_DEF);
1648 
1649 		finit(f, FREAD | FWRITE, DTYPE_CRYPTO, fcr, &cryptofops);
1650 		error = finstall(td, f, &fd, 0, NULL);
1651 		if (error) {
1652 			mtx_destroy(&fcr->lock);
1653 			free(fcr, M_XDATA);
1654 		} else
1655 			*(uint32_t *)data = fd;
1656 		fdrop(f, td);
1657 		break;
1658 	case CRIOFINDDEV:
1659 		error = cryptodev_find((struct crypt_find_op *)data);
1660 		break;
1661 	case CRIOASYMFEAT:
1662 		error = crypto_getfeat((int *)data);
1663 		break;
1664 	default:
1665 		error = EINVAL;
1666 		break;
1667 	}
1668 	return (error);
1669 }
1670 
1671 static struct cdevsw crypto_cdevsw = {
1672 	.d_version =	D_VERSION,
1673 	.d_ioctl =	cryptoioctl,
1674 	.d_name =	"crypto",
1675 };
1676 static struct cdev *crypto_dev;
1677 
1678 /*
1679  * Initialization code, both for static and dynamic loading.
1680  */
1681 static int
1682 cryptodev_modevent(module_t mod, int type, void *unused)
1683 {
1684 	switch (type) {
1685 	case MOD_LOAD:
1686 		if (bootverbose)
1687 			printf("crypto: <crypto device>\n");
1688 		crypto_dev = make_dev(&crypto_cdevsw, 0,
1689 				      UID_ROOT, GID_WHEEL, 0666,
1690 				      "crypto");
1691 		return 0;
1692 	case MOD_UNLOAD:
1693 		/*XXX disallow if active sessions */
1694 		destroy_dev(crypto_dev);
1695 		return 0;
1696 	}
1697 	return EINVAL;
1698 }
1699 
1700 static moduledata_t cryptodev_mod = {
1701 	"cryptodev",
1702 	cryptodev_modevent,
1703 	0
1704 };
1705 MODULE_VERSION(cryptodev, 1);
1706 DECLARE_MODULE(cryptodev, cryptodev_mod, SI_SUB_PSEUDO, SI_ORDER_ANY);
1707 MODULE_DEPEND(cryptodev, crypto, 1, 1, 1);
1708 MODULE_DEPEND(cryptodev, zlib, 1, 1, 1);
1709