igb: correct link test not being run when link is down
authorAlexander Duyck <alexander.h.duyck@intel.com>
Thu, 1 Jul 2010 13:39:01 +0000 (13:39 +0000)
committerDavid S. Miller <davem@davemloft.net>
Fri, 2 Jul 2010 05:45:57 +0000 (22:45 -0700)
The igb online link test was always reporting pass because instead of
checking for if_running it was checking for netif_carrier_ok.

This change corrects the test so that it is run if the interface is running
instead of checking for netif carrier ok.

Signed-off-by: Alexander Duyck <alexander.h.duyck@intel.com>
Tested-by: Emil Tantilov <emil.s.tantilov@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/igb/igb_ethtool.c

index f2ebf927e4bc0d2b6ab21285f9c54ebd0937829f..26bf6a13d1c1a6e40beb4f1b8ec9c207fb501e1a 100644 (file)
@@ -1823,12 +1823,10 @@ static void igb_diag_test(struct net_device *netdev,
                dev_info(&adapter->pdev->dev, "online testing starting\n");
 
                /* PHY is powered down when interface is down */
-               if (!netif_carrier_ok(netdev)) {
+               if (if_running && igb_link_test(adapter, &data[4]))
+                       eth_test->flags |= ETH_TEST_FL_FAILED;
+               else
                        data[4] = 0;
-               } else {
-                       if (igb_link_test(adapter, &data[4]))
-                               eth_test->flags |= ETH_TEST_FL_FAILED;
-               }
 
                /* Online tests aren't run; pass by default */
                data[0] = 0;