提交 303c6a02 编写于 作者: H Herbert Xu 提交者: David S. Miller

gro: Fix legacy path napi_complete crash

On the legacy netif_rx path, I incorrectly tried to optimise
the napi_complete call by using __napi_complete before we reenable
IRQs.  This simply doesn't work since we need to flush the held
GRO packets first.

This patch fixes it by doing the obvious thing of reenabling
IRQs first and then calling napi_complete.
Reported-by: NFrank Blaschka <blaschka@linux.vnet.ibm.com>
Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 ea8dbdd1
...@@ -2588,9 +2588,9 @@ static int process_backlog(struct napi_struct *napi, int quota) ...@@ -2588,9 +2588,9 @@ static int process_backlog(struct napi_struct *napi, int quota)
local_irq_disable(); local_irq_disable();
skb = __skb_dequeue(&queue->input_pkt_queue); skb = __skb_dequeue(&queue->input_pkt_queue);
if (!skb) { if (!skb) {
__napi_complete(napi);
local_irq_enable(); local_irq_enable();
break; napi_complete(napi);
goto out;
} }
local_irq_enable(); local_irq_enable();
...@@ -2599,6 +2599,7 @@ static int process_backlog(struct napi_struct *napi, int quota) ...@@ -2599,6 +2599,7 @@ static int process_backlog(struct napi_struct *napi, int quota)
napi_gro_flush(napi); napi_gro_flush(napi);
out:
return work; return work;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册