diff options
author | Brad Smith <brad@cvs.openbsd.org> | 2005-09-17 20:05:48 +0000 |
---|---|---|
committer | Brad Smith <brad@cvs.openbsd.org> | 2005-09-17 20:05:48 +0000 |
commit | 3ba1ec9ec892e42040c4d77f00f271b36a19e9c8 (patch) | |
tree | 8729369b91f4995fe352bf986f47b4f4d46aa424 /sys/dev/mii/brgphy.c | |
parent | c9c2fe62e362a702c65ef453e373b7e5530b0fbb (diff) |
- use PHY_RESET() on all models in brgphy_service()
- use PHY_RESET() in brgphy_mii_phy_auto()
- always use mii_phy_update() in brgphy_service()
ok krw@
Diffstat (limited to 'sys/dev/mii/brgphy.c')
-rw-r--r-- | sys/dev/mii/brgphy.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/sys/dev/mii/brgphy.c b/sys/dev/mii/brgphy.c index 1fe87b6cee3..9aa2b66f6f6 100644 --- a/sys/dev/mii/brgphy.c +++ b/sys/dev/mii/brgphy.c @@ -1,4 +1,4 @@ -/* $OpenBSD: brgphy.c,v 1.28 2005/08/27 14:15:47 brad Exp $ */ +/* $OpenBSD: brgphy.c,v 1.29 2005/09/17 20:05:47 brad Exp $ */ /* * Copyright (c) 2000 @@ -193,8 +193,7 @@ brgphy_service(struct mii_softc *sc, struct mii_data *mii, int cmd) if ((mii->mii_ifp->if_flags & IFF_UP) == 0) break; - if (sc->mii_model != MII_MODEL_xxBROADCOM_BCM5701) - PHY_RESET(sc); /* XXX hardware bug work-around */ + PHY_RESET(sc); /* XXX hardware bug work-around */ switch (IFM_SUBTYPE(ife->ifm_media)) { case IFM_AUTO: @@ -278,7 +277,7 @@ setit: * Only retry autonegotiation every mii_anegticks seconds. */ if (++sc->mii_ticks <= sc->mii_anegticks) - return (0); + break; sc->mii_ticks = 0; brgphy_mii_phy_auto(sc); @@ -295,7 +294,6 @@ setit: if (sc->mii_media_active != mii->mii_media_active || sc->mii_media_status != mii->mii_media_status || cmd == MII_MEDIACHG) { - mii_phy_update(sc, cmd); switch (sc->mii_model) { case MII_MODEL_BROADCOM_BCM5400: case MII_MODEL_xxBROADCOM_BCM5401: @@ -304,6 +302,7 @@ setit: break; } } + mii_phy_update(sc, cmd); return (0); } @@ -374,7 +373,7 @@ brgphy_mii_phy_auto(struct mii_softc *sc) int ktcr = 0; brgphy_loop(sc); - /* XXX need 'PHY_RESET(sc);'? Was done before getting here ... */ + PHY_RESET(sc); ktcr = BRGPHY_1000CTL_AFD|BRGPHY_1000CTL_AHD; if (sc->mii_model == MII_MODEL_xxBROADCOM_BCM5701) ktcr |= BRGPHY_1000CTL_MSE|BRGPHY_1000CTL_MSC; |