diff options
author | Jason Wright <jason@cvs.openbsd.org> | 2001-01-29 04:01:45 +0000 |
---|---|---|
committer | Jason Wright <jason@cvs.openbsd.org> | 2001-01-29 04:01:45 +0000 |
commit | 1f90ce194a5519ab3bd5c8b96b700e3bc80efd9e (patch) | |
tree | 8e9b72f6a44517e29dc65c4324d48272f77bbbe2 /sys/dev | |
parent | ce4bd0a82dae2c504f34ed1cd89a9877c98ccba1 (diff) |
grab rng stuff more often (now 6400bytes/sec)
document the other mcr2 operations
and fix a printf (luckily it's never been called =)
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/pci/ubsec.c | 16 | ||||
-rw-r--r-- | sys/dev/pci/ubsecreg.h | 17 |
2 files changed, 27 insertions, 6 deletions
diff --git a/sys/dev/pci/ubsec.c b/sys/dev/pci/ubsec.c index 5bee0a61135..2d29a7f0e94 100644 --- a/sys/dev/pci/ubsec.c +++ b/sys/dev/pci/ubsec.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ubsec.c,v 1.37 2001/01/29 00:39:20 jason Exp $ */ +/* $OpenBSD: ubsec.c,v 1.38 2001/01/29 04:01:44 jason Exp $ */ /* * Copyright (c) 2000 Jason L. Wright (jason@thought.net) @@ -200,7 +200,7 @@ ubsec_attach(parent, self, aux) if (sc->sc_5601) { timeout_set(&sc->sc_rngto, ubsec_rng, sc); - timeout_add(&sc->sc_rngto, hz); + timeout_add(&sc->sc_rngto, 1); } printf(": %s\n", intrstr); @@ -1070,6 +1070,7 @@ void ubsec_callback2(q) struct ubsec_q2 *q; { + struct ubsec_softc *sc = q->q_sc; struct ubsec_keyctx *ctx = q->q_ctx; switch (ctx->ctx_op) { @@ -1083,10 +1084,12 @@ ubsec_callback2(q) add_true_randomness(*dat); free(rng, M_DEVBUF); free(q, M_DEVBUF); + timeout_add(&sc->sc_rngto, 1); break; } default: - printf("%s: unknown ctx op: %x\n", ctx->ctx_op); + printf("%s: unknown ctx op: %x\n", sc->sc_dv.dv_xname, + ctx->ctx_op); break; } } @@ -1139,6 +1142,11 @@ ubsec_rng(vsc) ubsec_feed2(sc); splx(s); + return; + out: - timeout_add(&sc->sc_rngto, hz); + /* + * Something weird happened, generate our own call back. + */ + timeout_add(&sc->sc_rngto, 1); } diff --git a/sys/dev/pci/ubsecreg.h b/sys/dev/pci/ubsecreg.h index 59b90e9a4d1..ceb510230bc 100644 --- a/sys/dev/pci/ubsecreg.h +++ b/sys/dev/pci/ubsecreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: ubsecreg.h,v 1.8 2001/01/29 00:39:20 jason Exp $ */ +/* $OpenBSD: ubsecreg.h,v 1.9 2001/01/29 04:01:44 jason Exp $ */ /* * Copyright (c) 2000 Theo de Raadt @@ -126,7 +126,20 @@ struct ubsec_keyctx { volatile u_int16_t ctx_op; /* operation code */ volatile u_int8_t ctx_pad[60]; /* padding */ }; -#define UBS_CTXOP_RNGBYPASS 0x41 +#define UBS_CTXOP_DHPKGEN 0x01 /* dh public key generation */ +#define UBS_CTXOP_DHSSGEN 0x02 /* dh shared secret gen. */ +#define UBS_CTXOP_RSAPUB 0x03 /* rsa public key op */ +#define UBS_CTXOP_RSAPRIV 0x04 /* rsa private key op */ +#define UBS_CTXOP_DSASIGN 0x05 /* dsa signing op */ +#define UBS_CTXOP_DSAVRFY 0x06 /* dsa verification */ +#define UBS_CTXOP_RNGBYPASS 0x41 /* rng direct test mode */ +#define UBS_CTXOP_RNGSHA1 0x42 /* rng sha1 test mode */ +#define UBS_CTXOP_MODADD 0x43 /* modular addition */ +#define UBS_CTXOP_MODSUB 0x44 /* modular subtraction */ +#define UBS_CTXOP_MODMUL 0x45 /* modular multiplication */ +#define UBS_CTXOP_MODRED 0x46 /* modular reduction */ +#define UBS_CTXOP_MODEXP 0x47 /* modular exponentiation */ +#define UBS_CTXOP_MODINV 0x48 /* modular inverse */ struct ubsec_rngbypass_ctx { volatile u_int16_t rbp_len; /* command length, 64 */ |