diff options
Diffstat (limited to 'drivers/net/phy/micrel.c')
| -rw-r--r-- | drivers/net/phy/micrel.c | 31 | 
1 files changed, 11 insertions, 20 deletions
| diff --git a/drivers/net/phy/micrel.c b/drivers/net/phy/micrel.c index 9265dea79412..c33384710d26 100644 --- a/drivers/net/phy/micrel.c +++ b/drivers/net/phy/micrel.c @@ -311,17 +311,22 @@ static int kszphy_config_init(struct phy_device *phydev)  static int ksz8041_config_init(struct phy_device *phydev)  { +	__ETHTOOL_DECLARE_LINK_MODE_MASK(mask) = { 0, }; +  	struct device_node *of_node = phydev->mdio.dev.of_node;  	/* Limit supported and advertised modes in fiber mode */  	if (of_property_read_bool(of_node, "micrel,fiber-mode")) {  		phydev->dev_flags |= MICREL_PHY_FXEN; -		phydev->supported &= SUPPORTED_100baseT_Full | -				     SUPPORTED_100baseT_Half; -		phydev->supported |= SUPPORTED_FIBRE; -		phydev->advertising &= ADVERTISED_100baseT_Full | -				       ADVERTISED_100baseT_Half; -		phydev->advertising |= ADVERTISED_FIBRE; +		linkmode_set_bit(ETHTOOL_LINK_MODE_100baseT_Full_BIT, mask); +		linkmode_set_bit(ETHTOOL_LINK_MODE_100baseT_Half_BIT, mask); + +		linkmode_and(phydev->supported, phydev->supported, mask); +		linkmode_set_bit(ETHTOOL_LINK_MODE_FIBRE_BIT, +				 phydev->supported); +		linkmode_and(phydev->advertising, phydev->advertising, mask); +		linkmode_set_bit(ETHTOOL_LINK_MODE_FIBRE_BIT, +				 phydev->advertising);  		phydev->autoneg = AUTONEG_DISABLE;  	} @@ -918,7 +923,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.name		= "Micrel KS8737",  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ks8737_type,  	.config_init	= kszphy_config_init,  	.ack_interrupt	= kszphy_ack_interrupt, @@ -930,7 +934,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= 0x00ffffff,  	.name		= "Micrel KSZ8021 or KSZ8031",  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz8021_type,  	.probe		= kszphy_probe,  	.config_init	= kszphy_config_init, @@ -946,7 +949,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= 0x00ffffff,  	.name		= "Micrel KSZ8031",  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz8021_type,  	.probe		= kszphy_probe,  	.config_init	= kszphy_config_init, @@ -962,7 +964,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.name		= "Micrel KSZ8041",  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz8041_type,  	.probe		= kszphy_probe,  	.config_init	= ksz8041_config_init, @@ -979,7 +980,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.name		= "Micrel KSZ8041RNLI",  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz8041_type,  	.probe		= kszphy_probe,  	.config_init	= kszphy_config_init, @@ -995,7 +995,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.name		= "Micrel KSZ8051",  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz8051_type,  	.probe		= kszphy_probe,  	.config_init	= kszphy_config_init, @@ -1011,7 +1010,6 @@ static struct phy_driver ksphy_driver[] = {  	.name		= "Micrel KSZ8001 or KS8721",  	.phy_id_mask	= 0x00fffffc,  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz8041_type,  	.probe		= kszphy_probe,  	.config_init	= kszphy_config_init, @@ -1027,7 +1025,6 @@ static struct phy_driver ksphy_driver[] = {  	.name		= "Micrel KSZ8081 or KSZ8091",  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz8081_type,  	.probe		= kszphy_probe,  	.config_init	= kszphy_config_init, @@ -1043,7 +1040,6 @@ static struct phy_driver ksphy_driver[] = {  	.name		= "Micrel KSZ8061",  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.config_init	= kszphy_config_init,  	.ack_interrupt	= kszphy_ack_interrupt,  	.config_intr	= kszphy_config_intr, @@ -1054,7 +1050,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= 0x000ffffe,  	.name		= "Micrel KSZ9021 Gigabit PHY",  	.features	= PHY_GBIT_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz9021_type,  	.probe		= kszphy_probe,  	.config_init	= ksz9021_config_init, @@ -1072,7 +1067,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.name		= "Micrel KSZ9031 Gigabit PHY",  	.features	= PHY_GBIT_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz9021_type,  	.probe		= kszphy_probe,  	.config_init	= ksz9031_config_init, @@ -1089,7 +1083,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.name		= "Microchip KSZ9131 Gigabit PHY",  	.features	= PHY_GBIT_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.driver_data	= &ksz9021_type,  	.probe		= kszphy_probe,  	.config_init	= ksz9131_config_init, @@ -1115,7 +1108,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.name		= "Micrel KSZ886X Switch",  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.config_init	= kszphy_config_init,  	.suspend	= genphy_suspend,  	.resume		= genphy_resume, @@ -1124,7 +1116,6 @@ static struct phy_driver ksphy_driver[] = {  	.phy_id_mask	= MICREL_PHY_ID_MASK,  	.name		= "Micrel KSZ8795",  	.features	= PHY_BASIC_FEATURES, -	.flags		= PHY_HAS_INTERRUPT,  	.config_init	= kszphy_config_init,  	.config_aneg	= ksz8873mll_config_aneg,  	.read_status	= ksz8873mll_read_status, | 
