Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/opencrypto refactor crypto_newsession() like FreeBSD.



details:   https://anonhg.NetBSD.org/src/rev/fe53f4e28050
branches:  trunk
changeset: 354372:fe53f4e28050
user:      knakahara <knakahara%NetBSD.org@localhost>
date:      Wed Jun 14 07:36:24 2017 +0000

description:
refactor crypto_newsession() like FreeBSD.

diffstat:

 sys/opencrypto/crypto.c |  125 +++++++++++++++++++++++++++--------------------
 1 files changed, 72 insertions(+), 53 deletions(-)

diffs (164 lines):

diff -r 81fc5b90b3b6 -r fe53f4e28050 sys/opencrypto/crypto.c
--- a/sys/opencrypto/crypto.c   Wed Jun 14 07:32:19 2017 +0000
+++ b/sys/opencrypto/crypto.c   Wed Jun 14 07:36:24 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: crypto.c,v 1.87 2017/06/14 07:32:19 knakahara Exp $ */
+/*     $NetBSD: crypto.c,v 1.88 2017/06/14 07:36:24 knakahara Exp $ */
 /*     $FreeBSD: src/sys/opencrypto/crypto.c,v 1.4.2.5 2003/02/26 00:14:05 sam Exp $   */
 /*     $OpenBSD: crypto.c,v 1.41 2002/07/17 23:52:38 art Exp $ */
 
@@ -53,7 +53,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: crypto.c,v 1.87 2017/06/14 07:32:19 knakahara Exp $");
+__KERNEL_RCSID(0, "$NetBSD: crypto.c,v 1.88 2017/06/14 07:36:24 knakahara Exp $");
 
 #include <sys/param.h>
 #include <sys/reboot.h>
@@ -501,29 +501,34 @@
        return 0;
 }
 
-/*
- * Create a new session.
- */
-int
-crypto_newsession(u_int64_t *sid, struct cryptoini *cri, int hard)
+static bool
+crypto_driver_suitable(struct cryptocap *cap, struct cryptoini *cri)
 {
        struct cryptoini *cr;
-       struct cryptocap *cap;
-       u_int32_t hid, lid;
-       int err = EINVAL;
 
-       mutex_enter(&crypto_drv_mtx);
+       for (cr = cri; cr; cr = cr->cri_next)
+               if (cap->cc_alg[cr->cri_alg] == 0) {
+                       DPRINTF("alg %d not supported\n", cr->cri_alg);
+                       return false;
+               }
+
+       return true;
+}
 
-       /*
-        * The algorithm we use here is pretty stupid; just use the
-        * first driver that supports all the algorithms we need.
-        *
-        * XXX We need more smarts here (in real life too, but that's
-        * XXX another story altogether).
-        */
+/*
+ * The algorithm we use here is pretty stupid; just use the
+ * first driver that supports all the algorithms we need.
+ *
+ * XXX We need more smarts here (in real life too, but that's
+ * XXX another story altogether).
+ */
+static struct cryptocap *
+crypto_select_driver_lock(struct cryptoini *cri, int hard)
+{
+       u_int32_t hid;
 
        for (hid = 0; hid < crypto_drivers_num; hid++) {
-               cap = crypto_checkdriver(hid);
+               struct cryptocap *cap = crypto_checkdriver(hid);
                if (cap == NULL)
                        continue;
 
@@ -551,45 +556,59 @@
                }
 
                /* See if all the algorithms are supported. */
-               for (cr = cri; cr; cr = cr->cri_next)
-                       if (cap->cc_alg[cr->cri_alg] == 0) {
-                               DPRINTF("alg %d not supported\n", cr->cri_alg);
-                               break;
-                       }
-
-               if (cr == NULL) {
-                       /* Ok, all algorithms are supported. */
-
-                       /*
-                        * Can't do everything in one session.
-                        *
-                        * XXX Fix this. We need to inject a "virtual" session layer right
-                        * XXX about here.
-                        */
-
-                       /* Call the driver initialization routine. */
-                       lid = hid;              /* Pass the driver ID. */
-                       crypto_driver_unlock(cap);
-                       err = cap->cc_newsession(cap->cc_arg, &lid, cri);
-                       crypto_driver_lock(cap);
-                       if (err == 0) {
-                               (*sid) = hid;
-                               (*sid) <<= 32;
-                               (*sid) |= (lid & 0xffffffff);
-                               (cap->cc_sessions)++;
-                       } else {
-                               DPRINTF("crypto_drivers[%d].cc_newsession() failed. error=%d\n",
-                                       hid, err);
-                       }
-                       crypto_driver_unlock(cap);
-                       goto done;
-                       /*break;*/
+               if (crypto_driver_suitable(cap, cri)) {
+                       /* keep holding crypto_driver_lock(cap) */
+                       return cap;
                }
 
                crypto_driver_unlock(cap);
        }
-done:
+
+       return NULL;
+}
+
+/*
+ * Create a new session.
+ */
+int
+crypto_newsession(u_int64_t *sid, struct cryptoini *cri, int hard)
+{
+       struct cryptocap *cap;
+       int err = EINVAL;
+
+       mutex_enter(&crypto_drv_mtx);
+
+       cap = crypto_select_driver_lock(cri, hard);
+       if (cap != NULL) {
+               u_int32_t hid, lid;
+
+               hid = cap - crypto_drivers;
+               /*
+                * Can't do everything in one session.
+                *
+                * XXX Fix this. We need to inject a "virtual" session layer right
+                * XXX about here.
+                */
+
+               /* Call the driver initialization routine. */
+               lid = hid;              /* Pass the driver ID. */
+               crypto_driver_unlock(cap);
+               err = cap->cc_newsession(cap->cc_arg, &lid, cri);
+               crypto_driver_lock(cap);
+               if (err == 0) {
+                       (*sid) = hid;
+                       (*sid) <<= 32;
+                       (*sid) |= (lid & 0xffffffff);
+                       (cap->cc_sessions)++;
+               } else {
+                       DPRINTF("crypto_drivers[%d].cc_newsession() failed. error=%d\n",
+                           hid, err);
+               }
+               crypto_driver_unlock(cap);
+       }
+
        mutex_exit(&crypto_drv_mtx);
+
        return err;
 }
 



Home | Main Index | Thread Index | Old Index