• Home
  • Raw
  • Download

Lines Matching +full:twisted +full:- +full:pair

11 		Written 1998-2002 by Donald Becker.
40 advert = mii->mdio_read(mii->dev, mii->phy_id, addr); in mii_get_an()
46 * mii_ethtool_gset - get settings that are specified in @ecmd
57 struct net_device *dev = mii->dev; in mii_ethtool_gset()
61 ecmd->supported = in mii_ethtool_gset()
65 if (mii->supports_gmii) in mii_ethtool_gset()
66 ecmd->supported |= SUPPORTED_1000baseT_Half | in mii_ethtool_gset()
69 /* only supports twisted-pair */ in mii_ethtool_gset()
70 ecmd->port = PORT_MII; in mii_ethtool_gset()
73 ecmd->transceiver = XCVR_INTERNAL; in mii_ethtool_gset()
76 ecmd->phy_address = mii->phy_id; in mii_ethtool_gset()
77 ecmd->mdio_support = ETH_MDIO_SUPPORTS_C22; in mii_ethtool_gset()
79 ecmd->advertising = ADVERTISED_TP | ADVERTISED_MII; in mii_ethtool_gset()
81 bmcr = mii->mdio_read(dev, mii->phy_id, MII_BMCR); in mii_ethtool_gset()
82 bmsr = mii->mdio_read(dev, mii->phy_id, MII_BMSR); in mii_ethtool_gset()
83 if (mii->supports_gmii) { in mii_ethtool_gset()
84 ctrl1000 = mii->mdio_read(dev, mii->phy_id, MII_CTRL1000); in mii_ethtool_gset()
85 stat1000 = mii->mdio_read(dev, mii->phy_id, MII_STAT1000); in mii_ethtool_gset()
88 ecmd->advertising |= ADVERTISED_Autoneg; in mii_ethtool_gset()
89 ecmd->autoneg = AUTONEG_ENABLE; in mii_ethtool_gset()
91 ecmd->advertising |= mii_get_an(mii, MII_ADVERTISE); in mii_ethtool_gset()
92 if (mii->supports_gmii) in mii_ethtool_gset()
93 ecmd->advertising |= in mii_ethtool_gset()
97 ecmd->lp_advertising = mii_get_an(mii, MII_LPA); in mii_ethtool_gset()
98 ecmd->lp_advertising |= in mii_ethtool_gset()
101 ecmd->lp_advertising = 0; in mii_ethtool_gset()
104 nego = ecmd->advertising & ecmd->lp_advertising; in mii_ethtool_gset()
109 ecmd->duplex = !!(nego & ADVERTISED_1000baseT_Full); in mii_ethtool_gset()
113 ecmd->duplex = !!(nego & ADVERTISED_100baseT_Full); in mii_ethtool_gset()
116 ecmd->duplex = !!(nego & ADVERTISED_10baseT_Full); in mii_ethtool_gset()
119 ecmd->autoneg = AUTONEG_DISABLE; in mii_ethtool_gset()
127 ecmd->duplex = (bmcr & BMCR_FULLDPLX) ? DUPLEX_FULL : DUPLEX_HALF; in mii_ethtool_gset()
130 mii->full_duplex = ecmd->duplex; in mii_ethtool_gset()
138 * mii_ethtool_get_link_ksettings - get settings that are specified in @cmd
148 struct net_device *dev = mii->dev; in mii_ethtool_get_link_ksettings()
155 if (mii->supports_gmii) in mii_ethtool_get_link_ksettings()
159 /* only supports twisted-pair */ in mii_ethtool_get_link_ksettings()
160 cmd->base.port = PORT_MII; in mii_ethtool_get_link_ksettings()
163 cmd->base.phy_address = mii->phy_id; in mii_ethtool_get_link_ksettings()
164 cmd->base.mdio_support = ETH_MDIO_SUPPORTS_C22; in mii_ethtool_get_link_ksettings()
168 bmcr = mii->mdio_read(dev, mii->phy_id, MII_BMCR); in mii_ethtool_get_link_ksettings()
169 bmsr = mii->mdio_read(dev, mii->phy_id, MII_BMSR); in mii_ethtool_get_link_ksettings()
170 if (mii->supports_gmii) { in mii_ethtool_get_link_ksettings()
171 ctrl1000 = mii->mdio_read(dev, mii->phy_id, MII_CTRL1000); in mii_ethtool_get_link_ksettings()
172 stat1000 = mii->mdio_read(dev, mii->phy_id, MII_STAT1000); in mii_ethtool_get_link_ksettings()
176 cmd->base.autoneg = AUTONEG_ENABLE; in mii_ethtool_get_link_ksettings()
179 if (mii->supports_gmii) in mii_ethtool_get_link_ksettings()
194 cmd->base.speed = SPEED_1000; in mii_ethtool_get_link_ksettings()
195 cmd->base.duplex = !!(nego & ADVERTISED_1000baseT_Full); in mii_ethtool_get_link_ksettings()
198 cmd->base.speed = SPEED_100; in mii_ethtool_get_link_ksettings()
199 cmd->base.duplex = !!(nego & ADVERTISED_100baseT_Full); in mii_ethtool_get_link_ksettings()
201 cmd->base.speed = SPEED_10; in mii_ethtool_get_link_ksettings()
202 cmd->base.duplex = !!(nego & ADVERTISED_10baseT_Full); in mii_ethtool_get_link_ksettings()
205 cmd->base.autoneg = AUTONEG_DISABLE; in mii_ethtool_get_link_ksettings()
207 cmd->base.speed = ((bmcr & BMCR_SPEED1000 && in mii_ethtool_get_link_ksettings()
212 cmd->base.duplex = (bmcr & BMCR_FULLDPLX) ? in mii_ethtool_get_link_ksettings()
218 mii->full_duplex = cmd->base.duplex; in mii_ethtool_get_link_ksettings()
220 ethtool_convert_legacy_u32_to_link_mode(cmd->link_modes.supported, in mii_ethtool_get_link_ksettings()
222 ethtool_convert_legacy_u32_to_link_mode(cmd->link_modes.advertising, in mii_ethtool_get_link_ksettings()
224 ethtool_convert_legacy_u32_to_link_mode(cmd->link_modes.lp_advertising, in mii_ethtool_get_link_ksettings()
231 * mii_ethtool_sset - set settings that are specified in @ecmd
239 struct net_device *dev = mii->dev; in mii_ethtool_sset()
245 return -EINVAL; in mii_ethtool_sset()
246 if (ecmd->duplex != DUPLEX_HALF && ecmd->duplex != DUPLEX_FULL) in mii_ethtool_sset()
247 return -EINVAL; in mii_ethtool_sset()
248 if (ecmd->port != PORT_MII) in mii_ethtool_sset()
249 return -EINVAL; in mii_ethtool_sset()
250 if (ecmd->transceiver != XCVR_INTERNAL) in mii_ethtool_sset()
251 return -EINVAL; in mii_ethtool_sset()
252 if (ecmd->phy_address != mii->phy_id) in mii_ethtool_sset()
253 return -EINVAL; in mii_ethtool_sset()
254 if (ecmd->autoneg != AUTONEG_DISABLE && ecmd->autoneg != AUTONEG_ENABLE) in mii_ethtool_sset()
255 return -EINVAL; in mii_ethtool_sset()
256 if ((speed == SPEED_1000) && (!mii->supports_gmii)) in mii_ethtool_sset()
257 return -EINVAL; in mii_ethtool_sset()
261 if (ecmd->autoneg == AUTONEG_ENABLE) { in mii_ethtool_sset()
265 if ((ecmd->advertising & (ADVERTISED_10baseT_Half | in mii_ethtool_sset()
271 return -EINVAL; in mii_ethtool_sset()
274 advert = mii->mdio_read(dev, mii->phy_id, MII_ADVERTISE); in mii_ethtool_sset()
276 if (mii->supports_gmii) { in mii_ethtool_sset()
277 advert2 = mii->mdio_read(dev, mii->phy_id, MII_CTRL1000); in mii_ethtool_sset()
280 tmp |= ethtool_adv_to_mii_adv_t(ecmd->advertising); in mii_ethtool_sset()
282 if (mii->supports_gmii) in mii_ethtool_sset()
284 ethtool_adv_to_mii_ctrl1000_t(ecmd->advertising); in mii_ethtool_sset()
286 mii->mdio_write(dev, mii->phy_id, MII_ADVERTISE, tmp); in mii_ethtool_sset()
287 mii->advertising = tmp; in mii_ethtool_sset()
289 if ((mii->supports_gmii) && (advert2 != tmp2)) in mii_ethtool_sset()
290 mii->mdio_write(dev, mii->phy_id, MII_CTRL1000, tmp2); in mii_ethtool_sset()
293 bmcr = mii->mdio_read(dev, mii->phy_id, MII_BMCR); in mii_ethtool_sset()
295 mii->mdio_write(dev, mii->phy_id, MII_BMCR, bmcr); in mii_ethtool_sset()
297 mii->force_media = 0; in mii_ethtool_sset()
302 bmcr = mii->mdio_read(dev, mii->phy_id, MII_BMCR); in mii_ethtool_sset()
309 if (ecmd->duplex == DUPLEX_FULL) { in mii_ethtool_sset()
311 mii->full_duplex = 1; in mii_ethtool_sset()
313 mii->full_duplex = 0; in mii_ethtool_sset()
315 mii->mdio_write(dev, mii->phy_id, MII_BMCR, tmp); in mii_ethtool_sset()
317 mii->force_media = 1; in mii_ethtool_sset()
323 * mii_ethtool_set_link_ksettings - set settings that are specified in @cmd
332 struct net_device *dev = mii->dev; in mii_ethtool_set_link_ksettings()
333 u32 speed = cmd->base.speed; in mii_ethtool_set_link_ksettings()
338 return -EINVAL; in mii_ethtool_set_link_ksettings()
339 if (cmd->base.duplex != DUPLEX_HALF && cmd->base.duplex != DUPLEX_FULL) in mii_ethtool_set_link_ksettings()
340 return -EINVAL; in mii_ethtool_set_link_ksettings()
341 if (cmd->base.port != PORT_MII) in mii_ethtool_set_link_ksettings()
342 return -EINVAL; in mii_ethtool_set_link_ksettings()
343 if (cmd->base.phy_address != mii->phy_id) in mii_ethtool_set_link_ksettings()
344 return -EINVAL; in mii_ethtool_set_link_ksettings()
345 if (cmd->base.autoneg != AUTONEG_DISABLE && in mii_ethtool_set_link_ksettings()
346 cmd->base.autoneg != AUTONEG_ENABLE) in mii_ethtool_set_link_ksettings()
347 return -EINVAL; in mii_ethtool_set_link_ksettings()
348 if ((speed == SPEED_1000) && (!mii->supports_gmii)) in mii_ethtool_set_link_ksettings()
349 return -EINVAL; in mii_ethtool_set_link_ksettings()
353 if (cmd->base.autoneg == AUTONEG_ENABLE) { in mii_ethtool_set_link_ksettings()
359 &advertising, cmd->link_modes.advertising); in mii_ethtool_set_link_ksettings()
367 return -EINVAL; in mii_ethtool_set_link_ksettings()
370 advert = mii->mdio_read(dev, mii->phy_id, MII_ADVERTISE); in mii_ethtool_set_link_ksettings()
372 if (mii->supports_gmii) { in mii_ethtool_set_link_ksettings()
373 advert2 = mii->mdio_read(dev, mii->phy_id, in mii_ethtool_set_link_ksettings()
380 if (mii->supports_gmii) in mii_ethtool_set_link_ksettings()
383 mii->mdio_write(dev, mii->phy_id, MII_ADVERTISE, tmp); in mii_ethtool_set_link_ksettings()
384 mii->advertising = tmp; in mii_ethtool_set_link_ksettings()
386 if ((mii->supports_gmii) && (advert2 != tmp2)) in mii_ethtool_set_link_ksettings()
387 mii->mdio_write(dev, mii->phy_id, MII_CTRL1000, tmp2); in mii_ethtool_set_link_ksettings()
390 bmcr = mii->mdio_read(dev, mii->phy_id, MII_BMCR); in mii_ethtool_set_link_ksettings()
392 mii->mdio_write(dev, mii->phy_id, MII_BMCR, bmcr); in mii_ethtool_set_link_ksettings()
394 mii->force_media = 0; in mii_ethtool_set_link_ksettings()
399 bmcr = mii->mdio_read(dev, mii->phy_id, MII_BMCR); in mii_ethtool_set_link_ksettings()
406 if (cmd->base.duplex == DUPLEX_FULL) { in mii_ethtool_set_link_ksettings()
408 mii->full_duplex = 1; in mii_ethtool_set_link_ksettings()
410 mii->full_duplex = 0; in mii_ethtool_set_link_ksettings()
413 mii->mdio_write(dev, mii->phy_id, MII_BMCR, tmp); in mii_ethtool_set_link_ksettings()
415 mii->force_media = 1; in mii_ethtool_set_link_ksettings()
421 * mii_check_gmii_support - check if the MII supports Gb interfaces
428 reg = mii->mdio_read(mii->dev, mii->phy_id, MII_BMSR); in mii_check_gmii_support()
430 reg = mii->mdio_read(mii->dev, mii->phy_id, MII_ESTATUS); in mii_check_gmii_support()
439 * mii_link_ok - is link status up/ok
447 mii->mdio_read(mii->dev, mii->phy_id, MII_BMSR); in mii_link_ok()
448 if (mii->mdio_read(mii->dev, mii->phy_id, MII_BMSR) & BMSR_LSTATUS) in mii_link_ok()
454 * mii_nway_restart - restart NWay (autonegotiation) for this interface
462 int r = -EINVAL; in mii_nway_restart()
465 bmcr = mii->mdio_read(mii->dev, mii->phy_id, MII_BMCR); in mii_nway_restart()
469 mii->mdio_write(mii->dev, mii->phy_id, MII_BMCR, bmcr); in mii_nway_restart()
477 * mii_check_link - check MII link status
487 int prev_link = netif_carrier_ok(mii->dev); in mii_check_link()
490 netif_carrier_on(mii->dev); in mii_check_link()
492 netif_carrier_off(mii->dev); in mii_check_link()
496 * mii_check_media - check the MII interface for a carrier/speed/duplex change
513 old_carrier = netif_carrier_ok(mii->dev) ? 1 : 0; in mii_check_media()
524 netif_carrier_off(mii->dev); in mii_check_media()
526 netdev_info(mii->dev, "link down\n"); in mii_check_media()
533 netif_carrier_on(mii->dev); in mii_check_media()
535 if (mii->force_media) { in mii_check_media()
537 netdev_info(mii->dev, "link up\n"); in mii_check_media()
542 if ((!init_media) && (mii->advertising)) in mii_check_media()
543 advertise = mii->advertising; in mii_check_media()
545 advertise = mii->mdio_read(mii->dev, mii->phy_id, MII_ADVERTISE); in mii_check_media()
546 mii->advertising = advertise; in mii_check_media()
548 lpa = mii->mdio_read(mii->dev, mii->phy_id, MII_LPA); in mii_check_media()
549 if (mii->supports_gmii) in mii_check_media()
550 lpa2 = mii->mdio_read(mii->dev, mii->phy_id, MII_STAT1000); in mii_check_media()
559 netdev_info(mii->dev, "link up, %uMbps, %s-duplex, lpa 0x%04X\n", in mii_check_media()
566 if ((init_media) || (mii->full_duplex != duplex)) { in mii_check_media()
567 mii->full_duplex = duplex; in mii_check_media()
575 * generic_mii_ioctl - main MII ioctl interface
594 mii_data->phy_id &= mii_if->phy_id_mask; in generic_mii_ioctl()
595 mii_data->reg_num &= mii_if->reg_num_mask; in generic_mii_ioctl()
599 mii_data->phy_id = mii_if->phy_id; in generic_mii_ioctl()
603 mii_data->val_out = in generic_mii_ioctl()
604 mii_if->mdio_read(mii_if->dev, mii_data->phy_id, in generic_mii_ioctl()
605 mii_data->reg_num); in generic_mii_ioctl()
609 u16 val = mii_data->val_in; in generic_mii_ioctl()
611 if (mii_data->phy_id == mii_if->phy_id) { in generic_mii_ioctl()
612 switch(mii_data->reg_num) { in generic_mii_ioctl()
616 mii_if->force_media = 0; in generic_mii_ioctl()
618 mii_if->force_media = 1; in generic_mii_ioctl()
619 if (mii_if->force_media && in generic_mii_ioctl()
622 if (mii_if->full_duplex != new_duplex) { in generic_mii_ioctl()
624 mii_if->full_duplex = new_duplex; in generic_mii_ioctl()
629 mii_if->advertising = val; in generic_mii_ioctl()
637 mii_if->mdio_write(mii_if->dev, mii_data->phy_id, in generic_mii_ioctl()
638 mii_data->reg_num, val); in generic_mii_ioctl()
643 rc = -EOPNOTSUPP; in generic_mii_ioctl()