Commit fdcf7765 authored by Ma JieYue's avatar Ma JieYue Committed by David S. Miller

xen-netfront: fix missing rx_refill_timer when allocate memory failed

There was a bug in xennet_alloc_rx_buffers, when allocating page or
sk_buff failed, and at the same time rx_batch queue not empty,
the rx_refill_timer timer won't be scheduled. If finally the remaining
request buffers in rx ring less than what backend driver expected,
the backend driver would think of rx ring as full and start dropping packets.
In such situation, there is no way for the netfront driver to recover
automatically, so that the device can not work properly.

The patch fixes the problem by always scheduling rx_refill_timer timer when
alloc_page or __netdev_alloc_skb fails, no matter whether rx_batch queue is
empty or not. It ensures that the rx ring request buffers will finally meet
the backend needs.
Signed-off-by: default avatarMa JieYue <jieyue.majy@alibaba-inc.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 018c5bba
...@@ -277,12 +277,13 @@ static void xennet_alloc_rx_buffers(struct net_device *dev) ...@@ -277,12 +277,13 @@ static void xennet_alloc_rx_buffers(struct net_device *dev)
if (!page) { if (!page) {
kfree_skb(skb); kfree_skb(skb);
no_skb: no_skb:
/* Any skbuffs queued for refill? Force them out. */
if (i != 0)
goto refill;
/* Could not allocate any skbuffs. Try again later. */ /* Could not allocate any skbuffs. Try again later. */
mod_timer(&np->rx_refill_timer, mod_timer(&np->rx_refill_timer,
jiffies + (HZ/10)); jiffies + (HZ/10));
/* Any skbuffs queued for refill? Force them out. */
if (i != 0)
goto refill;
break; break;
} }
......
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