Message ID | 20210903020026.1381962-1-yoong.siang.song@intel.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | [net,1/1] net: stmmac: Fix overall budget calculation for rxtx_napi | expand |
Hello: This patch was applied to netdev/net.git (refs/heads/master): On Fri, 3 Sep 2021 10:00:26 +0800 you wrote: > tx_done is not used for napi_complete_done(). Thus, NAPI busy polling > mechanism by gro_flush_timeout and napi_defer_hard_irqs will not able > be triggered after a packet is transmitted when there is no receive > packet. > > Fix this by taking the maximum value between tx_done and rx_done as > overall budget completed by the rxtx NAPI poll to ensure XDP Tx ZC > operation is continuously polling for next Tx frame. This gives > benefit of lower packet submission processing latency and jitter > under XDP Tx ZC mode. > > [...] Here is the summary with links: - [net,1/1] net: stmmac: Fix overall budget calculation for rxtx_napi https://git.kernel.org/netdev/net/c/81d0885d68ec You are awesome, thank you! -- Deet-doot-dot, I am a bot. https://korg.docs.kernel.org/patchwork/pwbot.html
diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c index ed0cd3920171..97238359e101 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c @@ -5347,7 +5347,7 @@ static int stmmac_napi_poll_rxtx(struct napi_struct *napi, int budget) struct stmmac_channel *ch = container_of(napi, struct stmmac_channel, rxtx_napi); struct stmmac_priv *priv = ch->priv_data; - int rx_done, tx_done; + int rx_done, tx_done, rxtx_done; u32 chan = ch->index; priv->xstats.napi_poll++; @@ -5357,14 +5357,16 @@ static int stmmac_napi_poll_rxtx(struct napi_struct *napi, int budget) rx_done = stmmac_rx_zc(priv, budget, chan); + rxtx_done = max(tx_done, rx_done); + /* If either TX or RX work is not complete, return budget * and keep pooling */ - if (tx_done >= budget || rx_done >= budget) + if (rxtx_done >= budget) return budget; /* all work done, exit the polling mode */ - if (napi_complete_done(napi, rx_done)) { + if (napi_complete_done(napi, rxtx_done)) { unsigned long flags; spin_lock_irqsave(&ch->lock, flags); @@ -5375,7 +5377,7 @@ static int stmmac_napi_poll_rxtx(struct napi_struct *napi, int budget) spin_unlock_irqrestore(&ch->lock, flags); } - return min(rx_done, budget - 1); + return min(rxtx_done, budget - 1); } /**