be2net: Signal that the device cannot transmit during reconfiguration
authorBenjamin Poirier <bpoirier@suse.com>
Tue, 16 Jul 2019 08:16:55 +0000 (17:16 +0900)
committerDavid S. Miller <davem@davemloft.net>
Tue, 16 Jul 2019 19:41:37 +0000 (12:41 -0700)
While changing the number of interrupt channels, be2net stops adapter
operation (including netif_tx_disable()) but it doesn't signal that it
cannot transmit. This may lead dev_watchdog() to falsely trigger during
that time.

Add the missing call to netif_carrier_off(), following the pattern used in
many other drivers. netif_carrier_on() is already taken care of in
be_open().

Signed-off-by: Benjamin Poirier <bpoirier@suse.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/emulex/benet/be_main.c

index 82015c8a5ed73e16e365fcc9558620b706e546c1..b7a246b335990ac4cc2b6dc47d80bc7424e54a20 100644 (file)
@@ -4697,8 +4697,12 @@ int be_update_queues(struct be_adapter *adapter)
        struct net_device *netdev = adapter->netdev;
        int status;
 
-       if (netif_running(netdev))
+       if (netif_running(netdev)) {
+               /* device cannot transmit now, avoid dev_watchdog timeouts */
+               netif_carrier_off(netdev);
+
                be_close(netdev);
+       }
 
        be_cancel_worker(adapter);