OSDN Git Service

net: phy: phylink: Provide PHY interface to mac_link_{up, down}
authorFlorian Fainelli <f.fainelli@gmail.com>
Wed, 28 Mar 2018 22:44:15 +0000 (15:44 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 30 Mar 2018 14:11:06 +0000 (10:11 -0400)
In preparation for having DSA transition entirely to PHYLINK, we need to pass a
PHY interface type to the mac_link_{up,down} callbacks because we may have to
make decisions on that (e.g: turn on/off RGMII interfaces etc.). We do not pass
an entire phylink_link_state because not all parameters (pause, duplex etc.) are
defined when the link is down, only link and interface are.

Update mvneta accordingly since it currently implements phylink_mac_ops.

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

index eaa4bb8..cd09bde 100644 (file)
@@ -3396,7 +3396,8 @@ static void mvneta_set_eee(struct mvneta_port *pp, bool enable)
        mvreg_write(pp, MVNETA_LPI_CTRL_1, lpi_ctl1);
 }
 
-static void mvneta_mac_link_down(struct net_device *ndev, unsigned int mode)
+static void mvneta_mac_link_down(struct net_device *ndev, unsigned int mode,
+                                phy_interface_t interface)
 {
        struct mvneta_port *pp = netdev_priv(ndev);
        u32 val;
@@ -3415,6 +3416,7 @@ static void mvneta_mac_link_down(struct net_device *ndev, unsigned int mode)
 }
 
 static void mvneta_mac_link_up(struct net_device *ndev, unsigned int mode,
+                              phy_interface_t interface,
                               struct phy_device *phy)
 {
        struct mvneta_port *pp = netdev_priv(ndev);
index 51a011a..9b1e472 100644 (file)
@@ -470,10 +470,12 @@ static void phylink_resolve(struct work_struct *w)
        if (link_state.link != netif_carrier_ok(ndev)) {
                if (!link_state.link) {
                        netif_carrier_off(ndev);
-                       pl->ops->mac_link_down(ndev, pl->link_an_mode);
+                       pl->ops->mac_link_down(ndev, pl->link_an_mode,
+                                              pl->phy_state.interface);
                        netdev_info(ndev, "Link is Down\n");
                } else {
                        pl->ops->mac_link_up(ndev, pl->link_an_mode,
+                                            pl->phy_state.interface,
                                             pl->phydev);
 
                        netif_carrier_on(ndev);
index bd137c2..e95cc12 100644 (file)
@@ -73,8 +73,10 @@ struct phylink_mac_ops {
        void (*mac_config)(struct net_device *ndev, unsigned int mode,
                           const struct phylink_link_state *state);
        void (*mac_an_restart)(struct net_device *ndev);
-       void (*mac_link_down)(struct net_device *ndev, unsigned int mode);
+       void (*mac_link_down)(struct net_device *ndev, unsigned int mode,
+                             phy_interface_t interface);
        void (*mac_link_up)(struct net_device *ndev, unsigned int mode,
+                           phy_interface_t interface,
                            struct phy_device *phy);
 };
 
@@ -161,25 +163,31 @@ void mac_an_restart(struct net_device *ndev);
  * mac_link_down() - take the link down
  * @ndev: a pointer to a &struct net_device for the MAC.
  * @mode: link autonegotiation mode
+ * @interface: link &typedef phy_interface_t mode
  *
  * If @mode is not an in-band negotiation mode (as defined by
  * phylink_autoneg_inband()), force the link down and disable any
- * Energy Efficient Ethernet MAC configuration.
+ * Energy Efficient Ethernet MAC configuration. Interface type
+ * selection must be done in mac_config().
  */
-void mac_link_down(struct net_device *ndev, unsigned int mode);
+void mac_link_down(struct net_device *ndev, unsigned int mode,
+                  phy_interface_t interface);
 
 /**
  * mac_link_up() - allow the link to come up
  * @ndev: a pointer to a &struct net_device for the MAC.
  * @mode: link autonegotiation mode
+ * @interface: link &typedef phy_interface_t mode
  * @phy: any attached phy
  *
  * If @mode is not an in-band negotiation mode (as defined by
  * phylink_autoneg_inband()), allow the link to come up. If @phy
  * is non-%NULL, configure Energy Efficient Ethernet by calling
  * phy_init_eee() and perform appropriate MAC configuration for EEE.
+ * Interface type selection must be done in mac_config().
  */
 void mac_link_up(struct net_device *ndev, unsigned int mode,
+                phy_interface_t interface,
                 struct phy_device *phy);
 #endif