diff options
author | Jason Wright <jason@cvs.openbsd.org> | 2001-06-23 20:20:34 +0000 |
---|---|---|
committer | Jason Wright <jason@cvs.openbsd.org> | 2001-06-23 20:20:34 +0000 |
commit | f14ed829ac9e9f653c486570f9d06bed9ebdae23 (patch) | |
tree | b2a8fc64dfb6cb2a099c8f163cfb209c08225e04 /sys/dev/pci | |
parent | 67fdc804bc1427680a0a5d0778038a65ff487897 (diff) |
add some infrastructure for the public engine
require reworking interrupt enable and status checking as well as
a bit of initialization
Diffstat (limited to 'sys/dev/pci')
-rw-r--r-- | sys/dev/pci/hifn7751.c | 41 | ||||
-rw-r--r-- | sys/dev/pci/hifn7751reg.h | 3 |
2 files changed, 32 insertions, 12 deletions
diff --git a/sys/dev/pci/hifn7751.c b/sys/dev/pci/hifn7751.c index c0e672f9be6..fcf037e1e83 100644 --- a/sys/dev/pci/hifn7751.c +++ b/sys/dev/pci/hifn7751.c @@ -1,4 +1,4 @@ -/* $OpenBSD: hifn7751.c,v 1.73 2001/06/23 18:30:37 deraadt Exp $ */ +/* $OpenBSD: hifn7751.c,v 1.74 2001/06/23 20:20:32 jason Exp $ */ /* * Invertex AEON / Hi/fn 7751 driver @@ -356,6 +356,15 @@ hifn_init_pubrng(sc) timeout_add(&sc->sc_rngto, sc->sc_rnghz); } + /* Enable public key engine, if available */ + if (sc->sc_flags & HIFN_HAS_PUBLIC) { + WRITE_REG_1(sc, HIFN_1_PUB_STATUS, + READ_REG_1(sc, HIFN_1_PUB_STATUS) | HIFN_PUBSTS_DONE); + + sc->sc_dmaier |= HIFN_DMAIER_PUBDONE; + WRITE_REG_1(sc, HIFN_1_DMA_IER, sc->sc_dmaier); + } + return (0); } @@ -608,8 +617,8 @@ hifn_init_pci_registers(sc) WRITE_REG_1(sc, HIFN_1_DMA_CSR, HIFN_DMACSR_D_CTRL_ENA | HIFN_DMACSR_R_CTRL_ENA | HIFN_DMACSR_S_CTRL_ENA | HIFN_DMACSR_C_CTRL_ENA); - WRITE_REG_1(sc, HIFN_1_DMA_IER, HIFN_DMAIER_R_DONE); - sc->sc_dmaier = HIFN_DMAIER_R_DONE; + sc->sc_dmaier |= HIFN_DMAIER_R_DONE; + WRITE_REG_1(sc, HIFN_1_DMA_IER, sc->sc_dmaier); WRITE_REG_0(sc, HIFN_0_PUCNFG, HIFN_PUCNFG_COMPSING | HIFN_PUCNFG_DRFR_128 | HIFN_PUCNFG_TCALLPHASES | @@ -1143,9 +1152,8 @@ hifn_crypto(sc, cmd, crp) * in the queue. */ if (dma->cmdu > 1) { - WRITE_REG_1(sc, HIFN_1_DMA_IER, - HIFN_DMAIER_C_WAIT | HIFN_DMAIER_R_DONE); - sc->sc_dmaier = HIFN_DMAIER_C_WAIT | HIFN_DMAIER_R_DONE; + sc->sc_dmaier |= HIFN_DMAIER_C_WAIT; + WRITE_REG_1(sc, HIFN_1_DMA_IER, sc->sc_dmaier); } hifnstats.hst_ipackets++; @@ -1200,7 +1208,7 @@ hifn_intr(arg) struct hifn_softc *sc = arg; struct hifn_dma *dma = sc->sc_dma; u_int32_t dmacsr; - int i, u; + int i, r = 0, u; dmacsr = READ_REG_1(sc, HIFN_1_DMA_CSR); @@ -1213,7 +1221,18 @@ hifn_intr(arg) /* Nothing in the DMA unit interrupted */ if ((dmacsr & sc->sc_dmaier) == 0) - return (0); + return (r); + + if ((sc->sc_flags & HIFN_HAS_PUBLIC) && + (dmacsr & HIFN_DMACSR_PUBDONE)) { + r = 1; + dmacsr &= ~HIFN_DMACSR_PUBDONE; + } + + if ((dmacsr & sc->sc_dmaier) == 0) + return (r); + + r = 1; bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, BUS_DMASYNC_POSTWRITE | BUS_DMASYNC_POSTREAD); @@ -1228,8 +1247,8 @@ hifn_intr(arg) * command" interrupt, we disable the "waiting on command" * (by clearing it). */ - WRITE_REG_1(sc, HIFN_1_DMA_IER, HIFN_DMAIER_R_DONE); - sc->sc_dmaier = HIFN_DMAIER_R_DONE; + sc->sc_dmaier &= ~HIFN_DMAIER_C_WAIT; + WRITE_REG_1(sc, HIFN_1_DMA_IER, sc->sc_dmaier); } while (dma->resu > 0) { @@ -1281,7 +1300,7 @@ hifn_intr(arg) WRITE_REG_1(sc, HIFN_1_DMA_CSR, HIFN_DMACSR_R_DONE|HIFN_DMACSR_C_WAIT); bus_dmamap_sync(sc->sc_dmat, sc->sc_dmamap, BUS_DMASYNC_PREWRITE | BUS_DMASYNC_PREREAD); - return (1); + return (r); } /* diff --git a/sys/dev/pci/hifn7751reg.h b/sys/dev/pci/hifn7751reg.h index 4bdc1318b93..a00de62d32c 100644 --- a/sys/dev/pci/hifn7751reg.h +++ b/sys/dev/pci/hifn7751reg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: hifn7751reg.h,v 1.23 2001/06/23 19:50:47 jason Exp $ */ +/* $OpenBSD: hifn7751reg.h,v 1.24 2001/06/23 20:20:33 jason Exp $ */ /* * Invertex AEON / Hi/fn 7751 driver @@ -235,6 +235,7 @@ typedef struct hifn_desc { #define HIFN_DMACSR_C_DONE 0x00000010 /* Command Ring Done */ #define HIFN_DMACSR_C_LAST 0x00000008 /* Command Ring Last */ #define HIFN_DMACSR_C_WAIT 0x00000004 /* Command Ring Waiting */ +#define HIFN_DMACSR_PUBDONE 0x00000002 /* Public op done (7951 only) */ #define HIFN_DMACSR_C_EIRQ 0x00000001 /* Command Ring Engine IRQ */ /* DMA Interrupt Enable Register (HIFN_1_DMA_IER) */ |