diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 2002-10-13 14:15:36 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 2002-10-13 14:15:36 +0000 |
commit | 7bfd240dca0345c171c352c6529d7ffabf9bb855 (patch) | |
tree | 74477709419c46233ab21f4a6f687c3a06c47e11 /sys/arch/hppa/gsc | |
parent | e9d8842bbce2a07775747a16affc1e98db77859d (diff) |
split the scp/iscp/scb between the cache lines, make the leds blink better
Diffstat (limited to 'sys/arch/hppa/gsc')
-rw-r--r-- | sys/arch/hppa/gsc/if_ie_gsc.c | 46 |
1 files changed, 23 insertions, 23 deletions
diff --git a/sys/arch/hppa/gsc/if_ie_gsc.c b/sys/arch/hppa/gsc/if_ie_gsc.c index 00620d86615..a2b9012f190 100644 --- a/sys/arch/hppa/gsc/if_ie_gsc.c +++ b/sys/arch/hppa/gsc/if_ie_gsc.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_ie_gsc.c,v 1.13 2002/07/17 22:18:38 mickey Exp $ */ +/* $OpenBSD: if_ie_gsc.c,v 1.14 2002/10/13 14:15:35 mickey Exp $ */ /* * Copyright (c) 1998,1999 Michael Shalayeff @@ -109,21 +109,19 @@ ie_gsc_reset(sc, what) register volatile struct ie_gsc_regs *r = (struct ie_gsc_regs *)sc->ioh; register int i; + r->ie_reset = 0; + /* + * per [2] 4.6.2.1 + * delay for 10 system clocks + 5 transmit clocks, + * NB: works for system clocks over 10MHz + */ + DELAY(1000); + switch (what) { case IE_CHIP_PROBE: - r->ie_reset = 0; break; case IE_CARD_RESET: - r->ie_reset = 0; - - /* - * per [2] 4.6.2.1 - * delay for 10 system clocks + 5 transmit clocks, - * NB: works for system clocks over 10MHz - */ - DELAY(1000); - /* * after the hardware reset: * inform i825[89]6 about new SCP address, @@ -155,7 +153,9 @@ ie_gsc_attend(sc) register volatile struct ie_gsc_regs *r = (struct ie_gsc_regs *)sc->ioh; fdcache(0, (vaddr_t)ie_mem, IE_SIZE); + DELAY(10); r->ie_attn = 0; + DELAY(10); } void @@ -206,14 +206,14 @@ ie_gsc_intrhook(sc, where) int where; { switch (where) { - case IE_INTR_ENTER: - /* turn it on */ + case IE_INTR_ENRCV: + ledctl(PALED_NETRCV, 0, 0); break; - case IE_INTR_LOOP: - /* quick drop and raise */ + case IE_INTR_ENSND: + ledctl(PALED_NETSND, 0, 0); break; case IE_INTR_EXIT: - /* drop it */ + case IE_INTR_LOOP: break; } return 0; @@ -225,7 +225,7 @@ ie_gsc_read16(sc, offset) struct ie_softc *sc; int offset; { - pdcache(0, sc->bh + offset, 2); + fdce(0, sc->bh + offset); return *(volatile u_int16_t *)(sc->bh + offset); } @@ -236,7 +236,7 @@ ie_gsc_write16(sc, offset, v) u_int16_t v; { *(volatile u_int16_t *)(sc->bh + offset) = v; - fdcache(0, sc->bh + offset, 2); + fdce(0, sc->bh + offset); } void @@ -247,7 +247,8 @@ ie_gsc_write24(sc, offset, addr) { *(volatile u_int16_t *)(sc->bh + offset + 0) = (addr ) & 0xffff; *(volatile u_int16_t *)(sc->bh + offset + 2) = (addr >> 16) & 0xffff; - fdcache(0, sc->bh + offset, 4); + fdce(0, sc->bh + offset + 0); + fdce(0, sc->bh + offset + 2); } void @@ -272,7 +273,6 @@ ie_gsc_memcopyout(sc, p, offset, size) fdcache(0, sc->bh + offset, size); } - int ie_gsc_probe(parent, match, aux) struct device *parent; @@ -377,9 +377,9 @@ ie_gsc_attach(parent, self, aux) printf(": "); sc->iscp = 0; - sc->scp = sc->iscp + IE_ISCP_SZ; - sc->scb = sc->scp + IE_SCP_SZ; - sc->buf_area = sc->scb + 256; + sc->scp = 32; + sc->scb = 94; + sc->buf_area = 256; sc->buf_area_sz = sc->sc_msize - sc->buf_area; sc->sc_type = sc->sc_flags & IEGSC_GECKO? "LASI/i82596CA" : "i82596DX"; sc->sc_vers = ga->ga_type.iodc_model * 10 + ga->ga_type.iodc_sv_rev; |