summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/pci/if_fxp.c44
-rw-r--r--sys/dev/pci/if_fxpvar.h3
2 files changed, 42 insertions, 5 deletions
diff --git a/sys/dev/pci/if_fxp.c b/sys/dev/pci/if_fxp.c
index 7a305eddbab..9d23df040d9 100644
--- a/sys/dev/pci/if_fxp.c
+++ b/sys/dev/pci/if_fxp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_fxp.c,v 1.14 1998/08/21 20:29:10 downsj Exp $ */
+/* $OpenBSD: if_fxp.c,v 1.15 1998/08/24 18:52:17 downsj Exp $ */
/* $NetBSD: if_fxp.c,v 1.2 1997/06/05 02:01:55 thorpej Exp $ */
/*
@@ -183,6 +183,7 @@ static u_char fxp_cb_config_template[] = {
0x5 /* 21 */
};
+static const char *fxp_phyname __P((int));
static inline void fxp_scb_wait __P((struct fxp_softc *));
static FXP_INTR_TYPE fxp_intr __P((void *));
static void fxp_start __P((struct ifnet *));
@@ -381,8 +382,7 @@ fxp_attach(parent, self, aux)
return;
}
- printf(": address %s%s, %s\n", ether_sprintf(enaddr),
- sc->phy_10Mbps_only ? ", 10Mbps" : "", intrstr);
+ printf(": %s\n", intrstr);
#ifdef __OpenBSD__
ifp = &sc->arpcom.ac_if;
@@ -397,6 +397,11 @@ fxp_attach(parent, self, aux)
ifp->if_start = fxp_start;
ifp->if_watchdog = fxp_watchdog;
+ printf(FXP_FORMAT ": %s (%s) address %s\n", FXP_ARGS(sc),
+ fxp_phyname(sc->phy_primary_device),
+ sc->phy_10Mbps_only ? "10Mbps" : "10/100Mbps",
+ ether_sprintf(sc->arpcom.ac_enaddr));
+
/*
* Attach the interface.
*/
@@ -429,6 +434,20 @@ fxp_attach(parent, self, aux)
shutdownhook_establish(fxp_shutdown, sc);
}
+static const char *
+fxp_phyname(device)
+ int device;
+{
+ static const char * const phynames[] = { "unknown", "82553A",
+ "82553C", "82503", "DP83840", "80C240", "80C24",
+ "82555/82558/82558B", "unknown", "unknown",
+ "DP83840A", "82555B" };
+
+ if ((device < FXP_PHY_NONE) || (device > FXP_PHY_82555B))
+ return(phynames[0]);
+ return(phynames[device]);
+}
+
/*
* Device shutdown routine. Called at system shutdown after sync. The
* main purpose of this routine is to shut off receiver DMA so that
@@ -677,6 +696,7 @@ fxp_attach_common(sc, enaddr)
sc->phy_primary_addr = data & 0xff;
sc->phy_primary_device = (data >> 8) & 0x3f;
sc->phy_10Mbps_only = data >> 15;
+ sc->phy_settings = 0;
/*
* Read MAC address.
@@ -1210,7 +1230,7 @@ fxp_init(xsc)
struct fxp_cb_config *cbp;
struct fxp_cb_ias *cb_ias;
struct fxp_cb_tx *txp;
- int i, s, prm;
+ int i, s, prm, oldmdi;
s = splimp();
/*
@@ -1350,6 +1370,8 @@ fxp_init(xsc)
vtophys(sc->rfa_headm->m_ext.ext_buf) + RFA_ALIGNMENT_FUDGE);
CSR_WRITE_1(sc, FXP_CSR_SCB_COMMAND, FXP_SCB_COMMAND_RU_START);
+ oldmdi = sc->phy_settings;
+
/*
* Toggle a few bits in the PHY.
*/
@@ -1395,6 +1417,9 @@ fxp_init(xsc)
FXP_PHY_BMCR) |
FXP_PHY_BMCR_AUTOEN));
}
+
+ sc->phy_settings = fxp_mdi_read(sc, sc->phy_primary_addr,
+ FXP_PHY_BMCR);
break;
/*
* The Seeq 80c24 doesn't have a PHY programming interface, so do
@@ -1409,6 +1434,17 @@ fxp_init(xsc)
sc->phy_primary_addr);
}
+ if (oldmdi != sc->phy_settings) {
+ printf(FXP_FORMAT ": %s %s%s port\n",
+ FXP_ARGS(sc),
+ (sc->phy_settings & FXP_PHY_BMCR_AUTOEN) ?
+ "autosensing" : "enabling",
+ (sc->phy_settings & FXP_PHY_BMCR_FULLDUPLEX) ?
+ "full duplex " : "",
+ (sc->phy_settings & FXP_PHY_BMCR_SPEED_100M) ?
+ "100baseTX" : "10baseT");
+ }
+
ifp->if_flags |= IFF_RUNNING;
ifp->if_flags &= ~IFF_OACTIVE;
splx(s);
diff --git a/sys/dev/pci/if_fxpvar.h b/sys/dev/pci/if_fxpvar.h
index d4b9e656e8f..25e20891093 100644
--- a/sys/dev/pci/if_fxpvar.h
+++ b/sys/dev/pci/if_fxpvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_fxpvar.h,v 1.4 1998/08/21 20:29:13 downsj Exp $ */
+/* $OpenBSD: if_fxpvar.h,v 1.5 1998/08/24 18:52:19 downsj Exp $ */
/* $NetBSD: if_fxpvar.h,v 1.1 1997/06/05 02:01:58 thorpej Exp $ */
/*
@@ -70,6 +70,7 @@ struct fxp_softc {
int phy_primary_addr; /* address of primary PHY */
int phy_primary_device; /* device type of primary PHY */
int phy_10Mbps_only; /* PHY is 10Mbps-only device */
+ int phy_settings; /* previous PHY bits */
};
/* Macros to ease CSR access. */