diff options
Diffstat (limited to 'common/recipes-kernel/linux/linux-yocto-4.19.8/0616-Revert-net-phy-Replace-phy-driver-features-u32-with-.patch')
-rw-r--r-- | common/recipes-kernel/linux/linux-yocto-4.19.8/0616-Revert-net-phy-Replace-phy-driver-features-u32-with-.patch | 500 |
1 files changed, 500 insertions, 0 deletions
diff --git a/common/recipes-kernel/linux/linux-yocto-4.19.8/0616-Revert-net-phy-Replace-phy-driver-features-u32-with-.patch b/common/recipes-kernel/linux/linux-yocto-4.19.8/0616-Revert-net-phy-Replace-phy-driver-features-u32-with-.patch new file mode 100644 index 00000000..ab09d312 --- /dev/null +++ b/common/recipes-kernel/linux/linux-yocto-4.19.8/0616-Revert-net-phy-Replace-phy-driver-features-u32-with-.patch @@ -0,0 +1,500 @@ +From a9e69603a467fa4f4bc2403d6a803291258b9591 Mon Sep 17 00:00:00 2001 +From: Sudheesh Mavila <sudheesh.mavila@amd.com> +Date: Mon, 4 Feb 2019 11:49:32 +0530 +Subject: [PATCH 0616/2940] Revert "net: phy: Replace phy driver features u32 + with link_mode bitmap" + +This reverts commit 2e7f29f9450e373738039edc1b78f2597423fb89. +--- + drivers/net/ethernet/marvell/pxa168_eth.c | 4 +- + drivers/net/phy/aquantia.c | 12 +- + drivers/net/phy/bcm63xx.c | 9 +- + drivers/net/phy/et1011c.c | 2 +- + drivers/net/phy/marvell.c | 2 +- + drivers/net/phy/marvell10g.c | 11 +- + drivers/net/phy/microchip_t1.c | 2 +- + drivers/net/phy/phy_device.c | 164 +--------------------- + drivers/net/phy/ste10Xp.c | 4 +- + include/linux/linkmode.h | 9 -- + include/linux/phy.h | 24 ++-- + 11 files changed, 42 insertions(+), 201 deletions(-) + mode change 100755 => 100644 drivers/net/phy/et1011c.c + mode change 100755 => 100644 drivers/net/phy/ste10Xp.c + +diff --git a/drivers/net/ethernet/marvell/pxa168_eth.c b/drivers/net/ethernet/marvell/pxa168_eth.c +index b406395bbb37..3a9730612a70 100644 +--- a/drivers/net/ethernet/marvell/pxa168_eth.c ++++ b/drivers/net/ethernet/marvell/pxa168_eth.c +@@ -988,8 +988,8 @@ static int pxa168_init_phy(struct net_device *dev) + cmd.base.phy_address = pep->phy_addr; + cmd.base.speed = pep->phy_speed; + cmd.base.duplex = pep->phy_duplex; +- bitmap_copy(cmd.link_modes.advertising, PHY_BASIC_FEATURES, +- __ETHTOOL_LINK_MODE_MASK_NBITS); ++ ethtool_convert_legacy_u32_to_link_mode(cmd.link_modes.advertising, ++ PHY_BASIC_FEATURES); + cmd.base.autoneg = AUTONEG_ENABLE; + + if (cmd.base.speed != 0) +diff --git a/drivers/net/phy/aquantia.c b/drivers/net/phy/aquantia.c +index 632472cab3bb..319edc9c8ec7 100644 +--- a/drivers/net/phy/aquantia.c ++++ b/drivers/net/phy/aquantia.c +@@ -115,7 +115,7 @@ static struct phy_driver aquantia_driver[] = { + .phy_id = PHY_ID_AQ1202, + .phy_id_mask = 0xfffffff0, + .name = "Aquantia AQ1202", +- .features = PHY_10GBIT_FULL_FEATURES, ++ .features = PHY_AQUANTIA_FEATURES, + .flags = PHY_HAS_INTERRUPT, + .aneg_done = genphy_c45_aneg_done, + .config_aneg = aquantia_config_aneg, +@@ -127,7 +127,7 @@ static struct phy_driver aquantia_driver[] = { + .phy_id = PHY_ID_AQ2104, + .phy_id_mask = 0xfffffff0, + .name = "Aquantia AQ2104", +- .features = PHY_10GBIT_FULL_FEATURES, ++ .features = PHY_AQUANTIA_FEATURES, + .flags = PHY_HAS_INTERRUPT, + .aneg_done = genphy_c45_aneg_done, + .config_aneg = aquantia_config_aneg, +@@ -139,7 +139,7 @@ static struct phy_driver aquantia_driver[] = { + .phy_id = PHY_ID_AQR105, + .phy_id_mask = 0xfffffff0, + .name = "Aquantia AQR105", +- .features = PHY_10GBIT_FULL_FEATURES, ++ .features = PHY_AQUANTIA_FEATURES, + .flags = PHY_HAS_INTERRUPT, + .aneg_done = genphy_c45_aneg_done, + .config_aneg = aquantia_config_aneg, +@@ -151,7 +151,7 @@ static struct phy_driver aquantia_driver[] = { + .phy_id = PHY_ID_AQR106, + .phy_id_mask = 0xfffffff0, + .name = "Aquantia AQR106", +- .features = PHY_10GBIT_FULL_FEATURES, ++ .features = PHY_AQUANTIA_FEATURES, + .flags = PHY_HAS_INTERRUPT, + .aneg_done = genphy_c45_aneg_done, + .config_aneg = aquantia_config_aneg, +@@ -163,7 +163,7 @@ static struct phy_driver aquantia_driver[] = { + .phy_id = PHY_ID_AQR107, + .phy_id_mask = 0xfffffff0, + .name = "Aquantia AQR107", +- .features = PHY_10GBIT_FULL_FEATURES, ++ .features = PHY_AQUANTIA_FEATURES, + .flags = PHY_HAS_INTERRUPT, + .aneg_done = genphy_c45_aneg_done, + .config_aneg = aquantia_config_aneg, +@@ -175,7 +175,7 @@ static struct phy_driver aquantia_driver[] = { + .phy_id = PHY_ID_AQR405, + .phy_id_mask = 0xfffffff0, + .name = "Aquantia AQR405", +- .features = PHY_10GBIT_FULL_FEATURES, ++ .features = PHY_AQUANTIA_FEATURES, + .flags = PHY_HAS_INTERRUPT, + .aneg_done = genphy_c45_aneg_done, + .config_aneg = aquantia_config_aneg, +diff --git a/drivers/net/phy/bcm63xx.c b/drivers/net/phy/bcm63xx.c +index d95bffdec4c1..cf14613745c9 100644 +--- a/drivers/net/phy/bcm63xx.c ++++ b/drivers/net/phy/bcm63xx.c +@@ -42,9 +42,6 @@ static int bcm63xx_config_init(struct phy_device *phydev) + { + int reg, err; + +- /* ASYM_PAUSE bit is marked RO in datasheet, so don't cheat */ +- phydev->supported |= SUPPORTED_Pause; +- + reg = phy_read(phydev, MII_BCM63XX_IR); + if (reg < 0) + return reg; +@@ -68,7 +65,8 @@ static struct phy_driver bcm63xx_driver[] = { + .phy_id = 0x00406000, + .phy_id_mask = 0xfffffc00, + .name = "Broadcom BCM63XX (1)", +- .features = PHY_BASIC_FEATURES, ++ /* ASYM_PAUSE bit is marked RO in datasheet, so don't cheat */ ++ .features = (PHY_BASIC_FEATURES | SUPPORTED_Pause), + .flags = PHY_HAS_INTERRUPT | PHY_IS_INTERNAL, + .config_init = bcm63xx_config_init, + .ack_interrupt = bcm_phy_ack_intr, +@@ -77,7 +75,8 @@ static struct phy_driver bcm63xx_driver[] = { + /* same phy as above, with just a different OUI */ + .phy_id = 0x002bdc00, + .phy_id_mask = 0xfffffc00, +- .features = PHY_BASIC_FEATURES, ++ .name = "Broadcom BCM63XX (2)", ++ .features = (PHY_BASIC_FEATURES | SUPPORTED_Pause), + .flags = PHY_HAS_INTERRUPT | PHY_IS_INTERNAL, + .config_init = bcm63xx_config_init, + .ack_interrupt = bcm_phy_ack_intr, +diff --git a/drivers/net/phy/et1011c.c b/drivers/net/phy/et1011c.c +old mode 100755 +new mode 100644 +index ab541c9c56fb..a9a4edfa23c8 +--- a/drivers/net/phy/et1011c.c ++++ b/drivers/net/phy/et1011c.c +@@ -91,7 +91,7 @@ static struct phy_driver et1011c_driver[] = { { + .phy_id = 0x0282f014, + .name = "ET1011C", + .phy_id_mask = 0xfffffff0, +- .features = PHY_GBIT_FEATURES, ++ .features = (PHY_BASIC_FEATURES | SUPPORTED_1000baseT_Full), + .flags = PHY_POLL, + .config_aneg = et1011c_config_aneg, + .read_status = et1011c_read_status, +diff --git a/drivers/net/phy/marvell.c b/drivers/net/phy/marvell.c +index de1e900f7253..f7c69ca34056 100644 +--- a/drivers/net/phy/marvell.c ++++ b/drivers/net/phy/marvell.c +@@ -2222,7 +2222,7 @@ static struct phy_driver marvell_drivers[] = { + .phy_id = MARVELL_PHY_ID_88E1510, + .phy_id_mask = MARVELL_PHY_ID_MASK, + .name = "Marvell 88E1510", +- .features = PHY_GBIT_FIBRE_FEATURES, ++ .features = PHY_GBIT_FEATURES | SUPPORTED_FIBRE, + .flags = PHY_HAS_INTERRUPT, + .probe = &m88e1510_probe, + .config_init = &m88e1510_config_init, +diff --git a/drivers/net/phy/marvell10g.c b/drivers/net/phy/marvell10g.c +index 7f4a43c65da6..f77a2d9e7f9d 100644 +--- a/drivers/net/phy/marvell10g.c ++++ b/drivers/net/phy/marvell10g.c +@@ -535,7 +535,16 @@ static struct phy_driver mv3310_drivers[] = { + .phy_id = 0x002b09aa, + .phy_id_mask = MARVELL_PHY_ID_MASK, + .name = "mv88x3310", +- .features = PHY_10GBIT_FEATURES, ++ .features = SUPPORTED_10baseT_Full | ++ SUPPORTED_10baseT_Half | ++ SUPPORTED_100baseT_Full | ++ SUPPORTED_100baseT_Half | ++ SUPPORTED_1000baseT_Full | ++ SUPPORTED_Autoneg | ++ SUPPORTED_TP | ++ SUPPORTED_FIBRE | ++ SUPPORTED_10000baseT_Full | ++ SUPPORTED_Backplane, + .soft_reset = gen10g_no_soft_reset, + .config_init = mv3310_config_init, + .probe = mv3310_probe, +diff --git a/drivers/net/phy/microchip_t1.c b/drivers/net/phy/microchip_t1.c +index c600a8509d60..b1917dd1978a 100644 +--- a/drivers/net/phy/microchip_t1.c ++++ b/drivers/net/phy/microchip_t1.c +@@ -46,7 +46,7 @@ static struct phy_driver microchip_t1_phy_driver[] = { + .phy_id_mask = 0xfffffff0, + .name = "Microchip LAN87xx T1", + +- .features = PHY_BASIC_T1_FEATURES, ++ .features = SUPPORTED_100baseT_Full, + .flags = PHY_HAS_INTERRUPT, + + .config_init = genphy_config_init, +diff --git a/drivers/net/phy/phy_device.c b/drivers/net/phy/phy_device.c +index 9ce93eb66fb0..733e35b7c4bb 100644 +--- a/drivers/net/phy/phy_device.c ++++ b/drivers/net/phy/phy_device.c +@@ -29,7 +29,6 @@ + #include <linux/module.h> + #include <linux/mii.h> + #include <linux/ethtool.h> +-#include <linux/bitmap.h> + #include <linux/phy.h> + #include <linux/phy_led_triggers.h> + #include <linux/mdio.h> +@@ -43,149 +42,6 @@ MODULE_DESCRIPTION("PHY library"); + MODULE_AUTHOR("Andy Fleming"); + MODULE_LICENSE("GPL"); + +-__ETHTOOL_DECLARE_LINK_MODE_MASK(phy_basic_features) __ro_after_init; +-EXPORT_SYMBOL_GPL(phy_basic_features); +- +-__ETHTOOL_DECLARE_LINK_MODE_MASK(phy_basic_t1_features) __ro_after_init; +-EXPORT_SYMBOL_GPL(phy_basic_t1_features); +- +-__ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_features) __ro_after_init; +-EXPORT_SYMBOL_GPL(phy_gbit_features); +- +-__ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_fibre_features) __ro_after_init; +-EXPORT_SYMBOL_GPL(phy_gbit_fibre_features); +- +-__ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_all_ports_features) __ro_after_init; +-EXPORT_SYMBOL_GPL(phy_gbit_all_ports_features); +- +-__ETHTOOL_DECLARE_LINK_MODE_MASK(phy_10gbit_features) __ro_after_init; +-EXPORT_SYMBOL_GPL(phy_10gbit_features); +- +-static const int phy_basic_ports_array[] = { +- ETHTOOL_LINK_MODE_Autoneg_BIT, +- ETHTOOL_LINK_MODE_TP_BIT, +- ETHTOOL_LINK_MODE_MII_BIT, +-}; +- +-static const int phy_fibre_port_array[] = { +- ETHTOOL_LINK_MODE_FIBRE_BIT, +-}; +- +-static const int phy_all_ports_features_array[] = { +- ETHTOOL_LINK_MODE_Autoneg_BIT, +- ETHTOOL_LINK_MODE_TP_BIT, +- ETHTOOL_LINK_MODE_MII_BIT, +- ETHTOOL_LINK_MODE_FIBRE_BIT, +- ETHTOOL_LINK_MODE_AUI_BIT, +- ETHTOOL_LINK_MODE_BNC_BIT, +- ETHTOOL_LINK_MODE_Backplane_BIT, +-}; +- +-static const int phy_10_100_features_array[] = { +- ETHTOOL_LINK_MODE_10baseT_Half_BIT, +- ETHTOOL_LINK_MODE_10baseT_Full_BIT, +- ETHTOOL_LINK_MODE_100baseT_Half_BIT, +- ETHTOOL_LINK_MODE_100baseT_Full_BIT, +-}; +- +-static const int phy_basic_t1_features_array[] = { +- ETHTOOL_LINK_MODE_TP_BIT, +- ETHTOOL_LINK_MODE_100baseT_Full_BIT, +-}; +- +-static const int phy_gbit_features_array[] = { +- ETHTOOL_LINK_MODE_1000baseT_Half_BIT, +- ETHTOOL_LINK_MODE_1000baseT_Full_BIT, +-}; +- +-static const int phy_10gbit_features_array[] = { +- ETHTOOL_LINK_MODE_10000baseT_Full_BIT, +-}; +- +-__ETHTOOL_DECLARE_LINK_MODE_MASK(phy_10gbit_full_features) __ro_after_init; +-EXPORT_SYMBOL_GPL(phy_10gbit_full_features); +- +-static const int phy_10gbit_full_features_array[] = { +- ETHTOOL_LINK_MODE_10baseT_Full_BIT, +- ETHTOOL_LINK_MODE_100baseT_Full_BIT, +- ETHTOOL_LINK_MODE_1000baseT_Full_BIT, +- ETHTOOL_LINK_MODE_10000baseT_Full_BIT, +-}; +- +-static void features_init(void) +-{ +- /* 10/100 half/full*/ +- linkmode_set_bit_array(phy_basic_ports_array, +- ARRAY_SIZE(phy_basic_ports_array), +- phy_basic_features); +- linkmode_set_bit_array(phy_10_100_features_array, +- ARRAY_SIZE(phy_10_100_features_array), +- phy_basic_features); +- +- /* 100 full, TP */ +- linkmode_set_bit_array(phy_basic_t1_features_array, +- ARRAY_SIZE(phy_basic_t1_features_array), +- phy_basic_t1_features); +- +- /* 10/100 half/full + 1000 half/full */ +- linkmode_set_bit_array(phy_basic_ports_array, +- ARRAY_SIZE(phy_basic_ports_array), +- phy_gbit_features); +- linkmode_set_bit_array(phy_10_100_features_array, +- ARRAY_SIZE(phy_10_100_features_array), +- phy_gbit_features); +- linkmode_set_bit_array(phy_gbit_features_array, +- ARRAY_SIZE(phy_gbit_features_array), +- phy_gbit_features); +- +- /* 10/100 half/full + 1000 half/full + fibre*/ +- linkmode_set_bit_array(phy_basic_ports_array, +- ARRAY_SIZE(phy_basic_ports_array), +- phy_gbit_fibre_features); +- linkmode_set_bit_array(phy_10_100_features_array, +- ARRAY_SIZE(phy_10_100_features_array), +- phy_gbit_fibre_features); +- linkmode_set_bit_array(phy_gbit_features_array, +- ARRAY_SIZE(phy_gbit_features_array), +- phy_gbit_fibre_features); +- linkmode_set_bit_array(phy_fibre_port_array, +- ARRAY_SIZE(phy_fibre_port_array), +- phy_gbit_fibre_features); +- +- /* 10/100 half/full + 1000 half/full + TP/MII/FIBRE/AUI/BNC/Backplane*/ +- linkmode_set_bit_array(phy_all_ports_features_array, +- ARRAY_SIZE(phy_all_ports_features_array), +- phy_gbit_all_ports_features); +- linkmode_set_bit_array(phy_10_100_features_array, +- ARRAY_SIZE(phy_10_100_features_array), +- phy_gbit_all_ports_features); +- linkmode_set_bit_array(phy_gbit_features_array, +- ARRAY_SIZE(phy_gbit_features_array), +- phy_gbit_all_ports_features); +- +- /* 10/100 half/full + 1000 half/full + 10G full*/ +- linkmode_set_bit_array(phy_all_ports_features_array, +- ARRAY_SIZE(phy_all_ports_features_array), +- phy_10gbit_features); +- linkmode_set_bit_array(phy_10_100_features_array, +- ARRAY_SIZE(phy_10_100_features_array), +- phy_10gbit_features); +- linkmode_set_bit_array(phy_gbit_features_array, +- ARRAY_SIZE(phy_gbit_features_array), +- phy_10gbit_features); +- linkmode_set_bit_array(phy_10gbit_features_array, +- ARRAY_SIZE(phy_10gbit_features_array), +- phy_10gbit_features); +- +- /* 10/100/1000/10G full */ +- linkmode_set_bit_array(phy_all_ports_features_array, +- ARRAY_SIZE(phy_all_ports_features_array), +- phy_10gbit_full_features); +- linkmode_set_bit_array(phy_10gbit_full_features_array, +- ARRAY_SIZE(phy_10gbit_full_features_array), +- phy_10gbit_full_features); +-} +- + void phy_device_free(struct phy_device *phydev) + { + put_device(&phydev->mdio.dev); +@@ -1970,7 +1826,6 @@ static int phy_probe(struct device *dev) + struct phy_device *phydev = to_phy_device(dev); + struct device_driver *drv = phydev->mdio.dev.driver; + struct phy_driver *phydrv = to_phy_driver(drv); +- u32 features; + int err = 0; + + phydev->drv = phydrv; +@@ -1991,8 +1846,7 @@ static int phy_probe(struct device *dev) + * a controller will attach, and may modify one + * or both of these values + */ +- ethtool_convert_link_mode_to_legacy_u32(&features, phydrv->features); +- phydev->supported = features; ++ phydev->supported = phydrv->features; + of_set_phy_supported(phydev); + phydev->advertising = phydev->supported; + +@@ -2012,14 +1866,10 @@ static int phy_probe(struct device *dev) + * (e.g. hardware erratum) where the driver wants to set only one + * of these bits. + */ +- if (test_bit(ETHTOOL_LINK_MODE_Pause_BIT, phydrv->features) || +- test_bit(ETHTOOL_LINK_MODE_Asym_Pause_BIT, phydrv->features)) { ++ if (phydrv->features & (SUPPORTED_Pause | SUPPORTED_Asym_Pause)) { + phydev->supported &= ~(SUPPORTED_Pause | SUPPORTED_Asym_Pause); +- if (test_bit(ETHTOOL_LINK_MODE_Pause_BIT, phydrv->features)) +- phydev->supported |= SUPPORTED_Pause; +- if (test_bit(ETHTOOL_LINK_MODE_Asym_Pause_BIT, +- phydrv->features)) +- phydev->supported |= SUPPORTED_Asym_Pause; ++ phydev->supported |= phydrv->features & ++ (SUPPORTED_Pause | SUPPORTED_Asym_Pause); + } else { + phydev->supported |= SUPPORTED_Pause | SUPPORTED_Asym_Pause; + } +@@ -2140,7 +1990,9 @@ static struct phy_driver genphy_driver = { + .name = "Generic PHY", + .soft_reset = genphy_no_soft_reset, + .config_init = genphy_config_init, +- .features = PHY_GBIT_ALL_PORTS_FEATURES, ++ .features = PHY_GBIT_FEATURES | SUPPORTED_MII | ++ SUPPORTED_AUI | SUPPORTED_FIBRE | ++ SUPPORTED_BNC, + .aneg_done = genphy_aneg_done, + .suspend = genphy_suspend, + .resume = genphy_resume, +@@ -2155,8 +2007,6 @@ static int __init phy_init(void) + if (rc) + return rc; + +- features_init(); +- + rc = phy_driver_register(&genphy_10g_driver, THIS_MODULE); + if (rc) + goto err_10g; +diff --git a/drivers/net/phy/ste10Xp.c b/drivers/net/phy/ste10Xp.c +old mode 100755 +new mode 100644 +index 2fe9a87b55b5..fbd548a1ad84 +--- a/drivers/net/phy/ste10Xp.c ++++ b/drivers/net/phy/ste10Xp.c +@@ -86,7 +86,7 @@ static struct phy_driver ste10xp_pdriver[] = { + .phy_id = STE101P_PHY_ID, + .phy_id_mask = 0xfffffff0, + .name = "STe101p", +- .features = PHY_BASIC_FEATURES, ++ .features = PHY_BASIC_FEATURES | SUPPORTED_Pause, + .flags = PHY_HAS_INTERRUPT, + .config_init = ste10Xp_config_init, + .ack_interrupt = ste10Xp_ack_interrupt, +@@ -97,7 +97,7 @@ static struct phy_driver ste10xp_pdriver[] = { + .phy_id = STE100P_PHY_ID, + .phy_id_mask = 0xffffffff, + .name = "STe100p", +- .features = PHY_BASIC_FEATURES, ++ .features = PHY_BASIC_FEATURES | SUPPORTED_Pause, + .flags = PHY_HAS_INTERRUPT, + .config_init = ste10Xp_config_init, + .ack_interrupt = ste10Xp_ack_interrupt, +diff --git a/include/linux/linkmode.h b/include/linux/linkmode.h +index 22443d7fb5cd..014fb86c7114 100644 +--- a/include/linux/linkmode.h ++++ b/include/linux/linkmode.h +@@ -43,15 +43,6 @@ static inline void linkmode_set_bit(int nr, volatile unsigned long *addr) + __set_bit(nr, addr); + } + +-static inline void linkmode_set_bit_array(const int *array, int array_size, +- unsigned long *addr) +-{ +- int i; +- +- for (i = 0; i < array_size; i++) +- linkmode_set_bit(array[i], addr); +-} +- + static inline void linkmode_clear_bit(int nr, volatile unsigned long *addr) + { + __clear_bit(nr, addr); +diff --git a/include/linux/phy.h b/include/linux/phy.h +index 7086051820f9..81532a61e995 100644 +--- a/include/linux/phy.h ++++ b/include/linux/phy.h +@@ -42,21 +42,13 @@ + #define PHY_1000BT_FEATURES (SUPPORTED_1000baseT_Half | \ + SUPPORTED_1000baseT_Full) + +-extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_basic_features) __ro_after_init; +-extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_basic_t1_features) __ro_after_init; +-extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_features) __ro_after_init; +-extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_fibre_features) __ro_after_init; +-extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_all_ports_features) __ro_after_init; +-extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_10gbit_features) __ro_after_init; +-extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_10gbit_full_features) __ro_after_init; +- +-#define PHY_BASIC_FEATURES ((unsigned long *)&phy_basic_features) +-#define PHY_BASIC_T1_FEATURES ((unsigned long *)&phy_basic_t1_features) +-#define PHY_GBIT_FEATURES ((unsigned long *)&phy_gbit_features) +-#define PHY_GBIT_FIBRE_FEATURES ((unsigned long *)&phy_gbit_fibre_features) +-#define PHY_GBIT_ALL_PORTS_FEATURES ((unsigned long *)&phy_gbit_all_ports_features) +-#define PHY_10GBIT_FEATURES ((unsigned long *)&phy_10gbit_features) +-#define PHY_10GBIT_FULL_FEATURES ((unsigned long *)&phy_10gbit_full_features) ++#define PHY_BASIC_FEATURES (PHY_10BT_FEATURES | \ ++ PHY_100BT_FEATURES | \ ++ PHY_DEFAULT_FEATURES) ++ ++#define PHY_GBIT_FEATURES (PHY_BASIC_FEATURES | \ ++ PHY_1000BT_FEATURES) ++ + + /* + * Set phydev->irq to PHY_POLL if interrupts are not supported, +@@ -518,7 +510,7 @@ struct phy_driver { + u32 phy_id; + char *name; + u32 phy_id_mask; +- const unsigned long * const features; ++ u32 features; + u32 flags; + const void *driver_data; + +-- +2.17.1 + |