tsnep: Add link down PHY loopback support
authorGerhard Engleder <gerhard@engleder-embedded.com>
Tue, 23 Jan 2024 20:01:51 +0000 (21:01 +0100)
committerJakub Kicinski <kuba@kernel.org>
Fri, 26 Jan 2024 01:33:51 +0000 (17:33 -0800)
PHY loopback turns off link state change signalling. Therefore, the
loopback only works if the link is already up before the PHY loopback is
activated.

Ensure that PHY loopback works even if the link is not already up during
activation by calling netif_carrier_on() explicitly.

Signed-off-by: Gerhard Engleder <gerhard@engleder-embedded.com>
Link: https://lore.kernel.org/r/20240123200151.60848-1-gerhard@engleder-embedded.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/engleder/tsnep_main.c

index 9aeff2b..ae0b8b3 100644 (file)
@@ -229,8 +229,10 @@ static int tsnep_phy_loopback(struct tsnep_adapter *adapter, bool enable)
         * would delay a working loopback anyway, let's ensure that loopback
         * is working immediately by setting link mode directly
         */
-       if (!retval && enable)
+       if (!retval && enable) {
+               netif_carrier_on(adapter->netdev);
                tsnep_set_link_mode(adapter);
+       }
 
        return retval;
 }