1 1.1 dyoung #include <sys/param.h> 2 1.1 dyoung #include <sys/systm.h> 3 1.1 dyoung #include <sys/kernel.h> 4 1.1 dyoung #include <sys/errno.h> 5 1.1 dyoung #include <sys/device.h> 6 1.1 dyoung 7 1.1 dyoung #include <net/if.h> 8 1.1 dyoung #include <net/if_types.h> 9 1.1 dyoung 10 1.1 dyoung #include <net/if_ether.h> 11 1.1 dyoung #include <net/if_media.h> 12 1.1 dyoung #include <dev/mii/mii.h> 13 1.1 dyoung #include <dev/mii/miivar.h> 14 1.1 dyoung 15 1.1 dyoung int 16 1.1 dyoung ether_mediachange(struct ifnet *ifp) 17 1.1 dyoung { 18 1.1 dyoung struct ethercom *ec = (struct ethercom *)ifp; 19 1.1 dyoung int rc; 20 1.1 dyoung 21 1.1 dyoung KASSERT(ec->ec_mii != NULL); 22 1.1 dyoung 23 1.1 dyoung if ((ifp->if_flags & IFF_UP) == 0) 24 1.1 dyoung return 0; 25 1.1 dyoung if ((rc = mii_mediachg(ec->ec_mii)) == ENXIO) 26 1.1 dyoung return 0; 27 1.1 dyoung return rc; 28 1.1 dyoung } 29 1.1 dyoung 30 1.1 dyoung void 31 1.1 dyoung ether_mediastatus(struct ifnet *ifp, struct ifmediareq *ifmr) 32 1.1 dyoung { 33 1.1 dyoung struct ethercom *ec = (struct ethercom *)ifp; 34 1.1 dyoung struct mii_data *mii; 35 1.1 dyoung 36 1.1 dyoung KASSERT(ec->ec_mii != NULL); 37 1.1 dyoung 38 1.1 dyoung #ifdef notyet 39 1.1 dyoung if ((ifp->if_flags & IFF_RUNNING) == 0) { 40 1.1 dyoung ifmr->ifm_active = IFM_ETHER | IFM_NONE; 41 1.1 dyoung ifmr->ifm_status = 0; 42 1.1 dyoung return; 43 1.1 dyoung } 44 1.1 dyoung #endif 45 1.1 dyoung 46 1.1 dyoung mii = ec->ec_mii; 47 1.1 dyoung 48 1.1 dyoung mii_pollstat(mii); 49 1.1 dyoung ifmr->ifm_active = mii->mii_media_active; 50 1.1 dyoung ifmr->ifm_status = mii->mii_media_status; 51 1.1 dyoung } 52