summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/pci/hifn7751.c21
-rw-r--r--sys/dev/pci/hifn7751var.h9
2 files changed, 18 insertions, 12 deletions
diff --git a/sys/dev/pci/hifn7751.c b/sys/dev/pci/hifn7751.c
index b9e68f0107c..0fffdaebd90 100644
--- a/sys/dev/pci/hifn7751.c
+++ b/sys/dev/pci/hifn7751.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: hifn7751.c,v 1.96 2001/08/22 16:11:31 jason Exp $ */
+/* $OpenBSD: hifn7751.c,v 1.97 2001/08/22 16:34:47 jason Exp $ */
/*
* Invertex AEON / Hifn 7751 driver
@@ -1535,7 +1535,7 @@ hifn_newsession(sidp, cri)
return (EINVAL);
for (i = 0; i < sc->sc_maxses; i++)
- if (sc->sc_sessions[i].hs_flags == 0)
+ if (sc->sc_sessions[i].hs_state == HS_STATE_FREE)
break;
if (i == sc->sc_maxses)
return (ENOMEM);
@@ -1566,7 +1566,7 @@ hifn_newsession(sidp, cri)
return (EINVAL);
*sidp = HIFN_SID(sc->sc_dv.dv_unit, i);
- sc->sc_sessions[i].hs_flags = 1;
+ sc->sc_sessions[i].hs_state = HS_STATE_USED;
return (0);
}
@@ -1701,7 +1701,8 @@ hifn_process(crp)
cmd->cry_masks |= HIFN_CRYPT_CMD_ALG_RC4;
if ((enccrd->crd_flags & CRD_F_ENCRYPT)
!= sc->sc_sessions[session].hs_prev_op)
- sc->sc_sessions[session].hs_flags=1;
+ sc->sc_sessions[session].hs_state =
+ HS_STATE_USED;
break;
case CRYPTO_DES_CBC:
cmd->cry_masks |= HIFN_CRYPT_CMD_ALG_DES |
@@ -1755,7 +1756,7 @@ hifn_process(crp)
cmd->ck = enccrd->crd_key;
cmd->cklen = enccrd->crd_klen >> 3;
- if (sc->sc_sessions[session].hs_flags == 1)
+ if (sc->sc_sessions[session].hs_state == HS_STATE_USED)
cmd->cry_masks |= HIFN_CRYPT_CMD_NEW_KEY;
}
@@ -1771,7 +1772,7 @@ hifn_process(crp)
else
cmd->mac_masks |= HIFN_MAC_CMD_ALG_SHA1;
- if (sc->sc_sessions[session].hs_flags == 1) {
+ if (sc->sc_sessions[session].hs_state == HS_STATE_USED) {
cmd->mac_masks |= HIFN_MAC_CMD_NEW_KEY;
bcopy(maccrd->crd_key, cmd->mac, maccrd->crd_klen >> 3);
bzero(cmd->mac + (maccrd->crd_klen >> 3),
@@ -1787,8 +1788,8 @@ hifn_process(crp)
if (!err) {
sc->sc_sessions[session].hs_prev_op=enccrd->crd_flags
& CRD_F_ENCRYPT;
- if (sc->sc_sessions[session].hs_flags == 1)
- sc->sc_sessions[session].hs_flags = 2;
+ if (sc->sc_sessions[session].hs_state == HS_STATE_USED)
+ sc->sc_sessions[session].hs_state = HS_STATE_KEY;
return 0;
}
@@ -1868,8 +1869,8 @@ hifn_abort(sc)
/* Force upload of key next time */
for (i = 0; i < sc->sc_maxses; i++)
- if (sc->sc_sessions[i].hs_flags == 2)
- sc->sc_sessions[i].hs_flags = 1;
+ if (sc->sc_sessions[i].hs_state == HS_STATE_KEY)
+ sc->sc_sessions[i].hs_state = HS_STATE_USED;
hifn_reset_board(sc, 1);
hifn_init_dma(sc);
diff --git a/sys/dev/pci/hifn7751var.h b/sys/dev/pci/hifn7751var.h
index 264b81d4a6b..c1e718b2e78 100644
--- a/sys/dev/pci/hifn7751var.h
+++ b/sys/dev/pci/hifn7751var.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: hifn7751var.h,v 1.33 2001/08/17 17:37:12 ben Exp $ */
+/* $OpenBSD: hifn7751var.h,v 1.34 2001/08/22 16:34:47 jason Exp $ */
/*
* Invertex AEON / Hifn 7751 driver
@@ -97,11 +97,16 @@ struct hifn_dma {
};
struct hifn_session {
- int hs_flags;
+ int hs_state;
int hs_prev_op; /* XXX collapse into hs_flags? */
u_int8_t hs_iv[HIFN_IV_LENGTH];
};
+/* We use a state machine to on sessions */
+#define HS_STATE_FREE 0 /* unused session entry */
+#define HS_STATE_USED 1 /* allocated, but key not on card */
+#define HS_STATE_KEY 2 /* allocated and key is on card */
+
/*
* Holds data specific to a single HIFN board.
*/