summaryrefslogtreecommitdiff
path: root/sys/dev/pci/if_ste.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/pci/if_ste.c')
-rw-r--r--sys/dev/pci/if_ste.c46
1 files changed, 32 insertions, 14 deletions
diff --git a/sys/dev/pci/if_ste.c b/sys/dev/pci/if_ste.c
index 0e68be75244..f804eff0956 100644
--- a/sys/dev/pci/if_ste.c
+++ b/sys/dev/pci/if_ste.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ste.c,v 1.29 2005/04/08 20:30:51 beck Exp $ */
+/* $OpenBSD: if_ste.c,v 1.30 2005/04/21 06:48:05 fgsch Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
* Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
@@ -334,6 +334,9 @@ int ste_miibus_readreg(self, phy, reg)
struct ste_softc *sc = (struct ste_softc *)self;
struct ste_mii_frame frame;
+ if (sc->ste_one_phy && phy != 0)
+ return (0);
+
bzero((char *)&frame, sizeof(frame));
frame.mii_phyaddr = phy;
@@ -462,7 +465,8 @@ int ste_eeprom_wait(sc)
}
if (i == 100) {
- printf("%s: eeprom failed to come ready\n", sc->sc_dev.dv_xname);
+ printf("%s: eeprom failed to come ready\n",
+ sc->sc_dev.dv_xname);
return(1);
}
@@ -829,7 +833,6 @@ void ste_attach(parent, self, aux)
struct device *parent, *self;
void *aux;
{
- int s;
const char *intrstr = NULL;
u_int32_t command;
struct ste_softc *sc = (struct ste_softc *)self;
@@ -840,8 +843,6 @@ void ste_attach(parent, self, aux)
bus_addr_t iobase;
bus_size_t iosize;
- s = splimp();
-
/*
* Handle power management nonsense.
*/
@@ -871,6 +872,16 @@ void ste_attach(parent, self, aux)
}
/*
+ * Only use one PHY since this chip reports multiple
+ * Note on the DFE-550 the PHY is at 1 on the DFE-580
+ * it is at 0 & 1. It is rev 0x12.
+ */
+ if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_DLINK &&
+ PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_DLINK_550TX &&
+ PCI_REVISION(pa->pa_class) == 0x12)
+ sc->ste_one_phy = 1;
+
+ /*
* Map control/status registers.
*/
command = pci_conf_read(pc, pa->pa_tag, PCI_COMMAND_STATUS_REG);
@@ -932,15 +943,21 @@ void ste_attach(parent, self, aux)
/*
* Get station address from the EEPROM.
*/
- ste_read_eeprom(sc,(caddr_t)&sc->arpcom.ac_enaddr,STE_EEADDR_NODE0,3,0);
+ if (ste_read_eeprom(sc, (caddr_t)&sc->arpcom.ac_enaddr,
+ STE_EEADDR_NODE0, 3, 0)) {
+ printf("%s: failed to read station address\n",
+ sc->sc_dev.dv_xname);
+ goto fail_1;
+ }
printf(" address %s\n", ether_sprintf(sc->arpcom.ac_enaddr));
sc->ste_ldata_ptr = malloc(sizeof(struct ste_list_data) + 8,
- M_DEVBUF, M_DONTWAIT);
+ M_DEVBUF, M_DONTWAIT);
if (sc->ste_ldata_ptr == NULL) {
- printf("%s: no memory for list buffers!\n", sc->sc_dev.dv_xname);
- goto fail;
+ printf("%s: no memory for list buffers!\n",
+ sc->sc_dev.dv_xname);
+ goto fail_1;
}
sc->ste_ldata = (struct ste_list_data *)sc->ste_ldata_ptr;
@@ -982,8 +999,10 @@ void ste_attach(parent, self, aux)
shutdownhook_establish(ste_shutdown, sc);
fail:
- splx(s);
return;
+
+fail_1:
+ pci_intr_disestablish(pc, sc->sc_ih);
}
int ste_newbuf(sc, c, m)
@@ -1242,7 +1261,7 @@ void ste_stop(sc)
void ste_reset(sc)
struct ste_softc *sc;
{
- int i;
+ int i;
STE_SETBIT4(sc, STE_ASICCTL,
STE_ASICCTL_GLOBAL_RESET|STE_ASICCTL_RX_RESET|
@@ -1259,9 +1278,8 @@ void ste_reset(sc)
}
if (i == STE_TIMEOUT)
- printf("%s: global reset never completed\n", sc->sc_dev.dv_xname);
-
- return;
+ printf("%s: global reset never completed\n",
+ sc->sc_dev.dv_xname);
}
int ste_ioctl(ifp, command, data)