summaryrefslogtreecommitdiff
path: root/sys/dev/pci
diff options
context:
space:
mode:
authorJason Wright <jason@cvs.openbsd.org>2000-03-15 14:55:53 +0000
committerJason Wright <jason@cvs.openbsd.org>2000-03-15 14:55:53 +0000
commit2b26d034c2843eb3dae3222b1bf6ba1ac3d92e9c (patch)
treedc5be1e5911ddac4e57c9275142e5d7a94c84e2c /sys/dev/pci
parent3045dc1329e5be836aa6023692d291383d43cb0b (diff)
Bring in bit definitions from the datasheet and allow shared interrupts.
Diffstat (limited to 'sys/dev/pci')
-rw-r--r--sys/dev/pci/aeon.c103
-rw-r--r--sys/dev/pci/aeonreg.h264
-rw-r--r--sys/dev/pci/hifn7751.c103
-rw-r--r--sys/dev/pci/hifn7751reg.h264
4 files changed, 470 insertions, 264 deletions
diff --git a/sys/dev/pci/aeon.c b/sys/dev/pci/aeon.c
index 82205674fbe..015353a94cc 100644
--- a/sys/dev/pci/aeon.c
+++ b/sys/dev/pci/aeon.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: aeon.c,v 1.8 2000/03/10 19:54:24 deraadt Exp $ */
+/* $OpenBSD: aeon.c,v 1.9 2000/03/15 14:55:51 jason Exp $ */
/*
* Invertex AEON driver
@@ -135,8 +135,7 @@ aeon_attach(parent, self, aux)
return;
}
- if (pci_mem_find(pc, pa->pa_tag, PCI_BASE_ADDRESS_0, &iobase, &iosize,
- NULL)){
+ if (pci_mem_find(pc, pa->pa_tag, AEON_BAR0, &iobase, &iosize, NULL)) {
printf(": can't find mem space\n");
return;
}
@@ -146,8 +145,7 @@ aeon_attach(parent, self, aux)
}
sc->sc_st0 = pa->pa_memt;
- if (pci_mem_find(pc, pa->pa_tag, PCI_BASE_ADDRESS_1, &iobase, &iosize,
- NULL)){
+ if (pci_mem_find(pc, pa->pa_tag, AEON_BAR1, &iobase, &iosize, NULL)) {
printf(": can't find mem space\n");
return;
}
@@ -247,8 +245,8 @@ aeon_reset_board(sc)
* Set polling in the DMA configuration register to zero. 0x7 avoids
* resetting the board and zeros out the other fields.
*/
- WRITE_REG_1(sc, AEON_DMA_CFG, AEON_DMA_CFG_NOBOARDRESET |
- AEON_DMA_CFG_NODMARESET | AEON_DMA_CFG_NEED);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_MSTRESET |
+ AEON_DMACNFG_DMARESET | AEON_DMACNFG_MODE);
/*
* Now that polling has been disabled, we have to wait 1 ms
@@ -260,7 +258,7 @@ aeon_reset_board(sc)
* field, the BRD reset field, and the manditory 1 at position 2.
* Every other field is set to zero.
*/
- WRITE_REG_1(sc, AEON_DMA_CFG, AEON_DMA_CFG_NEED);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_MODE);
/*
* Wait another millisecond for the board to reset.
@@ -270,8 +268,8 @@ aeon_reset_board(sc)
/*
* Turn off the reset! (No joke.)
*/
- WRITE_REG_1(sc, AEON_DMA_CFG, AEON_DMA_CFG_NOBOARDRESET |
- AEON_DMA_CFG_NODMARESET | AEON_DMA_CFG_NEED);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_MSTRESET |
+ AEON_DMACNFG_DMARESET | AEON_DMACNFG_MODE);
}
u_int32_t
@@ -310,7 +308,7 @@ struct pci2id {
PCI_VENDOR_HIFN,
PCI_PRODUCT_HIFN_7751,
{ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00 } /* XXX incorrect */
+ 0x00, 0x00, 0x00, 0x00, 0x00 }
},
};
@@ -342,16 +340,16 @@ aeon_enable_crypto(sc, pciid)
return (1);
}
- ramcfg = READ_REG_0(sc, AEON_RAM_CONFIG);
- dmacfg = READ_REG_1(sc, AEON_DMA_CFG);
+ ramcfg = READ_REG_0(sc, AEON_0_PUCNFG);
+ dmacfg = READ_REG_1(sc, AEON_1_DMA_CNFG);
/*
* The RAM config register's encrypt level bit needs to be set before
* every read performed on the encryption level register.
*/
- WRITE_REG_0(sc, AEON_RAM_CONFIG, ramcfg | 0x20);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, ramcfg | AEON_PUCNFG_CHIPID);
- encl = READ_REG_0(sc, AEON_CRYPTLEVEL);
+ encl = READ_REG_0(sc, AEON_0_PUSTAT);
/*
* Make sure we don't re-unlock. Two unlocks kills chip until the
@@ -362,8 +360,8 @@ aeon_enable_crypto(sc, pciid)
printf("%s: Strong Crypto already enabled!\n",
sc->sc_dv.dv_xname);
#endif
- WRITE_REG_0(sc, AEON_RAM_CONFIG, ramcfg);
- WRITE_REG_1(sc, AEON_DMA_CFG, dmacfg);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, ramcfg);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, dmacfg);
return 0; /* success */
}
@@ -374,7 +372,8 @@ aeon_enable_crypto(sc, pciid)
return 1;
}
- WRITE_REG_1(sc, AEON_DMA_CFG, 0x807);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_UNLOCK |
+ AEON_DMACNFG_MSTRESET | AEON_DMACNFG_DMARESET | AEON_DMACNFG_MODE);
addr = READ_REG_1(sc, AEON_UNLOCK_SECRET1);
WRITE_REG_1(sc, AEON_UNLOCK_SECRET2, 0);
@@ -385,8 +384,8 @@ aeon_enable_crypto(sc, pciid)
DELAY(1000);
}
- WRITE_REG_0(sc, AEON_RAM_CONFIG, ramcfg | 0x20);
- encl = READ_REG_0(sc, AEON_CRYPTLEVEL);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, ramcfg | AEON_PUCNFG_CHIPID);
+ encl = READ_REG_0(sc, AEON_0_PUSTAT);
#ifdef AEON_DEBUG
if (encl != 0x1020 && encl != 0x1120)
@@ -395,8 +394,8 @@ aeon_enable_crypto(sc, pciid)
printf("Encryption engine enabled successfully!");
#endif
- WRITE_REG_0(sc, AEON_RAM_CONFIG, ramcfg);
- WRITE_REG_1(sc, AEON_DMA_CFG, dmacfg);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, ramcfg);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, dmacfg);
switch(encl) {
case 0x3020:
@@ -425,30 +424,38 @@ aeon_init_pci_registers(sc)
struct aeon_softc *sc;
{
/* write fixed values needed by the Initialization registers */
- WRITE_REG_0(sc, AEON_INIT_1, 0x2);
- WRITE_REG_0(sc, AEON_INIT_2, 0x400);
- WRITE_REG_0(sc, AEON_INIT_3, 0x200);
+ WRITE_REG_0(sc, AEON_0_PUCTRL, AEON_PUCTRL_DMAENA);
+ WRITE_REG_0(sc, AEON_0_FIFOCNFG, AEON_FIFOCNFG_THRESHOLD);
+ WRITE_REG_0(sc, AEON_0_PUIER, AEON_PUIER_DSTOVER);
/* write all 4 ring address registers */
- WRITE_REG_1(sc, AEON_CMDR_ADDR, vtophys(sc->sc_dma->cmdr));
- WRITE_REG_1(sc, AEON_SRCR_ADDR, vtophys(sc->sc_dma->srcr));
- WRITE_REG_1(sc, AEON_DSTR_ADDR, vtophys(sc->sc_dma->dstr));
- WRITE_REG_1(sc, AEON_RESR_ADDR, vtophys(sc->sc_dma->resr));
+ WRITE_REG_1(sc, AEON_1_DMA_CRAR, vtophys(sc->sc_dma->cmdr));
+ WRITE_REG_1(sc, AEON_1_DMA_SRAR, vtophys(sc->sc_dma->srcr));
+ WRITE_REG_1(sc, AEON_1_DMA_DRAR, vtophys(sc->sc_dma->dstr));
+ WRITE_REG_1(sc, AEON_1_DMA_RRAR, vtophys(sc->sc_dma->resr));
/* write status register */
- WRITE_REG_1(sc, AEON_STATUS, AEON_INIT_STATUS_REG);
- WRITE_REG_1(sc, AEON_IRQEN, AEON_INIT_INTERRUPT_ENABLE_REG);
+ WRITE_REG_1(sc, AEON_1_DMA_CSR, AEON_DMACSR_D_CTRL_ENA |
+ AEON_DMACSR_R_CTRL_ENA | AEON_DMACSR_S_CTRL_ENA |
+ AEON_DMACSR_C_CTRL_ENA);
+ WRITE_REG_1(sc, AEON_1_DMA_IER, AEON_DMAIER_R_DONE);
#if 0
#if BYTE_ORDER == BIG_ENDIAN
(0x1 << 7) |
#endif
#endif
- WRITE_REG_0(sc, AEON_RAM_CONFIG, AEON_INIT_RAM_CONFIG_REG |
- sc->sc_drammodel << 4);
-
- WRITE_REG_0(sc, AEON_EXPAND, AEON_INIT_EXPAND_REG);
- WRITE_REG_1(sc, AEON_DMA_CFG, AEON_INIT_DMA_CONFIG_REG);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, AEON_PUCNFG_COMPSING |
+ AEON_PUCNFG_DRFR_128 | AEON_PUCNFG_TCALLPHASES |
+ AEON_PUCNFG_TCDRVTOTEM | AEON_PUCNFG_BUS32 |
+ (sc->sc_drammodel ? AEON_PUCNFG_DRAM : AEON_PUCNFG_SRAM));
+
+ WRITE_REG_0(sc, AEON_0_PUISR, AEON_PUISR_DSTOVER);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_MSTRESET |
+ AEON_DMACNFG_DMARESET | AEON_DMACNFG_MODE |
+ AEON_DMACNFG_LAST |
+ ((AEON_POLL_FREQUENCY << 16 ) & AEON_DMACNFG_POLLFREQ) |
+ ((AEON_POLL_SCALAR << 8) & AEON_DMACNFG_POLLINVAL));
}
/*
@@ -905,7 +912,7 @@ aeon_crypto(struct aeon_command *cmd)
printf("%s: Entering cmd: stat %8x ien %8x u %d/%d/%d/%d n %d/%d\n",
sc->sc_dv.dv_xname,
- READ_REG_1(sc, AEON_STATUS), READ_REG_1(sc, AEON_IRQEN),
+ READ_REG_1(sc, AEON_1_DMA_CSR), READ_REG_1(sc, AEON_1_DMA_IER),
dma->cmdu, dma->srcu, dma->dstu, dma->resu, cmd->src_npa,
cmd->dst_npa);
@@ -993,8 +1000,8 @@ aeon_crypto(struct aeon_command *cmd)
* than one command in the queue.
*/
if (dma->slots_in_use > 1) {
- WRITE_REG_1(sc, AEON_IRQEN,
- AEON_INTR_ON_RESULT_DONE | AEON_INTR_ON_COMMAND_WAITING);
+ WRITE_REG_1(sc, AEON_1_DMA_IER,
+ AEON_DMAIER_R_DONE | AEON_DMAIER_C_WAIT);
}
/*
@@ -1014,7 +1021,7 @@ aeon_crypto(struct aeon_command *cmd)
printf("%s: command: stat %8x ier %8x\n",
sc->sc_dv.dv_xname,
- READ_REG_1(sc, AEON_STATUS), READ_REG_1(sc, AEON_IRQEN));
+ READ_REG_1(sc, AEON_1_DMA_CSR), READ_REG_1(sc, AEON_1_DMA_IER));
splx(s);
return 0; /* success */
@@ -1026,19 +1033,25 @@ aeon_intr(arg)
{
struct aeon_softc *sc = arg;
struct aeon_dma *dma = sc->sc_dma;
+ u_int32_t dmacsr;
+
+ dmacsr = READ_REG_1(sc, AEON_1_DMA_CSR);
printf("%s: irq: stat %8x ien %8x u %d/%d/%d/%d\n",
sc->sc_dv.dv_xname,
- READ_REG_1(sc, AEON_STATUS), READ_REG_1(sc, AEON_IRQEN),
+ dmacsr, READ_REG_1(sc, AEON_1_DMA_IER),
dma->cmdu, dma->srcu, dma->dstu, dma->resu);
-
- if (dma->slots_in_use == 0 && (READ_REG_1(sc, AEON_STATUS) & (1 << 2))) {
+
+ if ((dmacsr & (AEON_DMACSR_C_WAIT|AEON_DMACSR_R_DONE)) == 0)
+ return (0);
+
+ if ((dma->slots_in_use == 0) && (dmacsr & AEON_DMACSR_C_WAIT)) {
/*
* If no slots to process and we received a "waiting on
* result" interrupt, we disable the "waiting on result"
* (by clearing it).
*/
- WRITE_REG_1(sc, AEON_IRQEN, AEON_INTR_ON_RESULT_DONE);
+ WRITE_REG_1(sc, AEON_1_DMA_IER, AEON_DMAIER_R_DONE);
} else {
if (dma->slots_in_use > AEON_D_RSIZE)
printf("%s: Internal Error -- ring overflow\n",
@@ -1078,6 +1091,6 @@ aeon_intr(arg)
* register. If we still have slots to process and we received a
* waiting interrupt, this will interupt us again.
*/
- WRITE_REG_1(sc, AEON_STATUS, (1 << 20) | (1 << 2));
+ WRITE_REG_1(sc, AEON_1_DMA_CSR, AEON_DMACSR_R_DONE|AEON_DMACSR_C_WAIT);
return (1);
}
diff --git a/sys/dev/pci/aeonreg.h b/sys/dev/pci/aeonreg.h
index 1e37fd2a3e3..d5a44e3180f 100644
--- a/sys/dev/pci/aeonreg.h
+++ b/sys/dev/pci/aeonreg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: aeonreg.h,v 1.5 2000/03/10 08:45:00 mickey Exp $ */
+/* $OpenBSD: aeonreg.h,v 1.6 2000/03/15 14:55:52 jason Exp $ */
/*
* Invertex AEON driver
@@ -40,8 +40,8 @@
* Some PCI configuration space offset defines. The names were made
* identical to the names used by the Linux kernel.
*/
-#define PCI_BASE_ADDRESS_0 0x10 /* 32 bits */
-#define PCI_BASE_ADDRESS_1 0x14 /* 32 bits */
+#define AEON_BAR0 (PCI_MAPREG_START + 0) /* PUC register map */
+#define AEON_BAR1 (PCI_MAPREG_START + 4) /* DMA register map */
/*
* Some configurable values for the driver
@@ -131,14 +131,181 @@ struct aeon_softc {
};
/*
- * Register offsets in register set 0
+ * Processing Unit Registers (offset from BASEREG0)
*/
-#define AEON_INIT_1 0x04
-#define AEON_RAM_CONFIG 0x0c
-#define AEON_EXPAND 0x08
-#define AEON_CRYPTLEVEL 0x14
-#define AEON_INIT_3 0x10
-#define AEON_INIT_2 0x1c
+#define AEON_0_PUDATA 0x00 /* Processing Unit Data */
+#define AEON_0_PUCTRL 0x04 /* Processing Unit Control */
+#define AEON_0_PUISR 0x08 /* Processing Unit Interrupt Status */
+#define AEON_0_PUCNFG 0x0c /* Processing Unit Configuration */
+#define AEON_0_PUIER 0x10 /* Processing Unit Interrupt Enable */
+#define AEON_0_PUSTAT 0x14 /* Processing Unit Status/Chip ID */
+#define AEON_0_FIFOSTAT 0x18 /* FIFO Status */
+#define AEON_0_FIFOCNFG 0x1c /* FIFO Configuration */
+#define AEON_0_SPACESIZE 0x20 /* Register space size */
+
+/* Processing Unit Control Register (AEON_0_PUCTRL) */
+#define AEON_PUCTRL_CLRSRCFIFO 0x0010 /* clear source fifo */
+#define AEON_PUCTRL_STOP 0x0008 /* stop pu */
+#define AEON_PUCTRL_LOCKRAM 0x0004 /* lock ram */
+#define AEON_PUCTRL_DMAENA 0x0002 /* enable dma */
+#define AEON_PUCTRL_RESET 0x0001 /* Reset processing unit */
+
+/* Processing Unit Interrupt Status Register (AEON_0_PUISR) */
+#define AEON_PUISR_CMDINVAL 0x8000 /* Invalid command interrupt */
+#define AEON_PUISR_DATAERR 0x4000 /* Data error interrupt */
+#define AEON_PUISR_SRCFIFO 0x2000 /* Source FIFO ready interrupt */
+#define AEON_PUISR_DSTFIFO 0x1000 /* Destination FIFO ready interrupt */
+#define AEON_PUISR_DSTOVER 0x0200 /* Destination overrun interrupt */
+#define AEON_PUISR_SRCCMD 0x0080 /* Source command interrupt */
+#define AEON_PUISR_SRCCTX 0x0040 /* Source context interrupt */
+#define AEON_PUISR_SRCDATA 0x0020 /* Source data interrupt */
+#define AEON_PUISR_DSTDATA 0x0010 /* Destination data interrupt */
+#define AEON_PUISR_DSTRESULT 0x0004 /* Destination result interrupt */
+
+/* Processing Unit Configuration Register (AEON_0_PUCNFG) */
+#define AEON_PUCNFG_DRAMMASK 0xe000 /* DRAM size mask */
+#define AEON_PUCNFG_DSZ_256K 0x0000 /* 256k dram */
+#define AEON_PUCNFG_DSZ_512K 0x2000 /* 512k dram */
+#define AEON_PUCNFG_DSZ_1M 0x4000 /* 1m dram */
+#define AEON_PUCNFG_DSZ_2M 0x6000 /* 2m dram */
+#define AEON_PUCNFG_DSZ_4M 0x8000 /* 4m dram */
+#define AEON_PUCNFG_DSZ_8M 0xa000 /* 8m dram */
+#define AEON_PUNCFG_DSZ_16M 0xc000 /* 16m dram */
+#define AEON_PUCNFG_DSZ_32M 0xe000 /* 32m dram */
+#define AEON_PUCNFG_DRAMREFRESH 0x1800 /* DRAM refresh rate mask */
+#define AEON_PUCNFG_DRFR_512 0x0000 /* 512 divisor of ECLK */
+#define AEON_PUCNFG_DRFR_256 0x0800 /* 256 divisor of ECLK */
+#define AEON_PUCNFG_DRFR_128 0x1000 /* 128 divisor of ECLK */
+#define AEON_PUCNFG_TCALLPHASES 0x0200 /* your guess is as good as mine... */
+#define AEON_PUCNFG_TCDRVTOTEM 0x0100 /* your guess is as good as mine... */
+#define AEON_PUCNFG_BIGENDIAN 0x0080 /* DMA big endian mode */
+#define AEON_PUCNFG_BUS32 0x0040 /* Bus width 32bits */
+#define AEON_PUCNFG_BUS16 0x0000 /* Bus width 16 bits */
+#define AEON_PUCNFG_CHIPID 0x0020 /* Allow chipid from PUSTAT */
+#define AEON_PUCNFG_DRAM 0x0010 /* Context RAM is DRAM */
+#define AEON_PUCNFG_SRAM 0x0000 /* Context RAM is SRAM */
+#define AEON_PUCNFG_COMPSING 0x0004 /* Enable single compression context */
+#define AEON_PUCNFG_ENCCNFG 0x0002 /* Encryption configuration */
+
+/* Processing Unit Interrupt Enable Register (AEON_0_PUIER) */
+#define AEON_PUIER_CMDINVAL 0x8000 /* Invalid command interrupt */
+#define AEON_PUIER_DATAERR 0x4000 /* Data error interrupt */
+#define AEON_PUIER_SRCFIFO 0x2000 /* Source FIFO ready interrupt */
+#define AEON_PUIER_DSTFIFO 0x1000 /* Destination FIFO ready interrupt */
+#define AEON_PUIER_DSTOVER 0x0200 /* Destination overrun interrupt */
+#define AEON_PUIER_SRCCMD 0x0080 /* Source command interrupt */
+#define AEON_PUIER_SRCCTX 0x0040 /* Source context interrupt */
+#define AEON_PUIER_SRCDATA 0x0020 /* Source data interrupt */
+#define AEON_PUIER_DSTDATA 0x0010 /* Destination data interrupt */
+#define AEON_PUIER_DSTRESULT 0x0004 /* Destination result interrupt */
+
+/* Processing Unit Status Register/Chip ID (AEON_0_PUSTAT) */
+#define AEON_PUSTAT_CMDINVAL 0x8000 /* Invalid command interrupt */
+#define AEON_PUSTAT_DATAERR 0x4000 /* Data error interrupt */
+#define AEON_PUSTAT_SRCFIFO 0x2000 /* Source FIFO ready interrupt */
+#define AEON_PUSTAT_DSTFIFO 0x1000 /* Destination FIFO ready interrupt */
+#define AEON_PUSTAT_DSTOVER 0x0200 /* Destination overrun interrupt */
+#define AEON_PUSTAT_SRCCMD 0x0080 /* Source command interrupt */
+#define AEON_PUSTAT_SRCCTX 0x0040 /* Source context interrupt */
+#define AEON_PUSTAT_SRCDATA 0x0020 /* Source data interrupt */
+#define AEON_PUSTAT_DSTDATA 0x0010 /* Destination data interrupt */
+#define AEON_PUSTAT_DSTRESULT 0x0004 /* Destination result interrupt */
+#define AEON_PUSTAT_CHIPREV 0x00ff /* Chip revision mask */
+#define AEON_PUSTAT_CHIPENA 0xff00 /* Chip enabled mask */
+#define AEON_PUSTAT_ENA_2 0x1100 /* Level 2 enabled */
+#define AEON_PUSTAT_ENA_1 0x1000 /* Level 1 enabled */
+#define AEON_PUSTAT_ENA_0 0x3000 /* Level 0 enabled */
+#define AEON_PUSTAT_REV_2 0x0020 /* 7751 PT6/2 */
+#define AEON_PUSTAT_REV_3 0x0030 /* 7751 PT6/3 */
+
+/* FIFO Status Register (AEON_0_FIFOSTAT) */
+#define AEON_FIFOSTAT_SRC 0x7f00 /* Source FIFO available */
+#define AEON_FIFOSTAT_DST 0x007f /* Destination FIFO available */
+
+/* FIFO Configuration Register (AEON_0_FIFOCNFG) */
+#define AEON_FIFOCNFG_THRESHOLD 0x0400 /* must be written as 1 */
+
+/*
+ * DMA Interface Registers (offset from BASEREG1)
+ */
+#define AEON_1_DMA_CRAR 0x0c /* DMA Command Ring Address */
+#define AEON_1_DMA_SRAR 0x1c /* DMA Source Ring Address */
+#define AEON_1_DMA_RRAR 0x2c /* DMA Resultt Ring Address */
+#define AEON_1_DMA_DRAR 0x3c /* DMA Destination Ring Address */
+#define AEON_1_DMA_CSR 0x40 /* DMA Status and Control */
+#define AEON_1_DMA_IER 0x44 /* DMA Interrupt Enable */
+#define AEON_1_DMA_CNFG 0x48 /* DMA Configuration */
+#define AEON_1_REVID 0x98 /* Revision ID */
+
+/* DMA Status and Control Register (AEON_1_DMA_CSR) */
+#define AEON_DMACSR_D_CTRLMASK 0xc0000000 /* Destinition Ring Control */
+#define AEON_DMACSR_D_CTRL_NOP 0x00000000 /* Dest. Control: no-op */
+#define AEON_DMACSR_D_CTRL_DIS 0x40000000 /* Dest. Control: disable */
+#define AEON_DMACSR_D_CTRL_ENA 0x80000000 /* Dest. Control: enable */
+#define AEON_DMACSR_D_ABORT 0x20000000 /* Destinition Ring PCIAbort */
+#define AEON_DMACSR_D_DONE 0x10000000 /* Destinition Ring Done */
+#define AEON_DMACSR_D_LAST 0x08000000 /* Destinition Ring Last */
+#define AEON_DMACSR_D_WAIT 0x04000000 /* Destinition Ring Waiting */
+#define AEON_DMACSR_D_OVER 0x02000000 /* Destinition Ring Overflow */
+#define AEON_DMACSR_R_CTRL 0x00c00000 /* Result Ring Control */
+#define AEON_DMACSR_R_CTRL_NOP 0x00000000 /* Result Control: no-op */
+#define AEON_DMACSR_R_CTRL_DIS 0x00400000 /* Result Control: disable */
+#define AEON_DMACSR_R_CTRL_ENA 0x00800000 /* Result Control: enable */
+#define AEON_DMACSR_R_ABORT 0x00200000 /* Result Ring PCI Abort */
+#define AEON_DMACSR_R_DONE 0x00100000 /* Result Ring Done */
+#define AEON_DMACSR_R_LAST 0x00080000 /* Result Ring Last */
+#define AEON_DMACSR_R_WAIT 0x00040000 /* Result Ring Waiting */
+#define AEON_DMACSR_R_OVER 0x00020000 /* Result Ring Overflow */
+#define AEON_DMACSR_S_CTRL 0x0000c000 /* Source Ring Control */
+#define AEON_DMACSR_S_CTRL_NOP 0x00000000 /* Source Control: no-op */
+#define AEON_DMACSR_S_CTRL_DIS 0x00004000 /* Source Control: disable */
+#define AEON_DMACSR_S_CTRL_ENA 0x00008000 /* Source Control: enable */
+#define AEON_DMACSR_S_ABORT 0x00002000 /* Source Ring PCI Abort */
+#define AEON_DMACSR_S_DONE 0x00001000 /* Source Ring Done */
+#define AEON_DMACSR_S_LAST 0x00000800 /* Source Ring Last */
+#define AEON_DMACSR_S_WAIT 0x00000400 /* Source Ring Waiting */
+#define AEON_DMACSR_S_OVER 0x00000200 /* Source Ring Overflow */
+#define AEON_DMACSR_C_CTRL 0x000000c0 /* Command Ring Control */
+#define AEON_DMACSR_C_CTRL_NOP 0x00000000 /* Command Control: no-op */
+#define AEON_DMACSR_C_CTRL_DIS 0x00000040 /* Command Control: disable */
+#define AEON_DMACSR_C_CTRL_ENA 0x00000080 /* Command Control: enable */
+#define AEON_DMACSR_C_ABORT 0x00000020 /* Command Ring PCI Abort */
+#define AEON_DMACSR_C_DONE 0x00000010 /* Command Ring Done */
+#define AEON_DMACSR_C_LAST 0x00000008 /* Command Ring Last */
+#define AEON_DMACSR_C_WAIT 0x00000004 /* Command Ring Waiting */
+#define AEON_DMACSR_C_EIRQ 0x00000001 /* Command Ring Engine IRQ */
+
+/* DMA Interrupt Enable Register (AEON_1_DMA_IER) */
+#define AEON_DMAIER_D_ABORT 0x20000000 /* Destination Ring PCIAbort */
+#define AEON_DMAIER_D_DONE 0x10000000 /* Destination Ring Done */
+#define AEON_DMAIER_D_LAST 0x08000000 /* Destination Ring Last */
+#define AEON_DMAIER_D_WAIT 0x04000000 /* Destination Ring Waiting */
+#define AEON_DMAIER_D_OVER 0x02000000 /* Destination Ring Overflow */
+#define AEON_DMAIER_R_ABORT 0x00200000 /* Result Ring PCI Abort */
+#define AEON_DMAIER_R_DONE 0x00100000 /* Result Ring Done */
+#define AEON_DMAIER_R_LAST 0x00080000 /* Result Ring Last */
+#define AEON_DMAIER_R_WAIT 0x00040000 /* Result Ring Waiting */
+#define AEON_DMAIER_R_OVER 0x00020000 /* Result Ring Overflow */
+#define AEON_DMAIER_S_ABORT 0x00002000 /* Source Ring PCI Abort */
+#define AEON_DMAIER_S_DONE 0x00001000 /* Source Ring Done */
+#define AEON_DMAIER_S_LAST 0x00000800 /* Source Ring Last */
+#define AEON_DMAIER_S_WAIT 0x00000400 /* Source Ring Waiting */
+#define AEON_DMAIER_S_OVER 0x00000200 /* Source Ring Overflow */
+#define AEON_DMAIER_C_ABORT 0x00000020 /* Command Ring PCI Abort */
+#define AEON_DMAIER_C_DONE 0x00000010 /* Command Ring Done */
+#define AEON_DMAIER_C_LAST 0x00000008 /* Command Ring Last */
+#define AEON_DMAIER_C_WAIT 0x00000004 /* Command Ring Waiting */
+#define AEON_DMAIER_ENGINE 0x00000001 /* Engine IRQ */
+
+/* DMA Configuration Register (AEON_1_DMA_CNFG) */
+#define AEON_DMACNFG_BIGENDIAN 0x10000000 /* big endian mode */
+#define AEON_DMACNFG_POLLFREQ 0x00ff0000 /* Poll frequency mask */
+#define AEON_DMACNFG_UNLOCK 0x00000800
+#define AEON_DMACNFG_POLLINVAL 0x00000700 /* Invalid Poll Scalar */
+#define AEON_DMACNFG_LAST 0x00000010 /* Host control LAST bit */
+#define AEON_DMACNFG_MODE 0x00000004 /* DMA mode */
+#define AEON_DMACNFG_DMARESET 0x00000002 /* DMA Reset # */
+#define AEON_DMACNFG_MSTRESET 0x00000001 /* Master Reset # */
#define WRITE_REG_0(sc,reg,val) \
bus_space_write_4((sc)->sc_st0, (sc)->sc_sh0, reg, val)
@@ -148,18 +315,6 @@ struct aeon_softc {
/*
* Register offsets in register set 1
*/
-#define AEON_CMDR_ADDR 0x0c
-#define AEON_SRCR_ADDR 0x1c
-#define AEON_RESR_ADDR 0x2c
-#define AEON_DSTR_ADDR 0x3c
-#define AEON_STATUS 0x40
-#define AEON_IRQEN 0x44
-
-#define AEON_DMA_CFG 0x48
-#define AEON_DMA_CFG_NOBOARDRESET 0x00000001
-#define AEON_DMA_CFG_NODMARESET 0x00000002
-#define AEON_DMA_CFG_NEED 0x00000004
-#define AEON_DMA_CFG_HOSTLAST 0x00000010
#define AEON_UNLOCK_SECRET1 0xf4
#define AEON_UNLOCK_SECRET2 0xfc
@@ -169,65 +324,6 @@ struct aeon_softc {
#define READ_REG_1(sc,reg) \
bus_space_read_4((sc)->sc_st1, (sc)->sc_sh1, reg)
-/*
- * Initial register values
- */
-
-/*
- * Status Register
- *
- * The value below enables polling on all 4 descriptor rings and
- * writes a "1" to every status bit in the register. (Writing "1"
- * clears the bit.)
- */
-#define AEON_INIT_STATUS_REG ((1<<31)|(1<<23)|(1<<15)|(1<<7))
-
-/*
- * Interrupt Enable Register
- *
- * Initial value sets all interrupts to off except the "mask done"
- * interrupt of the the result descriptor ring.
- */
-#define AEON_INIT_INTERRUPT_ENABLE_REG (AEON_INTR_ON_RESULT_DONE)
-
-/*
- * DMA Configuration Register
- *
- * Initial value sets the polling scalar and frequency, and puts
- * the host (not the AEON board) in charge of "last" bits in the
- * dest data and result descriptor rings.
- */
-#define AEON_INIT_DMA_CONFIG_REG \
- (AEON_DMA_CFG_NOBOARDRESET | AEON_DMA_CFG_NODMARESET | \
- AEON_DMA_CFG_NEED | \
- AEON_DMA_CFG_HOSTLAST | /* host controls last bit in all rings */ \
- (AEON_POLL_SCALAR << 8) | /* setting poll scalar value */ \
- (AEON_POLL_FREQUENCY << 16)) /* setting poll frequency value */
-
-/*
- * RAM Configuration Register
- *
- * Initial value sets the ecryption context size to 128 bytes (if using
- * RC4 bump it to 512, but you'll decrease the number of available
- * sessions). We don't configure multiple compression histories -- since
- * IPSec doesn't use them.
- *
- * NOTE: Use the AEON_RAM_CONFIG_INIT() macro instead of the
- * variable, since DRAM/SRAM detection is not determined staticly.
- */
-#define AEON_INIT_RAM_CONFIG_REG \
- ((0x0 << 1) | /* RAM Encrypt: 0 for 128 bytes, 1 for 512 bytes */ \
- (0x1 << 2) | /* RAM Comp cfg: 1 for single compression history */ \
- 0x4B40) /* Setting fixed bits required by the register */
-
-/*
- * Expand Register
- *
- * The only bit in this register is the expand bit at position 9. It's
- * cleared by writing a 1 to it.
- */
-#define AEON_INIT_EXPAND_REG (0x1 << 9)
-
/*********************************************************************
* Structs for board commands
*
@@ -299,12 +395,6 @@ typedef struct aeon_command_buf_data {
} aeon_command_buf_data_t;
/*
- * Values for the interrupt enable register
- */
-#define AEON_INTR_ON_RESULT_DONE (1 << 20)
-#define AEON_INTR_ON_COMMAND_WAITING (1 << 2)
-
-/*
* The poll frequency and poll scalar defines are unshifted values used
* to set fields in the DMA Configuration Register.
*/
diff --git a/sys/dev/pci/hifn7751.c b/sys/dev/pci/hifn7751.c
index 05e0b4ce2ae..07f51f0ce56 100644
--- a/sys/dev/pci/hifn7751.c
+++ b/sys/dev/pci/hifn7751.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: hifn7751.c,v 1.8 2000/03/10 19:54:24 deraadt Exp $ */
+/* $OpenBSD: hifn7751.c,v 1.9 2000/03/15 14:55:51 jason Exp $ */
/*
* Invertex AEON driver
@@ -135,8 +135,7 @@ aeon_attach(parent, self, aux)
return;
}
- if (pci_mem_find(pc, pa->pa_tag, PCI_BASE_ADDRESS_0, &iobase, &iosize,
- NULL)){
+ if (pci_mem_find(pc, pa->pa_tag, AEON_BAR0, &iobase, &iosize, NULL)) {
printf(": can't find mem space\n");
return;
}
@@ -146,8 +145,7 @@ aeon_attach(parent, self, aux)
}
sc->sc_st0 = pa->pa_memt;
- if (pci_mem_find(pc, pa->pa_tag, PCI_BASE_ADDRESS_1, &iobase, &iosize,
- NULL)){
+ if (pci_mem_find(pc, pa->pa_tag, AEON_BAR1, &iobase, &iosize, NULL)) {
printf(": can't find mem space\n");
return;
}
@@ -247,8 +245,8 @@ aeon_reset_board(sc)
* Set polling in the DMA configuration register to zero. 0x7 avoids
* resetting the board and zeros out the other fields.
*/
- WRITE_REG_1(sc, AEON_DMA_CFG, AEON_DMA_CFG_NOBOARDRESET |
- AEON_DMA_CFG_NODMARESET | AEON_DMA_CFG_NEED);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_MSTRESET |
+ AEON_DMACNFG_DMARESET | AEON_DMACNFG_MODE);
/*
* Now that polling has been disabled, we have to wait 1 ms
@@ -260,7 +258,7 @@ aeon_reset_board(sc)
* field, the BRD reset field, and the manditory 1 at position 2.
* Every other field is set to zero.
*/
- WRITE_REG_1(sc, AEON_DMA_CFG, AEON_DMA_CFG_NEED);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_MODE);
/*
* Wait another millisecond for the board to reset.
@@ -270,8 +268,8 @@ aeon_reset_board(sc)
/*
* Turn off the reset! (No joke.)
*/
- WRITE_REG_1(sc, AEON_DMA_CFG, AEON_DMA_CFG_NOBOARDRESET |
- AEON_DMA_CFG_NODMARESET | AEON_DMA_CFG_NEED);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_MSTRESET |
+ AEON_DMACNFG_DMARESET | AEON_DMACNFG_MODE);
}
u_int32_t
@@ -310,7 +308,7 @@ struct pci2id {
PCI_VENDOR_HIFN,
PCI_PRODUCT_HIFN_7751,
{ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00 } /* XXX incorrect */
+ 0x00, 0x00, 0x00, 0x00, 0x00 }
},
};
@@ -342,16 +340,16 @@ aeon_enable_crypto(sc, pciid)
return (1);
}
- ramcfg = READ_REG_0(sc, AEON_RAM_CONFIG);
- dmacfg = READ_REG_1(sc, AEON_DMA_CFG);
+ ramcfg = READ_REG_0(sc, AEON_0_PUCNFG);
+ dmacfg = READ_REG_1(sc, AEON_1_DMA_CNFG);
/*
* The RAM config register's encrypt level bit needs to be set before
* every read performed on the encryption level register.
*/
- WRITE_REG_0(sc, AEON_RAM_CONFIG, ramcfg | 0x20);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, ramcfg | AEON_PUCNFG_CHIPID);
- encl = READ_REG_0(sc, AEON_CRYPTLEVEL);
+ encl = READ_REG_0(sc, AEON_0_PUSTAT);
/*
* Make sure we don't re-unlock. Two unlocks kills chip until the
@@ -362,8 +360,8 @@ aeon_enable_crypto(sc, pciid)
printf("%s: Strong Crypto already enabled!\n",
sc->sc_dv.dv_xname);
#endif
- WRITE_REG_0(sc, AEON_RAM_CONFIG, ramcfg);
- WRITE_REG_1(sc, AEON_DMA_CFG, dmacfg);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, ramcfg);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, dmacfg);
return 0; /* success */
}
@@ -374,7 +372,8 @@ aeon_enable_crypto(sc, pciid)
return 1;
}
- WRITE_REG_1(sc, AEON_DMA_CFG, 0x807);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_UNLOCK |
+ AEON_DMACNFG_MSTRESET | AEON_DMACNFG_DMARESET | AEON_DMACNFG_MODE);
addr = READ_REG_1(sc, AEON_UNLOCK_SECRET1);
WRITE_REG_1(sc, AEON_UNLOCK_SECRET2, 0);
@@ -385,8 +384,8 @@ aeon_enable_crypto(sc, pciid)
DELAY(1000);
}
- WRITE_REG_0(sc, AEON_RAM_CONFIG, ramcfg | 0x20);
- encl = READ_REG_0(sc, AEON_CRYPTLEVEL);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, ramcfg | AEON_PUCNFG_CHIPID);
+ encl = READ_REG_0(sc, AEON_0_PUSTAT);
#ifdef AEON_DEBUG
if (encl != 0x1020 && encl != 0x1120)
@@ -395,8 +394,8 @@ aeon_enable_crypto(sc, pciid)
printf("Encryption engine enabled successfully!");
#endif
- WRITE_REG_0(sc, AEON_RAM_CONFIG, ramcfg);
- WRITE_REG_1(sc, AEON_DMA_CFG, dmacfg);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, ramcfg);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, dmacfg);
switch(encl) {
case 0x3020:
@@ -425,30 +424,38 @@ aeon_init_pci_registers(sc)
struct aeon_softc *sc;
{
/* write fixed values needed by the Initialization registers */
- WRITE_REG_0(sc, AEON_INIT_1, 0x2);
- WRITE_REG_0(sc, AEON_INIT_2, 0x400);
- WRITE_REG_0(sc, AEON_INIT_3, 0x200);
+ WRITE_REG_0(sc, AEON_0_PUCTRL, AEON_PUCTRL_DMAENA);
+ WRITE_REG_0(sc, AEON_0_FIFOCNFG, AEON_FIFOCNFG_THRESHOLD);
+ WRITE_REG_0(sc, AEON_0_PUIER, AEON_PUIER_DSTOVER);
/* write all 4 ring address registers */
- WRITE_REG_1(sc, AEON_CMDR_ADDR, vtophys(sc->sc_dma->cmdr));
- WRITE_REG_1(sc, AEON_SRCR_ADDR, vtophys(sc->sc_dma->srcr));
- WRITE_REG_1(sc, AEON_DSTR_ADDR, vtophys(sc->sc_dma->dstr));
- WRITE_REG_1(sc, AEON_RESR_ADDR, vtophys(sc->sc_dma->resr));
+ WRITE_REG_1(sc, AEON_1_DMA_CRAR, vtophys(sc->sc_dma->cmdr));
+ WRITE_REG_1(sc, AEON_1_DMA_SRAR, vtophys(sc->sc_dma->srcr));
+ WRITE_REG_1(sc, AEON_1_DMA_DRAR, vtophys(sc->sc_dma->dstr));
+ WRITE_REG_1(sc, AEON_1_DMA_RRAR, vtophys(sc->sc_dma->resr));
/* write status register */
- WRITE_REG_1(sc, AEON_STATUS, AEON_INIT_STATUS_REG);
- WRITE_REG_1(sc, AEON_IRQEN, AEON_INIT_INTERRUPT_ENABLE_REG);
+ WRITE_REG_1(sc, AEON_1_DMA_CSR, AEON_DMACSR_D_CTRL_ENA |
+ AEON_DMACSR_R_CTRL_ENA | AEON_DMACSR_S_CTRL_ENA |
+ AEON_DMACSR_C_CTRL_ENA);
+ WRITE_REG_1(sc, AEON_1_DMA_IER, AEON_DMAIER_R_DONE);
#if 0
#if BYTE_ORDER == BIG_ENDIAN
(0x1 << 7) |
#endif
#endif
- WRITE_REG_0(sc, AEON_RAM_CONFIG, AEON_INIT_RAM_CONFIG_REG |
- sc->sc_drammodel << 4);
-
- WRITE_REG_0(sc, AEON_EXPAND, AEON_INIT_EXPAND_REG);
- WRITE_REG_1(sc, AEON_DMA_CFG, AEON_INIT_DMA_CONFIG_REG);
+ WRITE_REG_0(sc, AEON_0_PUCNFG, AEON_PUCNFG_COMPSING |
+ AEON_PUCNFG_DRFR_128 | AEON_PUCNFG_TCALLPHASES |
+ AEON_PUCNFG_TCDRVTOTEM | AEON_PUCNFG_BUS32 |
+ (sc->sc_drammodel ? AEON_PUCNFG_DRAM : AEON_PUCNFG_SRAM));
+
+ WRITE_REG_0(sc, AEON_0_PUISR, AEON_PUISR_DSTOVER);
+ WRITE_REG_1(sc, AEON_1_DMA_CNFG, AEON_DMACNFG_MSTRESET |
+ AEON_DMACNFG_DMARESET | AEON_DMACNFG_MODE |
+ AEON_DMACNFG_LAST |
+ ((AEON_POLL_FREQUENCY << 16 ) & AEON_DMACNFG_POLLFREQ) |
+ ((AEON_POLL_SCALAR << 8) & AEON_DMACNFG_POLLINVAL));
}
/*
@@ -905,7 +912,7 @@ aeon_crypto(struct aeon_command *cmd)
printf("%s: Entering cmd: stat %8x ien %8x u %d/%d/%d/%d n %d/%d\n",
sc->sc_dv.dv_xname,
- READ_REG_1(sc, AEON_STATUS), READ_REG_1(sc, AEON_IRQEN),
+ READ_REG_1(sc, AEON_1_DMA_CSR), READ_REG_1(sc, AEON_1_DMA_IER),
dma->cmdu, dma->srcu, dma->dstu, dma->resu, cmd->src_npa,
cmd->dst_npa);
@@ -993,8 +1000,8 @@ aeon_crypto(struct aeon_command *cmd)
* than one command in the queue.
*/
if (dma->slots_in_use > 1) {
- WRITE_REG_1(sc, AEON_IRQEN,
- AEON_INTR_ON_RESULT_DONE | AEON_INTR_ON_COMMAND_WAITING);
+ WRITE_REG_1(sc, AEON_1_DMA_IER,
+ AEON_DMAIER_R_DONE | AEON_DMAIER_C_WAIT);
}
/*
@@ -1014,7 +1021,7 @@ aeon_crypto(struct aeon_command *cmd)
printf("%s: command: stat %8x ier %8x\n",
sc->sc_dv.dv_xname,
- READ_REG_1(sc, AEON_STATUS), READ_REG_1(sc, AEON_IRQEN));
+ READ_REG_1(sc, AEON_1_DMA_CSR), READ_REG_1(sc, AEON_1_DMA_IER));
splx(s);
return 0; /* success */
@@ -1026,19 +1033,25 @@ aeon_intr(arg)
{
struct aeon_softc *sc = arg;
struct aeon_dma *dma = sc->sc_dma;
+ u_int32_t dmacsr;
+
+ dmacsr = READ_REG_1(sc, AEON_1_DMA_CSR);
printf("%s: irq: stat %8x ien %8x u %d/%d/%d/%d\n",
sc->sc_dv.dv_xname,
- READ_REG_1(sc, AEON_STATUS), READ_REG_1(sc, AEON_IRQEN),
+ dmacsr, READ_REG_1(sc, AEON_1_DMA_IER),
dma->cmdu, dma->srcu, dma->dstu, dma->resu);
-
- if (dma->slots_in_use == 0 && (READ_REG_1(sc, AEON_STATUS) & (1 << 2))) {
+
+ if ((dmacsr & (AEON_DMACSR_C_WAIT|AEON_DMACSR_R_DONE)) == 0)
+ return (0);
+
+ if ((dma->slots_in_use == 0) && (dmacsr & AEON_DMACSR_C_WAIT)) {
/*
* If no slots to process and we received a "waiting on
* result" interrupt, we disable the "waiting on result"
* (by clearing it).
*/
- WRITE_REG_1(sc, AEON_IRQEN, AEON_INTR_ON_RESULT_DONE);
+ WRITE_REG_1(sc, AEON_1_DMA_IER, AEON_DMAIER_R_DONE);
} else {
if (dma->slots_in_use > AEON_D_RSIZE)
printf("%s: Internal Error -- ring overflow\n",
@@ -1078,6 +1091,6 @@ aeon_intr(arg)
* register. If we still have slots to process and we received a
* waiting interrupt, this will interupt us again.
*/
- WRITE_REG_1(sc, AEON_STATUS, (1 << 20) | (1 << 2));
+ WRITE_REG_1(sc, AEON_1_DMA_CSR, AEON_DMACSR_R_DONE|AEON_DMACSR_C_WAIT);
return (1);
}
diff --git a/sys/dev/pci/hifn7751reg.h b/sys/dev/pci/hifn7751reg.h
index 836cae8f592..cee7b06ae87 100644
--- a/sys/dev/pci/hifn7751reg.h
+++ b/sys/dev/pci/hifn7751reg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: hifn7751reg.h,v 1.5 2000/03/10 08:45:00 mickey Exp $ */
+/* $OpenBSD: hifn7751reg.h,v 1.6 2000/03/15 14:55:52 jason Exp $ */
/*
* Invertex AEON driver
@@ -40,8 +40,8 @@
* Some PCI configuration space offset defines. The names were made
* identical to the names used by the Linux kernel.
*/
-#define PCI_BASE_ADDRESS_0 0x10 /* 32 bits */
-#define PCI_BASE_ADDRESS_1 0x14 /* 32 bits */
+#define AEON_BAR0 (PCI_MAPREG_START + 0) /* PUC register map */
+#define AEON_BAR1 (PCI_MAPREG_START + 4) /* DMA register map */
/*
* Some configurable values for the driver
@@ -131,14 +131,181 @@ struct aeon_softc {
};
/*
- * Register offsets in register set 0
+ * Processing Unit Registers (offset from BASEREG0)
*/
-#define AEON_INIT_1 0x04
-#define AEON_RAM_CONFIG 0x0c
-#define AEON_EXPAND 0x08
-#define AEON_CRYPTLEVEL 0x14
-#define AEON_INIT_3 0x10
-#define AEON_INIT_2 0x1c
+#define AEON_0_PUDATA 0x00 /* Processing Unit Data */
+#define AEON_0_PUCTRL 0x04 /* Processing Unit Control */
+#define AEON_0_PUISR 0x08 /* Processing Unit Interrupt Status */
+#define AEON_0_PUCNFG 0x0c /* Processing Unit Configuration */
+#define AEON_0_PUIER 0x10 /* Processing Unit Interrupt Enable */
+#define AEON_0_PUSTAT 0x14 /* Processing Unit Status/Chip ID */
+#define AEON_0_FIFOSTAT 0x18 /* FIFO Status */
+#define AEON_0_FIFOCNFG 0x1c /* FIFO Configuration */
+#define AEON_0_SPACESIZE 0x20 /* Register space size */
+
+/* Processing Unit Control Register (AEON_0_PUCTRL) */
+#define AEON_PUCTRL_CLRSRCFIFO 0x0010 /* clear source fifo */
+#define AEON_PUCTRL_STOP 0x0008 /* stop pu */
+#define AEON_PUCTRL_LOCKRAM 0x0004 /* lock ram */
+#define AEON_PUCTRL_DMAENA 0x0002 /* enable dma */
+#define AEON_PUCTRL_RESET 0x0001 /* Reset processing unit */
+
+/* Processing Unit Interrupt Status Register (AEON_0_PUISR) */
+#define AEON_PUISR_CMDINVAL 0x8000 /* Invalid command interrupt */
+#define AEON_PUISR_DATAERR 0x4000 /* Data error interrupt */
+#define AEON_PUISR_SRCFIFO 0x2000 /* Source FIFO ready interrupt */
+#define AEON_PUISR_DSTFIFO 0x1000 /* Destination FIFO ready interrupt */
+#define AEON_PUISR_DSTOVER 0x0200 /* Destination overrun interrupt */
+#define AEON_PUISR_SRCCMD 0x0080 /* Source command interrupt */
+#define AEON_PUISR_SRCCTX 0x0040 /* Source context interrupt */
+#define AEON_PUISR_SRCDATA 0x0020 /* Source data interrupt */
+#define AEON_PUISR_DSTDATA 0x0010 /* Destination data interrupt */
+#define AEON_PUISR_DSTRESULT 0x0004 /* Destination result interrupt */
+
+/* Processing Unit Configuration Register (AEON_0_PUCNFG) */
+#define AEON_PUCNFG_DRAMMASK 0xe000 /* DRAM size mask */
+#define AEON_PUCNFG_DSZ_256K 0x0000 /* 256k dram */
+#define AEON_PUCNFG_DSZ_512K 0x2000 /* 512k dram */
+#define AEON_PUCNFG_DSZ_1M 0x4000 /* 1m dram */
+#define AEON_PUCNFG_DSZ_2M 0x6000 /* 2m dram */
+#define AEON_PUCNFG_DSZ_4M 0x8000 /* 4m dram */
+#define AEON_PUCNFG_DSZ_8M 0xa000 /* 8m dram */
+#define AEON_PUNCFG_DSZ_16M 0xc000 /* 16m dram */
+#define AEON_PUCNFG_DSZ_32M 0xe000 /* 32m dram */
+#define AEON_PUCNFG_DRAMREFRESH 0x1800 /* DRAM refresh rate mask */
+#define AEON_PUCNFG_DRFR_512 0x0000 /* 512 divisor of ECLK */
+#define AEON_PUCNFG_DRFR_256 0x0800 /* 256 divisor of ECLK */
+#define AEON_PUCNFG_DRFR_128 0x1000 /* 128 divisor of ECLK */
+#define AEON_PUCNFG_TCALLPHASES 0x0200 /* your guess is as good as mine... */
+#define AEON_PUCNFG_TCDRVTOTEM 0x0100 /* your guess is as good as mine... */
+#define AEON_PUCNFG_BIGENDIAN 0x0080 /* DMA big endian mode */
+#define AEON_PUCNFG_BUS32 0x0040 /* Bus width 32bits */
+#define AEON_PUCNFG_BUS16 0x0000 /* Bus width 16 bits */
+#define AEON_PUCNFG_CHIPID 0x0020 /* Allow chipid from PUSTAT */
+#define AEON_PUCNFG_DRAM 0x0010 /* Context RAM is DRAM */
+#define AEON_PUCNFG_SRAM 0x0000 /* Context RAM is SRAM */
+#define AEON_PUCNFG_COMPSING 0x0004 /* Enable single compression context */
+#define AEON_PUCNFG_ENCCNFG 0x0002 /* Encryption configuration */
+
+/* Processing Unit Interrupt Enable Register (AEON_0_PUIER) */
+#define AEON_PUIER_CMDINVAL 0x8000 /* Invalid command interrupt */
+#define AEON_PUIER_DATAERR 0x4000 /* Data error interrupt */
+#define AEON_PUIER_SRCFIFO 0x2000 /* Source FIFO ready interrupt */
+#define AEON_PUIER_DSTFIFO 0x1000 /* Destination FIFO ready interrupt */
+#define AEON_PUIER_DSTOVER 0x0200 /* Destination overrun interrupt */
+#define AEON_PUIER_SRCCMD 0x0080 /* Source command interrupt */
+#define AEON_PUIER_SRCCTX 0x0040 /* Source context interrupt */
+#define AEON_PUIER_SRCDATA 0x0020 /* Source data interrupt */
+#define AEON_PUIER_DSTDATA 0x0010 /* Destination data interrupt */
+#define AEON_PUIER_DSTRESULT 0x0004 /* Destination result interrupt */
+
+/* Processing Unit Status Register/Chip ID (AEON_0_PUSTAT) */
+#define AEON_PUSTAT_CMDINVAL 0x8000 /* Invalid command interrupt */
+#define AEON_PUSTAT_DATAERR 0x4000 /* Data error interrupt */
+#define AEON_PUSTAT_SRCFIFO 0x2000 /* Source FIFO ready interrupt */
+#define AEON_PUSTAT_DSTFIFO 0x1000 /* Destination FIFO ready interrupt */
+#define AEON_PUSTAT_DSTOVER 0x0200 /* Destination overrun interrupt */
+#define AEON_PUSTAT_SRCCMD 0x0080 /* Source command interrupt */
+#define AEON_PUSTAT_SRCCTX 0x0040 /* Source context interrupt */
+#define AEON_PUSTAT_SRCDATA 0x0020 /* Source data interrupt */
+#define AEON_PUSTAT_DSTDATA 0x0010 /* Destination data interrupt */
+#define AEON_PUSTAT_DSTRESULT 0x0004 /* Destination result interrupt */
+#define AEON_PUSTAT_CHIPREV 0x00ff /* Chip revision mask */
+#define AEON_PUSTAT_CHIPENA 0xff00 /* Chip enabled mask */
+#define AEON_PUSTAT_ENA_2 0x1100 /* Level 2 enabled */
+#define AEON_PUSTAT_ENA_1 0x1000 /* Level 1 enabled */
+#define AEON_PUSTAT_ENA_0 0x3000 /* Level 0 enabled */
+#define AEON_PUSTAT_REV_2 0x0020 /* 7751 PT6/2 */
+#define AEON_PUSTAT_REV_3 0x0030 /* 7751 PT6/3 */
+
+/* FIFO Status Register (AEON_0_FIFOSTAT) */
+#define AEON_FIFOSTAT_SRC 0x7f00 /* Source FIFO available */
+#define AEON_FIFOSTAT_DST 0x007f /* Destination FIFO available */
+
+/* FIFO Configuration Register (AEON_0_FIFOCNFG) */
+#define AEON_FIFOCNFG_THRESHOLD 0x0400 /* must be written as 1 */
+
+/*
+ * DMA Interface Registers (offset from BASEREG1)
+ */
+#define AEON_1_DMA_CRAR 0x0c /* DMA Command Ring Address */
+#define AEON_1_DMA_SRAR 0x1c /* DMA Source Ring Address */
+#define AEON_1_DMA_RRAR 0x2c /* DMA Resultt Ring Address */
+#define AEON_1_DMA_DRAR 0x3c /* DMA Destination Ring Address */
+#define AEON_1_DMA_CSR 0x40 /* DMA Status and Control */
+#define AEON_1_DMA_IER 0x44 /* DMA Interrupt Enable */
+#define AEON_1_DMA_CNFG 0x48 /* DMA Configuration */
+#define AEON_1_REVID 0x98 /* Revision ID */
+
+/* DMA Status and Control Register (AEON_1_DMA_CSR) */
+#define AEON_DMACSR_D_CTRLMASK 0xc0000000 /* Destinition Ring Control */
+#define AEON_DMACSR_D_CTRL_NOP 0x00000000 /* Dest. Control: no-op */
+#define AEON_DMACSR_D_CTRL_DIS 0x40000000 /* Dest. Control: disable */
+#define AEON_DMACSR_D_CTRL_ENA 0x80000000 /* Dest. Control: enable */
+#define AEON_DMACSR_D_ABORT 0x20000000 /* Destinition Ring PCIAbort */
+#define AEON_DMACSR_D_DONE 0x10000000 /* Destinition Ring Done */
+#define AEON_DMACSR_D_LAST 0x08000000 /* Destinition Ring Last */
+#define AEON_DMACSR_D_WAIT 0x04000000 /* Destinition Ring Waiting */
+#define AEON_DMACSR_D_OVER 0x02000000 /* Destinition Ring Overflow */
+#define AEON_DMACSR_R_CTRL 0x00c00000 /* Result Ring Control */
+#define AEON_DMACSR_R_CTRL_NOP 0x00000000 /* Result Control: no-op */
+#define AEON_DMACSR_R_CTRL_DIS 0x00400000 /* Result Control: disable */
+#define AEON_DMACSR_R_CTRL_ENA 0x00800000 /* Result Control: enable */
+#define AEON_DMACSR_R_ABORT 0x00200000 /* Result Ring PCI Abort */
+#define AEON_DMACSR_R_DONE 0x00100000 /* Result Ring Done */
+#define AEON_DMACSR_R_LAST 0x00080000 /* Result Ring Last */
+#define AEON_DMACSR_R_WAIT 0x00040000 /* Result Ring Waiting */
+#define AEON_DMACSR_R_OVER 0x00020000 /* Result Ring Overflow */
+#define AEON_DMACSR_S_CTRL 0x0000c000 /* Source Ring Control */
+#define AEON_DMACSR_S_CTRL_NOP 0x00000000 /* Source Control: no-op */
+#define AEON_DMACSR_S_CTRL_DIS 0x00004000 /* Source Control: disable */
+#define AEON_DMACSR_S_CTRL_ENA 0x00008000 /* Source Control: enable */
+#define AEON_DMACSR_S_ABORT 0x00002000 /* Source Ring PCI Abort */
+#define AEON_DMACSR_S_DONE 0x00001000 /* Source Ring Done */
+#define AEON_DMACSR_S_LAST 0x00000800 /* Source Ring Last */
+#define AEON_DMACSR_S_WAIT 0x00000400 /* Source Ring Waiting */
+#define AEON_DMACSR_S_OVER 0x00000200 /* Source Ring Overflow */
+#define AEON_DMACSR_C_CTRL 0x000000c0 /* Command Ring Control */
+#define AEON_DMACSR_C_CTRL_NOP 0x00000000 /* Command Control: no-op */
+#define AEON_DMACSR_C_CTRL_DIS 0x00000040 /* Command Control: disable */
+#define AEON_DMACSR_C_CTRL_ENA 0x00000080 /* Command Control: enable */
+#define AEON_DMACSR_C_ABORT 0x00000020 /* Command Ring PCI Abort */
+#define AEON_DMACSR_C_DONE 0x00000010 /* Command Ring Done */
+#define AEON_DMACSR_C_LAST 0x00000008 /* Command Ring Last */
+#define AEON_DMACSR_C_WAIT 0x00000004 /* Command Ring Waiting */
+#define AEON_DMACSR_C_EIRQ 0x00000001 /* Command Ring Engine IRQ */
+
+/* DMA Interrupt Enable Register (AEON_1_DMA_IER) */
+#define AEON_DMAIER_D_ABORT 0x20000000 /* Destination Ring PCIAbort */
+#define AEON_DMAIER_D_DONE 0x10000000 /* Destination Ring Done */
+#define AEON_DMAIER_D_LAST 0x08000000 /* Destination Ring Last */
+#define AEON_DMAIER_D_WAIT 0x04000000 /* Destination Ring Waiting */
+#define AEON_DMAIER_D_OVER 0x02000000 /* Destination Ring Overflow */
+#define AEON_DMAIER_R_ABORT 0x00200000 /* Result Ring PCI Abort */
+#define AEON_DMAIER_R_DONE 0x00100000 /* Result Ring Done */
+#define AEON_DMAIER_R_LAST 0x00080000 /* Result Ring Last */
+#define AEON_DMAIER_R_WAIT 0x00040000 /* Result Ring Waiting */
+#define AEON_DMAIER_R_OVER 0x00020000 /* Result Ring Overflow */
+#define AEON_DMAIER_S_ABORT 0x00002000 /* Source Ring PCI Abort */
+#define AEON_DMAIER_S_DONE 0x00001000 /* Source Ring Done */
+#define AEON_DMAIER_S_LAST 0x00000800 /* Source Ring Last */
+#define AEON_DMAIER_S_WAIT 0x00000400 /* Source Ring Waiting */
+#define AEON_DMAIER_S_OVER 0x00000200 /* Source Ring Overflow */
+#define AEON_DMAIER_C_ABORT 0x00000020 /* Command Ring PCI Abort */
+#define AEON_DMAIER_C_DONE 0x00000010 /* Command Ring Done */
+#define AEON_DMAIER_C_LAST 0x00000008 /* Command Ring Last */
+#define AEON_DMAIER_C_WAIT 0x00000004 /* Command Ring Waiting */
+#define AEON_DMAIER_ENGINE 0x00000001 /* Engine IRQ */
+
+/* DMA Configuration Register (AEON_1_DMA_CNFG) */
+#define AEON_DMACNFG_BIGENDIAN 0x10000000 /* big endian mode */
+#define AEON_DMACNFG_POLLFREQ 0x00ff0000 /* Poll frequency mask */
+#define AEON_DMACNFG_UNLOCK 0x00000800
+#define AEON_DMACNFG_POLLINVAL 0x00000700 /* Invalid Poll Scalar */
+#define AEON_DMACNFG_LAST 0x00000010 /* Host control LAST bit */
+#define AEON_DMACNFG_MODE 0x00000004 /* DMA mode */
+#define AEON_DMACNFG_DMARESET 0x00000002 /* DMA Reset # */
+#define AEON_DMACNFG_MSTRESET 0x00000001 /* Master Reset # */
#define WRITE_REG_0(sc,reg,val) \
bus_space_write_4((sc)->sc_st0, (sc)->sc_sh0, reg, val)
@@ -148,18 +315,6 @@ struct aeon_softc {
/*
* Register offsets in register set 1
*/
-#define AEON_CMDR_ADDR 0x0c
-#define AEON_SRCR_ADDR 0x1c
-#define AEON_RESR_ADDR 0x2c
-#define AEON_DSTR_ADDR 0x3c
-#define AEON_STATUS 0x40
-#define AEON_IRQEN 0x44
-
-#define AEON_DMA_CFG 0x48
-#define AEON_DMA_CFG_NOBOARDRESET 0x00000001
-#define AEON_DMA_CFG_NODMARESET 0x00000002
-#define AEON_DMA_CFG_NEED 0x00000004
-#define AEON_DMA_CFG_HOSTLAST 0x00000010
#define AEON_UNLOCK_SECRET1 0xf4
#define AEON_UNLOCK_SECRET2 0xfc
@@ -169,65 +324,6 @@ struct aeon_softc {
#define READ_REG_1(sc,reg) \
bus_space_read_4((sc)->sc_st1, (sc)->sc_sh1, reg)
-/*
- * Initial register values
- */
-
-/*
- * Status Register
- *
- * The value below enables polling on all 4 descriptor rings and
- * writes a "1" to every status bit in the register. (Writing "1"
- * clears the bit.)
- */
-#define AEON_INIT_STATUS_REG ((1<<31)|(1<<23)|(1<<15)|(1<<7))
-
-/*
- * Interrupt Enable Register
- *
- * Initial value sets all interrupts to off except the "mask done"
- * interrupt of the the result descriptor ring.
- */
-#define AEON_INIT_INTERRUPT_ENABLE_REG (AEON_INTR_ON_RESULT_DONE)
-
-/*
- * DMA Configuration Register
- *
- * Initial value sets the polling scalar and frequency, and puts
- * the host (not the AEON board) in charge of "last" bits in the
- * dest data and result descriptor rings.
- */
-#define AEON_INIT_DMA_CONFIG_REG \
- (AEON_DMA_CFG_NOBOARDRESET | AEON_DMA_CFG_NODMARESET | \
- AEON_DMA_CFG_NEED | \
- AEON_DMA_CFG_HOSTLAST | /* host controls last bit in all rings */ \
- (AEON_POLL_SCALAR << 8) | /* setting poll scalar value */ \
- (AEON_POLL_FREQUENCY << 16)) /* setting poll frequency value */
-
-/*
- * RAM Configuration Register
- *
- * Initial value sets the ecryption context size to 128 bytes (if using
- * RC4 bump it to 512, but you'll decrease the number of available
- * sessions). We don't configure multiple compression histories -- since
- * IPSec doesn't use them.
- *
- * NOTE: Use the AEON_RAM_CONFIG_INIT() macro instead of the
- * variable, since DRAM/SRAM detection is not determined staticly.
- */
-#define AEON_INIT_RAM_CONFIG_REG \
- ((0x0 << 1) | /* RAM Encrypt: 0 for 128 bytes, 1 for 512 bytes */ \
- (0x1 << 2) | /* RAM Comp cfg: 1 for single compression history */ \
- 0x4B40) /* Setting fixed bits required by the register */
-
-/*
- * Expand Register
- *
- * The only bit in this register is the expand bit at position 9. It's
- * cleared by writing a 1 to it.
- */
-#define AEON_INIT_EXPAND_REG (0x1 << 9)
-
/*********************************************************************
* Structs for board commands
*
@@ -299,12 +395,6 @@ typedef struct aeon_command_buf_data {
} aeon_command_buf_data_t;
/*
- * Values for the interrupt enable register
- */
-#define AEON_INTR_ON_RESULT_DONE (1 << 20)
-#define AEON_INTR_ON_COMMAND_WAITING (1 << 2)
-
-/*
* The poll frequency and poll scalar defines are unshifted values used
* to set fields in the DMA Configuration Register.
*/