Commit aa90be3e authored by Christian Lamparter's avatar Christian Lamparter Committed by Greg Kroah-Hartman

net: emac: Fix napi poll list corruption


[ Upstream commit f5595606 ]

This patch is pretty much a carbon copy of
commit 3079c652 ("caif: Fix napi poll list corruption")
with "caif" replaced by "emac".

The commit d75b1ade ("net: less interrupt masking in NAPI")
breaks emac.

It is now required that if the entire budget is consumed when poll
returns, the napi poll_list must remain empty.  However, like some
other drivers emac tries to do a last-ditch check and if there is
more work it will call napi_reschedule and then immediately process
some of this new work.  Should the entire budget be consumed while
processing such new work then we will violate the new caller
contract.

This patch fixes this by not touching any work when we reschedule
in emac.
Signed-off-by: default avatarChristian Lamparter <chunkeey@googlemail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 3483c650
...@@ -402,7 +402,7 @@ static int mal_poll(struct napi_struct *napi, int budget) ...@@ -402,7 +402,7 @@ static int mal_poll(struct napi_struct *napi, int budget)
unsigned long flags; unsigned long flags;
MAL_DBG2(mal, "poll(%d)" NL, budget); MAL_DBG2(mal, "poll(%d)" NL, budget);
again:
/* Process TX skbs */ /* Process TX skbs */
list_for_each(l, &mal->poll_list) { list_for_each(l, &mal->poll_list) {
struct mal_commac *mc = struct mal_commac *mc =
...@@ -451,7 +451,6 @@ static int mal_poll(struct napi_struct *napi, int budget) ...@@ -451,7 +451,6 @@ static int mal_poll(struct napi_struct *napi, int budget)
spin_lock_irqsave(&mal->lock, flags); spin_lock_irqsave(&mal->lock, flags);
mal_disable_eob_irq(mal); mal_disable_eob_irq(mal);
spin_unlock_irqrestore(&mal->lock, flags); spin_unlock_irqrestore(&mal->lock, flags);
goto again;
} }
mc->ops->poll_tx(mc->dev); mc->ops->poll_tx(mc->dev);
} }
......
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