summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--share/man/man9/crypto.918
-rw-r--r--sys/crypto/crypto.c8
-rw-r--r--sys/crypto/cryptodev.c10
-rw-r--r--sys/crypto/cryptodev.h4
-rw-r--r--sys/crypto/cryptosoft.c4
-rw-r--r--sys/dev/pci/hifn7751.c4
-rw-r--r--sys/dev/pci/ises.c4
-rw-r--r--sys/dev/pci/ubsec.c4
8 files changed, 32 insertions, 24 deletions
diff --git a/share/man/man9/crypto.9 b/share/man/man9/crypto.9
index 46121cf9d64..834d64f4eeb 100644
--- a/share/man/man9/crypto.9
+++ b/share/man/man9/crypto.9
@@ -1,4 +1,4 @@
-.\" $OpenBSD: crypto.9,v 1.13 2001/08/03 15:21:17 mpech Exp $
+.\" $OpenBSD: crypto.9,v 1.14 2001/11/09 03:11:38 deraadt Exp $
.\"
.\" The author of this man page is Angelos D. Keromytis (angelos@cis.upenn.edu)
.\"
@@ -24,7 +24,7 @@
.Sh SYNOPSIS
.Fd #include <crypto/crypto.h>
.Ft int32_t
-.Fn crypto_get_driverid "void"
+.Fn crypto_get_driverid "u_int8_t"
.Ft int
.Fn crypto_register "u_int32_t" "int" "int (*)(u_int32_t *, struct cryptoini *)" "int (*)(u_int64_t)" "int (*)(struct cryptop *)"
.Ft int
@@ -45,8 +45,7 @@
#define EALG_MAX_BLOCK_LEN 8
-struct cryptoini
-{
+struct cryptoini {
int cri_alg;
int cri_klen;
int cri_rnd;
@@ -55,8 +54,7 @@ struct cryptoini
struct cryptoini *cri_next;
};
-struct cryptodesc
-{
+struct cryptodesc {
int crd_skip;
int crd_len;
int crd_inject;
@@ -65,8 +63,7 @@ struct cryptodesc
struct cryptodesc *crd_next;
};
-struct cryptop
-{
+struct cryptop {
u_int64_t crp_sid;
int crp_ilen;
int crp_olen;
@@ -369,7 +366,10 @@ primitives to register and unregister with the kernel crypto services
framework.
Drivers must first use the
.Fn crypto_get_driverid
-function to acquire a driver identifier.
+function to acquire a driver identifier, specifying the
+.Fa cc_flags
+as an argument (normally 0, but software-only drivers should specify
+.Dv CRYPTOCAP_F_SOFTWARE Ns ).
For each algorithm the driver supports, it must then call
.Fn crypto_register .
The first two arguments are the driver and algorithm identifiers.
diff --git a/sys/crypto/crypto.c b/sys/crypto/crypto.c
index ffb8fddf3e2..4b4f5c5462f 100644
--- a/sys/crypto/crypto.c
+++ b/sys/crypto/crypto.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: crypto.c,v 1.27 2001/11/08 23:12:38 deraadt Exp $ */
+/* $OpenBSD: crypto.c,v 1.28 2001/11/09 03:11:38 deraadt Exp $ */
/*
* The author of this code is Angelos D. Keromytis (angelos@cis.upenn.edu)
*
@@ -69,6 +69,9 @@ crypto_newsession(u_int64_t *sid, struct cryptoini *cri, int hard)
(crypto_drivers[hid].cc_flags & CRYPTOCAP_F_CLEANUP))
continue;
+ if (crypto_drivers[hid].cc_sessions == 0)
+ continue;
+
/* Hardware requested -- ignore software drivers. */
if (hard &&
(crypto_drivers[hid].cc_flags & CRYPTOCAP_F_SOFTWARE))
@@ -154,7 +157,7 @@ crypto_freesession(u_int64_t sid)
* Find an empty slot.
*/
int32_t
-crypto_get_driverid(void)
+crypto_get_driverid(u_int8_t flags)
{
struct cryptocap *newdrv;
int i, s = splimp();
@@ -204,6 +207,7 @@ crypto_get_driverid(void)
crypto_drivers_num * sizeof(struct cryptocap));
newdrv[i].cc_sessions = 1; /* Mark */
+ newdrv[i].cc_flags = flags;
crypto_drivers_num *= 2;
free(crypto_drivers, M_CRYPTO_DATA);
diff --git a/sys/crypto/cryptodev.c b/sys/crypto/cryptodev.c
index f7f87b42ed9..8b0c606214c 100644
--- a/sys/crypto/cryptodev.c
+++ b/sys/crypto/cryptodev.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cryptodev.c,v 1.26 2001/11/08 23:12:38 deraadt Exp $ */
+/* $OpenBSD: cryptodev.c,v 1.27 2001/11/09 03:11:38 deraadt Exp $ */
/*
* Copyright (c) 2001 Theo de Raadt
@@ -221,8 +221,10 @@ cryptof_ioctl(fp, cmd, data, p)
MALLOC(crie.cri_key, u_int8_t *,
crie.cri_klen / 8, M_XDATA, M_WAITOK);
if ((error = copyin(sop->key, crie.cri_key,
- crie.cri_klen / 8)))
+ crie.cri_klen / 8))) {
+ error = EINVAL;
goto bail;
+ }
if (thash)
crie.cri_next = &cria;
}
@@ -238,8 +240,10 @@ cryptof_ioctl(fp, cmd, data, p)
MALLOC(cria.cri_key, u_int8_t *,
cria.cri_klen / 8, M_XDATA, M_WAITOK);
if ((error = copyin(sop->mackey, cria.cri_key,
- cria.cri_klen / 8)))
+ cria.cri_klen / 8))) {
+ error = EINVAL;
goto bail;
+ }
}
error = crypto_newsession(&sid, (txform ? &crie : &cria), 1);
diff --git a/sys/crypto/cryptodev.h b/sys/crypto/cryptodev.h
index 72f472ef1d4..62c0534783e 100644
--- a/sys/crypto/cryptodev.h
+++ b/sys/crypto/cryptodev.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cryptodev.h,v 1.14 2001/08/28 12:20:43 ben Exp $ */
+/* $OpenBSD: cryptodev.h,v 1.15 2001/11/09 03:11:38 deraadt Exp $ */
/*
* The author of this code is Angelos D. Keromytis (angelos@cis.upenn.edu)
@@ -364,7 +364,7 @@ int crypto_register(u_int32_t, int, u_int16_t, u_int32_t,
int (*)(u_int32_t *, struct cryptoini *), int (*)(u_int64_t),
int (*)(struct cryptop *));
int crypto_unregister(u_int32_t, int);
-int32_t crypto_get_driverid(void);
+int32_t crypto_get_driverid(u_int8_t);
void crypto_thread(void);
int crypto_invoke(struct cryptop *);
void crypto_done(struct cryptop *);
diff --git a/sys/crypto/cryptosoft.c b/sys/crypto/cryptosoft.c
index d6950b34321..25739aaeef4 100644
--- a/sys/crypto/cryptosoft.c
+++ b/sys/crypto/cryptosoft.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cryptosoft.c,v 1.28 2001/08/08 15:12:09 jjbg Exp $ */
+/* $OpenBSD: cryptosoft.c,v 1.29 2001/11/09 03:11:38 deraadt Exp $ */
/*
* The author of this code is Angelos D. Keromytis (angelos@cis.upenn.edu)
@@ -812,7 +812,7 @@ done:
void
swcr_init(void)
{
- swcr_id = crypto_get_driverid();
+ swcr_id = crypto_get_driverid(CRYPTOCAP_F_SOFTWARE);
if (swcr_id >= 0) {
crypto_register(swcr_id, CRYPTO_DES_CBC, 0, 0, swcr_newsession,
swcr_freesession, swcr_process);
diff --git a/sys/dev/pci/hifn7751.c b/sys/dev/pci/hifn7751.c
index ba3b46a8339..529fce095f3 100644
--- a/sys/dev/pci/hifn7751.c
+++ b/sys/dev/pci/hifn7751.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: hifn7751.c,v 1.106 2001/11/06 19:53:19 miod Exp $ */
+/* $OpenBSD: hifn7751.c,v 1.107 2001/11/09 03:11:38 deraadt Exp $ */
/*
* Invertex AEON / Hifn 7751 driver
@@ -282,7 +282,7 @@ hifn_attach(parent, self, aux)
printf(", %d%cB %cram, %s\n", rseg, rbase,
sc->sc_drammodel ? 'd' : 's', intrstr);
- sc->sc_cid = crypto_get_driverid();
+ sc->sc_cid = crypto_get_driverid(0);
if (sc->sc_cid < 0)
goto fail_intr;
diff --git a/sys/dev/pci/ises.c b/sys/dev/pci/ises.c
index 6d3a2dc5b52..32a4f5450f1 100644
--- a/sys/dev/pci/ises.c
+++ b/sys/dev/pci/ises.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ises.c,v 1.17 2001/11/05 17:25:58 art Exp $ */
+/* $OpenBSD: ises.c,v 1.18 2001/11/09 03:11:38 deraadt Exp $ */
/*
* Copyright (c) 2000, 2001 Håkan Olsson (ho@crt.se)
@@ -245,7 +245,7 @@ ises_attach(struct device *parent, struct device *self, void *aux)
bzero(&isesstats, sizeof(isesstats));
- sc->sc_cid = crypto_get_driverid();
+ sc->sc_cid = crypto_get_driverid(0);
if (sc->sc_cid < 0)
goto fail;
diff --git a/sys/dev/pci/ubsec.c b/sys/dev/pci/ubsec.c
index 7d2aa87be86..d7cdb8f2afb 100644
--- a/sys/dev/pci/ubsec.c
+++ b/sys/dev/pci/ubsec.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ubsec.c,v 1.72 2001/11/06 19:53:19 miod Exp $ */
+/* $OpenBSD: ubsec.c,v 1.73 2001/11/09 03:11:38 deraadt Exp $ */
/*
* Copyright (c) 2000 Jason L. Wright (jason@thought.net)
@@ -183,7 +183,7 @@ ubsec_attach(parent, self, aux)
return;
}
- sc->sc_cid = crypto_get_driverid();
+ sc->sc_cid = crypto_get_driverid(0);
if (sc->sc_cid < 0) {
pci_intr_disestablish(pc, sc->sc_ih);
bus_space_unmap(sc->sc_st, sc->sc_sh, iosize);