phy: add phy_interface_mode_is_8023z() helper
authorRussell King <rmk+kernel@armlinux.org.uk>
Fri, 1 Dec 2017 10:24:16 +0000 (10:24 +0000)
committerDavid S. Miller <davem@davemloft.net>
Tue, 5 Dec 2017 16:16:17 +0000 (11:16 -0500)
Add and use phy_interface_mode_is_8023z() helper to identify the
interface modes that use 802.3z negotiation.  Use it in phylink's
phylink_mac_an_restart().

Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/phy/phylink.c
include/linux/phy.h

index 5dc9668dde34fe6b810c48f2bcd63e8609caa74e..a02d67689d6e8676f0ac54e3c0603928113692f1 100644 (file)
@@ -320,8 +320,7 @@ static void phylink_mac_config(struct phylink *pl,
 static void phylink_mac_an_restart(struct phylink *pl)
 {
        if (pl->link_config.an_enabled &&
-           (pl->link_config.interface == PHY_INTERFACE_MODE_1000BASEX ||
-            pl->link_config.interface == PHY_INTERFACE_MODE_2500BASEX))
+           phy_interface_mode_is_8023z(pl->link_config.interface))
                pl->ops->mac_an_restart(pl->netdev);
 }
 
index 50030da016648ac9f3dd54dc06e589ed73057fa1..7570cb838410dec7ff83654f6eb46aeb8779f81e 100644 (file)
@@ -761,6 +761,20 @@ static inline bool phy_interface_mode_is_rgmii(phy_interface_t mode)
                mode <= PHY_INTERFACE_MODE_RGMII_TXID;
 };
 
+/**
+ * phy_interface_mode_is_8023z() - does the phy interface mode use 802.3z
+ *   negotiation
+ * @mode: one of &enum phy_interface_t
+ *
+ * Returns true if the phy interface mode uses the 16-bit negotiation
+ * word as defined in 802.3z. (See 802.3-2015 37.2.1 Config_Reg encoding)
+ */
+static inline bool phy_interface_mode_is_8023z(phy_interface_t mode)
+{
+       return mode == PHY_INTERFACE_MODE_1000BASEX ||
+              mode == PHY_INTERFACE_MODE_2500BASEX;
+}
+
 /**
  * phy_interface_is_rgmii - Convenience function for testing if a PHY interface
  * is RGMII (all variants)