summaryrefslogtreecommitdiff
path: root/sys/dev/pci
diff options
context:
space:
mode:
authorBrad Smith <brad@cvs.openbsd.org>2004-12-02 02:20:42 +0000
committerBrad Smith <brad@cvs.openbsd.org>2004-12-02 02:20:42 +0000
commiteb3cedd43561d5d9e147e965d5ec78333019d2b8 (patch)
treea9b31b9d2db3ada9d6b0be27ea0db3b94aa1af46 /sys/dev/pci
parentd99839b0a1dd089db0f10ee74329b9edf3014708 (diff)
rev 1.4
fix obvious past-o where the activity led register gets overwritten by the traffic meter led register rev 1.5 Keep track of what we set the interrupt mask to, rather than reading it from the chip. From NetBSD ok deraadt@
Diffstat (limited to 'sys/dev/pci')
-rw-r--r--sys/dev/pci/if_bce.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/sys/dev/pci/if_bce.c b/sys/dev/pci/if_bce.c
index 65936265590..94156e4cb67 100644
--- a/sys/dev/pci/if_bce.c
+++ b/sys/dev/pci/if_bce.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_bce.c,v 1.3 2004/11/10 10:14:47 grange Exp $ */
+/* $OpenBSD: if_bce.c,v 1.4 2004/12/02 02:20:41 brad Exp $ */
/* $NetBSD: if_bce.c,v 1.3 2003/09/29 01:53:02 mrg Exp $ */
/*
@@ -135,6 +135,7 @@ struct bce_softc {
struct bce_dma_slot *bce_tx_ring; /* transmit ring */
struct bce_chain_data bce_cdata; /* mbufs */
bus_dmamap_t bce_ring_map;
+ u_int32_t bce_intmask; /* current intr mask */
u_int32_t bce_rxin; /* last rx descriptor seen */
u_int32_t bce_txin; /* last tx descriptor seen */
int bce_txsfree; /* no. tx slots available */
@@ -449,7 +450,7 @@ bce_attach(parent, self, aux)
bce_mii_write((struct device *) sc, 1, 26, /* MAGIC */
bce_mii_read((struct device *) sc, 1, 26) & 0x7fff); /* MAGIC */
/* enable traffic meter led mode */
- bce_mii_write((struct device *) sc, 1, 26, /* MAGIC */
+ bce_mii_write((struct device *) sc, 1, 27, /* MAGIC */
bce_mii_read((struct device *) sc, 1, 27) | (1 << 6)); /* MAGIC */
@@ -684,7 +685,6 @@ bce_intr(xsc)
struct bce_softc *sc;
struct ifnet *ifp;
u_int32_t intstatus;
- u_int32_t intmask;
int wantinit;
int handled = 0;
@@ -695,11 +695,9 @@ bce_intr(xsc)
for (wantinit = 0; wantinit == 0;) {
intstatus = bus_space_read_4(sc->bce_btag, sc->bce_bhandle,
BCE_INT_STS);
- intmask = bus_space_read_4(sc->bce_btag, sc->bce_bhandle,
- BCE_INT_MASK);
/* ignore if not ours, or unsolicited interrupts */
- intstatus &= intmask;
+ intstatus &= sc->bce_intmask;
if (intstatus == 0)
break;
@@ -1005,8 +1003,10 @@ bce_init(ifp)
}
/* Enable interrupts */
+ sc->bce_intmask =
+ I_XI | I_RI | I_XU | I_RO | I_RU | I_DE | I_PD | I_PC | I_TO;
bus_space_write_4(sc->bce_btag, sc->bce_bhandle, BCE_INT_MASK,
- I_XI | I_RI | I_XU | I_RO | I_RU | I_DE | I_PD | I_PC | I_TO);
+ sc->bce_intmask);
/* start the receive dma */
bus_space_write_4(sc->bce_btag, sc->bce_bhandle, BCE_DMA_RXDPTR,
@@ -1134,7 +1134,8 @@ bce_stop(ifp, disable)
/* Disable interrupts. */
bus_space_write_4(sc->bce_btag, sc->bce_bhandle, BCE_INT_MASK, 0);
- bus_space_read_4(sc->bce_btag, sc->bce_bhandle, BCE_INT_MASK);
+ sc->bce_intmask = 0;
+ delay(10);
/* Disable emac */
bus_space_write_4(sc->bce_btag, sc->bce_bhandle, BCE_ENET_CTL, EC_ED);