1
0
Fork 0

net: systemport: fix tx work done in TX napi poll

With commit d75b1ade56 ("net: less interrupt masking in NAPI") napi
repoll is done only when work_done == budget. bcm_sysport_tx_poll()
always returns 0 whether or not we completed the poll quantum.

Fix this by returning either 0 when we did complete the TX ring reclaim,
or budget to trigger a repoll.

Fixes: d75b1ade56 ("net: less interrupt masking in NAPI")
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
hifive-unleashed-5.1
Florian Fainelli 2014-11-12 15:40:43 -08:00 committed by David S. Miller
parent f41281d02f
commit 9dfa9a27b6
1 changed files with 3 additions and 1 deletions

View File

@ -731,9 +731,11 @@ static int bcm_sysport_tx_poll(struct napi_struct *napi, int budget)
napi_complete(napi);
/* re-enable TX interrupt */
intrl2_1_mask_clear(ring->priv, BIT(ring->index));
return 0;
}
return 0;
return budget;
}
static void bcm_sysport_tx_reclaim_all(struct bcm_sysport_priv *priv)