Commit 976ee3b2 authored by Shannon Nelson's avatar Shannon Nelson Committed by David S. Miller

ionic: wait on queue start until after IFF_UP

The netif_running() test looks at __LINK_STATE_START which
gets set before ndo_open() is called, there is a window of
time between that and when the queues are actually ready to
be run.  If ionic_check_link_status() notices that the link is
up very soon after netif_running() becomes true, it might try
to run the queues before they are ready, causing all manner of
potential issues.  Since the netdev->flags IFF_UP isn't set
until after ndo_open() returns, we can wait for that before
we allow ionic_check_link_status() to start the queues.

On the way back to close, __LINK_STATE_START is cleared before
calling ndo_stop(), and IFF_UP is cleared after.  Both of
these need to be true in order to safely stop the queues
from ionic_check_link_status().

Fixes: 49d3b493 ("ionic: disable the queues on link down")
Signed-off-by: default avatarShannon Nelson <snelson@pensando.io>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 1a3db27a
...@@ -116,7 +116,7 @@ static void ionic_link_status_check(struct ionic_lif *lif) ...@@ -116,7 +116,7 @@ static void ionic_link_status_check(struct ionic_lif *lif)
netif_carrier_on(netdev); netif_carrier_on(netdev);
} }
if (netif_running(lif->netdev)) if (lif->netdev->flags & IFF_UP && netif_running(lif->netdev))
ionic_start_queues(lif); ionic_start_queues(lif);
} else { } else {
if (netif_carrier_ok(netdev)) { if (netif_carrier_ok(netdev)) {
...@@ -124,7 +124,7 @@ static void ionic_link_status_check(struct ionic_lif *lif) ...@@ -124,7 +124,7 @@ static void ionic_link_status_check(struct ionic_lif *lif)
netif_carrier_off(netdev); netif_carrier_off(netdev);
} }
if (netif_running(lif->netdev)) if (lif->netdev->flags & IFF_UP && netif_running(lif->netdev))
ionic_stop_queues(lif); ionic_stop_queues(lif);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment