diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 1999-11-26 17:45:58 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 1999-11-26 17:45:58 +0000 |
commit | 2cf0dd800898c2256528105c92ebb3d02121e7ee (patch) | |
tree | 2ed0c8462731abfb873bc831198b3531207b57c1 | |
parent | f13d3d7960d196bd2233c2e4697d0681a9e0a6b2 (diff) |
provide general "probing" routine, also used in isa cards memory sizing;
also utilize port commands (if provided by the md backend);
prefix macros w/ IE_;
build control structures here, providing sysbus byte in the softc.
-rw-r--r-- | sys/dev/ic/i82596.c | 124 | ||||
-rw-r--r-- | sys/dev/ic/i82596var.h | 24 |
2 files changed, 60 insertions, 88 deletions
diff --git a/sys/dev/ic/i82596.c b/sys/dev/ic/i82596.c index 174880ecddd..76c0811bc99 100644 --- a/sys/dev/ic/i82596.c +++ b/sys/dev/ic/i82596.c @@ -1,4 +1,4 @@ -/* $OpenBSD: i82596.c,v 1.1 1999/08/15 23:49:30 mickey Exp $ */ +/* $OpenBSD: i82596.c,v 1.2 1999/11/26 17:45:57 mickey Exp $ */ /* $NetBSD: i82586.c,v 1.18 1998/08/15 04:42:42 mycroft Exp $ */ /*- @@ -209,8 +209,6 @@ int i82596_cmd_wait __P((struct ie_softc *)); #ifdef I82596_DEBUG void print_rbd __P((struct ie_softc *, int)); - -int spurious_intrs = 0; #endif struct cfdriver ie_cd = { @@ -224,83 +222,44 @@ int i82596_probe(sc) struct ie_softc *sc; { -#ifdef rewrite_also_do_the_test_command - volatile struct ie_sys_conf_ptr *scp; - volatile struct ie_int_sys_conf_ptr *iscp; - volatile struct ie_sys_ctl_block *scb; - u_long realbase; - int s; - - s = splnet(); - - realbase = (u_long)where + size - (1 << 24); - - scp = (volatile struct ie_sys_conf_ptr *)(realbase + IE_SCP_ADDR); - bzero((char *)scp, sizeof *scp); - - /* - * First we put the ISCP at the bottom of memory; this tests to make - * sure that our idea of the size of memory is the same as the - * controller's. This is NOT where the ISCP will be in normal - * operation. - */ - iscp = (volatile struct ie_int_sys_conf_ptr *)where; - bzero((char *)iscp, sizeof *iscp); - - scb = (volatile struct ie_sys_ctl_block *)where; - bzero((char *)scb, sizeof *scb); + int i; - scp->ie_bus_use = 0; /* 16-bit */ - scp->ie_iscp_ptr = (caddr_t)((volatile caddr_t)iscp - - (volatile caddr_t)realbase); + sc->scp = sc->sc_msize - IE_SCP_SZ; + sc->iscp = 0; + sc->scb = 32; - iscp->ie_busy = 1; - iscp->ie_scb_offset = MK_16(realbase, scb) + 256; + (sc->ie_bus_write16)(sc, IE_ISCP_BUSY(sc->iscp), 1); + (sc->ie_bus_write16)(sc, IE_ISCP_SCB(sc->iscp), sc->scb); + (sc->ie_bus_write24)(sc, IE_ISCP_BASE(sc->iscp), sc->sc_maddr); + (sc->ie_bus_write24)(sc, IE_SCP_ISCP(sc->scp), sc->sc_maddr); + (sc->ie_bus_write16)(sc, IE_SCP_BUS_USE(sc->scp), sc->sysbus); - (sc->reset)(sc); + (sc->hwreset)(sc, IE_CARD_RESET); (sc->chan_attn)(sc); + DELAY(1000); - delay(100); /* wait a while... */ - - if (iscp->ie_busy) { - splx(s); + if ((sc->ie_bus_read16)(sc, IE_ISCP_BUSY(sc->iscp))) { +#ifdef I82596_DEBUG + printf ("%s: ISCP set failed\n", sc->sc_dev.dv_xname); +#endif return 0; } - /* - * Now relocate the ISCP to its real home, and reset the controller - * again. - */ - iscp = (void *)ALIGN(realbase + IE_SCP_ADDR - sizeof(*iscp)); - bzero((char *)iscp, sizeof *iscp); - - scp->ie_iscp_ptr = (caddr_t)((caddr_t)iscp - (caddr_t)realbase); - - iscp->ie_busy = 1; - iscp->ie_scb_offset = MK_16(realbase, scb); + if (sc->port) { + (sc->ie_bus_write24)(sc, IE_SCP_TEST(sc->scp), -1); + (sc->port)(sc, IE_PORT_TEST); + for (i = 9000; i-- && + (sc->ie_bus_read16)(sc, IE_SCP_TEST(sc->scp)); + DELAY(100)); - (sc->reset)(sc); - (sc->chan_attn)(sc); - - delay(100); +#ifdef I82596_DEBUG + printf ("%s: test %x:%x\n", sc->sc_dev.dv_xname, + *((volatile int32_t *)(sc->bh + sc->scp)), + *(int32_t *)(sc->bh + IE_SCP_TEST(sc->scp))); - if (iscp->ie_busy) { - splx(s); - return 0; +#endif } - sc->sc_msize = size; - sc->sc_maddr = (caddr_t)realbase; - - sc->iscp = iscp; - sc->scb = scb; - - /* - * Acknowledge any interrupts we may have caused... - */ - ie_ack(sc, IE_ST_WHENCE); - splx(s); -#endif return 1; } @@ -336,6 +295,15 @@ i82596_attach(sc, name, etheraddr, media, nmedia, defmedia) int i; struct ifnet *ifp = &sc->sc_arpcom.ac_if; + /* Setup SCP+ISCP */ + (sc->ie_bus_write16)(sc, IE_ISCP_BUSY(sc->iscp), 1); + (sc->ie_bus_write16)(sc, IE_ISCP_SCB(sc->iscp), sc->scb); + (sc->ie_bus_write24)(sc, IE_ISCP_BASE(sc->iscp), sc->sc_maddr); + (sc->ie_bus_write24)(sc, IE_SCP_ISCP(sc->scp), sc->sc_maddr +sc->iscp); + (sc->ie_bus_write16)(sc, IE_SCP_BUS_USE(sc->scp), sc->sysbus); + (sc->hwreset)(sc, IE_CARD_RESET); + + /* Setup Iface */ bcopy(sc->sc_dev.dv_xname, ifp->if_xname, IFNAMSIZ); ifp->if_softc = sc; ifp->if_start = i82596_start; @@ -362,7 +330,8 @@ i82596_attach(sc, name, etheraddr, media, nmedia, defmedia) if_attach(ifp); ether_ifattach(ifp); - printf(" address %s, type %s\n", ether_sprintf(etheraddr), name); + printf(" %s v%d.%d, address %s\n", name, sc->sc_vers / 10, + sc->sc_vers % 10, ether_sprintf(etheraddr)); #if NBPFILTER > 0 bpfattach(&ifp->if_bpf, ifp, DLT_EN10MB, sizeof(struct ether_header)); @@ -541,20 +510,15 @@ i82596_intr(v) * Implementation dependent interrupt handling. */ if (sc->intrhook) - (sc->intrhook)(sc, INTR_ENTER); + (sc->intrhook)(sc, IE_INTR_ENTER); off = IE_SCB_STATUS(sc->scb); bus_space_barrier(sc->bt, sc->bh, off, 2, BUS_SPACE_BARRIER_READ); status = sc->ie_bus_read16(sc, off) /* & IE_ST_WHENCE */; if ((status & IE_ST_WHENCE) == 0) { -#ifdef I82596_DEBUG - if ((spurious_intrs++ % 25) == 0) - printf("%s: i82596_intr: %d spurious interrupts\n", - sc->sc_dev.dv_xname, spurious_intrs); -#endif if (sc->intrhook) - (sc->intrhook)(sc, INTR_EXIT); + (sc->intrhook)(sc, IE_INTR_EXIT); return (0); } @@ -580,7 +544,7 @@ loop: status, IE_ST_BITS); #endif if (sc->intrhook) - (sc->intrhook)(sc, INTR_LOOP); + (sc->intrhook)(sc, IE_INTR_LOOP); /* * Interrupt ACK was posted asynchronously; wait for @@ -595,7 +559,7 @@ loop: out: if (sc->intrhook) - (sc->intrhook)(sc, INTR_EXIT); + (sc->intrhook)(sc, IE_INTR_EXIT); return (1); reset: @@ -1349,7 +1313,7 @@ i82596_proberam(sc) bus_space_barrier(sc->bt, sc->bh, off, 1, BUS_SPACE_BARRIER_WRITE); if (sc->hwreset) - (sc->hwreset)(sc, CHIP_PROBE); + (sc->hwreset)(sc, IE_CHIP_PROBE); (sc->chan_attn) (sc); @@ -1392,7 +1356,7 @@ i82596_reset(sc, hard) * lockups. */ if (hard && sc->hwreset) - (sc->hwreset)(sc, CARD_RESET); + (sc->hwreset)(sc, IE_CARD_RESET); delay(100); ie_ack(sc, IE_ST_WHENCE); diff --git a/sys/dev/ic/i82596var.h b/sys/dev/ic/i82596var.h index 7fbd7b30daa..4cdcdb78776 100644 --- a/sys/dev/ic/i82596var.h +++ b/sys/dev/ic/i82596var.h @@ -1,4 +1,4 @@ -/* $OpenBSD: i82596var.h,v 1.1 1999/08/15 23:49:30 mickey Exp $ */ +/* $OpenBSD: i82596var.h,v 1.2 1999/11/26 17:45:57 mickey Exp $ */ /* $NetBSD: i82586var.h,v 1.10 1998/08/15 04:42:42 mycroft Exp $ */ /*- @@ -98,7 +98,7 @@ * This sun version based on i386 version 1.30. */ -#undef I82596_DEBUG +/* #define I82596_DEBUG */ /* Debug elements */ #define IED_RINT 0x01 @@ -123,12 +123,17 @@ #define IE_MAXMCAST (IE_TBUF_SIZE/6)/* must fit in transmit buffer */ -#define INTR_ENTER 0 /* intr hook called on ISR entry */ -#define INTR_EXIT 1 /* intr hook called on ISR exit */ -#define INTR_LOOP 2 /* intr hook called on ISR loop */ +#define IE_INTR_ENTER 0 /* intr hook called on ISR entry */ +#define IE_INTR_EXIT 1 /* intr hook called on ISR exit */ +#define IE_INTR_LOOP 2 /* intr hook called on ISR loop */ -#define CHIP_PROBE 0 /* reset called from chip probe */ -#define CARD_RESET 1 /* reset called from card reset */ +#define IE_CHIP_PROBE 0 /* reset called from chip probe */ +#define IE_CARD_RESET 1 /* reset called from card reset */ + +#define IE_PORT_RESET 0 +#define IE_PORT_TEST 1 +#define IE_PORT_SCP 2 +#define IE_PORT_DUMP 3 /* * Ethernet status, per interface. @@ -188,7 +193,6 @@ struct ie_softc { void *sc_iobase; /* (MD) KVA of base of 24 bit addr space */ u_long sc_maddr; /* (MD) base of chip's RAM (16bit addr space) */ u_int sc_msize; /* (MD) how much RAM we have/use */ - void *sc_reg; /* (MD) KVA of car's register (also iot/ioh) */ u_int sc_flags; /* (MI/MD) flags */ #define IEMD_FLAG0 0x00010000 #define IEMD_FLAG1 0x00020000 @@ -205,6 +209,7 @@ struct ie_softc { void (*hwreset) __P((struct ie_softc *, int)); void (*hwinit) __P((struct ie_softc *)); void (*chan_attn) __P((struct ie_softc *)); + void (*port) __P((struct ie_softc *, u_int)); int (*intrhook) __P((struct ie_softc *, int where)); void (*memcopyin) __P((struct ie_softc *, void *, int, size_t)); @@ -237,6 +242,9 @@ struct ie_softc { int buf_area; /* Start of descriptors and buffers */ int buf_area_sz; /* Size of above */ + /* SYSBUS byte */ + int sysbus; + /* * The buffers & descriptors (recv and xmit) */ |