diff options
Diffstat (limited to 'drivers/net/phy/phylink.c')
| -rw-r--r-- | drivers/net/phy/phylink.c | 8 | 
1 files changed, 6 insertions, 2 deletions
| diff --git a/drivers/net/phy/phylink.c b/drivers/net/phy/phylink.c index e3bbc70372d3..249ce5cbea22 100644 --- a/drivers/net/phy/phylink.c +++ b/drivers/net/phy/phylink.c @@ -526,6 +526,7 @@ struct phylink *phylink_create(struct net_device *ndev, struct device_node *np,  	pl->link_config.pause = MLO_PAUSE_AN;  	pl->link_config.speed = SPEED_UNKNOWN;  	pl->link_config.duplex = DUPLEX_UNKNOWN; +	pl->link_config.an_enabled = true;  	pl->ops = ops;  	__set_bit(PHYLINK_DISABLE_STOPPED, &pl->phylink_disable_state); @@ -773,6 +774,7 @@ void phylink_stop(struct phylink *pl)  		sfp_upstream_stop(pl->sfp_bus);  	set_bit(PHYLINK_DISABLE_STOPPED, &pl->phylink_disable_state); +	queue_work(system_power_efficient_wq, &pl->resolve);  	flush_work(&pl->resolve);  }  EXPORT_SYMBOL_GPL(phylink_stop); @@ -950,6 +952,7 @@ int phylink_ethtool_ksettings_set(struct phylink *pl,  	mutex_lock(&pl->state_mutex);  	/* Configure the MAC to match the new settings */  	linkmode_copy(pl->link_config.advertising, our_kset.link_modes.advertising); +	pl->link_config.interface = config.interface;  	pl->link_config.speed = our_kset.base.speed;  	pl->link_config.duplex = our_kset.base.duplex;  	pl->link_config.an_enabled = our_kset.base.autoneg != AUTONEG_DISABLE; @@ -1293,6 +1296,7 @@ int phylink_mii_ioctl(struct phylink *pl, struct ifreq *ifr, int cmd)  		switch (cmd) {  		case SIOCGMIIPHY:  			mii->phy_id = pl->phydev->mdio.addr; +			/* fall through */  		case SIOCGMIIREG:  			ret = phylink_phy_read(pl, mii->phy_id, mii->reg_num); @@ -1315,6 +1319,7 @@ int phylink_mii_ioctl(struct phylink *pl, struct ifreq *ifr, int cmd)  		switch (cmd) {  		case SIOCGMIIPHY:  			mii->phy_id = 0; +			/* fall through */  		case SIOCGMIIREG:  			ret = phylink_mii_read(pl, mii->phy_id, mii->reg_num); @@ -1426,9 +1431,8 @@ static void phylink_sfp_link_down(void *upstream)  	WARN_ON(!lockdep_rtnl_is_held());  	set_bit(PHYLINK_DISABLE_LINK, &pl->phylink_disable_state); +	queue_work(system_power_efficient_wq, &pl->resolve);  	flush_work(&pl->resolve); - -	netif_carrier_off(pl->netdev);  }  static void phylink_sfp_link_up(void *upstream) | 
