diff options
Diffstat (limited to 'sys/arch/vax/if')
-rw-r--r-- | sys/arch/vax/if/if_ze.c | 4 | ||||
-rw-r--r-- | sys/arch/vax/if/sgec.c | 38 | ||||
-rw-r--r-- | sys/arch/vax/if/sgecvar.h | 4 |
3 files changed, 41 insertions, 5 deletions
diff --git a/sys/arch/vax/if/if_ze.c b/sys/arch/vax/if/if_ze.c index bc5f9c91a31..51f8dd5db85 100644 --- a/sys/arch/vax/if/if_ze.c +++ b/sys/arch/vax/if/if_ze.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_ze.c,v 1.7 2006/08/30 19:28:11 miod Exp $ */ +/* $OpenBSD: if_ze.c,v 1.8 2008/08/22 17:09:06 deraadt Exp $ */ /* $NetBSD: if_ze.c,v 1.3 2000/01/24 02:54:03 matt Exp $ */ /* * Copyright (c) 1999 Ludd, University of Lule}, Sweden. All rights reserved. @@ -38,6 +38,8 @@ #include <net/if.h> #include <net/if_dl.h> +#include <net/if_media.h> + #include <netinet/in.h> #include <netinet/if_ether.h> diff --git a/sys/arch/vax/if/sgec.c b/sys/arch/vax/if/sgec.c index ba11abc9ec9..e7dce2eddcc 100644 --- a/sys/arch/vax/if/sgec.c +++ b/sys/arch/vax/if/sgec.c @@ -1,4 +1,4 @@ -/* $OpenBSD: sgec.c,v 1.15 2006/08/31 22:10:57 miod Exp $ */ +/* $OpenBSD: sgec.c,v 1.16 2008/08/22 17:09:06 deraadt Exp $ */ /* $NetBSD: sgec.c,v 1.5 2000/06/04 02:14:14 matt Exp $ */ /* * Copyright (c) 1999 Ludd, University of Lule}, Sweden. All rights reserved. @@ -56,6 +56,7 @@ #include <net/if.h> #include <net/if_dl.h> +#include <net/if_media.h> #include <netinet/in.h> #include <netinet/if_ether.h> @@ -74,6 +75,8 @@ void sgec_rxintr(struct ze_softc *); void sgec_txintr(struct ze_softc *); void zeinit(struct ze_softc *); int zeioctl(struct ifnet *, u_long, caddr_t); +int ze_ifmedia_change(struct ifnet *const); +void ze_ifmedia_status(struct ifnet *const, struct ifmediareq *); void zekick(struct ze_softc *); int zereset(struct ze_softc *); void zestart(struct ifnet *); @@ -215,6 +218,12 @@ sgec_attach(sc) ether_ifattach(ifp); printf(": address %s\n", ether_sprintf(sc->sc_ac.ac_enaddr)); + + ifmedia_init(&sc->sc_ifmedia, 0, ze_ifmedia_change, + ze_ifmedia_status); + ifmedia_add(&sc->sc_ifmedia, IFM_ETHER | IFM_10_5, 0, 0); + ifmedia_set(&sc->sc_ifmedia, IFM_ETHER | IFM_10_5); + sc->sc_flags |= SGECF_LINKUP; return; /* @@ -250,6 +259,23 @@ sgec_attach(sc) return; } +int +ze_ifmedia_change(struct ifnet *const ifp) +{ + return (0); +} + +void +ze_ifmedia_status(struct ifnet *const ifp, struct ifmediareq *req) +{ + struct ze_softc *sc = ifp->if_softc; + + req->ifm_status = IFM_AVALID; + if (sc->sc_flags & SGECF_LINKUP) + req->ifm_status |= IFM_ACTIVE; + req->ifm_active = IFM_10_5 | IFM_ETHER; +} + /* * Initialization of interface. */ @@ -503,6 +529,7 @@ sgec_txintr(struct ze_softc *sc) struct ifnet *ifp = &sc->sc_if; u_short tdes0; + sc->sc_flags |= SGECF_LINKUP; while ((zc->zc_xmit[sc->sc_lastack].ze_tdr & ZE_TDR_OW) == 0) { int idx = sc->sc_lastack; @@ -523,8 +550,7 @@ sgec_txintr(struct ze_softc *sc) printf("%s: transmit watchdog timeout\n", sc->sc_dev.dv_xname); if (tdes0 & (ZE_TDES0_LO | ZE_TDES0_NC)) - printf("%s: no carrier\n", - sc->sc_dev.dv_xname); + sc->sc_flags &= ~SGECF_LINKUP; if (tdes0 & ZE_TDES0_EC) { printf("%s: excessive collisions, tdr %d\n", sc->sc_dev.dv_xname, @@ -617,6 +643,12 @@ zeioctl(ifp, cmd, data) } break; + case SIOCSIFMEDIA: + case SIOCGIFMEDIA: + error = ifmedia_ioctl(ifp, (struct ifreq *)data, + &sc->sc_ifmedia, cmd); + break; + case SIOCSIFFLAGS: if ((ifp->if_flags & IFF_UP) == 0 && (ifp->if_flags & IFF_RUNNING) != 0) { diff --git a/sys/arch/vax/if/sgecvar.h b/sys/arch/vax/if/sgecvar.h index 6e1417527d6..9418bcff3d1 100644 --- a/sys/arch/vax/if/sgecvar.h +++ b/sys/arch/vax/if/sgecvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: sgecvar.h,v 1.5 2006/08/30 19:28:11 miod Exp $ */ +/* $OpenBSD: sgecvar.h,v 1.6 2008/08/22 17:09:06 deraadt Exp $ */ /* $NetBSD: sgecvar.h,v 1.2 2000/06/04 02:14:14 matt Exp $ */ /* * Copyright (c) 1999 Ludd, University of Lule}, Sweden. All rights reserved. @@ -47,6 +47,7 @@ struct ze_softc { struct evcount sc_intrcnt; /* Interrupt counters */ struct arpcom sc_ac; /* Ethernet common part */ #define sc_if sc_ac.ac_if /* network-visible interface */ + struct ifmedia sc_ifmedia; bus_space_tag_t sc_iot; bus_addr_t sc_ioh; bus_dma_tag_t sc_dmat; @@ -65,6 +66,7 @@ struct ze_softc { int sc_flags; #define SGECF_SETUP 0x00000001 /* need to send setup packet */ #define SGECF_VXTQUIRKS 0x00000002 /* need VXT2000 care */ +#define SGECF_LINKUP 0x00000004 /* got link */ }; void sgec_attach(struct ze_softc *); |