diff options
| author | Zoltan Kiss <zoltan.kiss@citrix.com> | 2014-08-04 16:20:58 +0100 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2014-08-05 16:04:46 -0700 | 
| commit | f34a4cf9c9b4fd35ba7f9a596cedb011879a1a4d (patch) | |
| tree | 00be3a0233299ae75e9ab75ca4940cdea15fb6d9 /lib/memory-notifier-error-inject.c | |
| parent | 3d1af1df9762e56e563e8fd088a1b4ce2bcfaf8b (diff) | |
xen-netback: Turn off the carrier if the guest is not able to receive
Currently when the guest is not able to receive more packets, qdisc layer starts
a timer, and when it goes off, qdisc is started again to deliver a packet again.
This is a very slow way to drain the queues, consumes unnecessary resources and
slows down other guests shutdown.
This patch change the behaviour by turning the carrier off when that timer
fires, so all the packets are freed up which were stucked waiting for that vif.
Instead of the rx_queue_purge bool it uses the VIF_STATUS_RX_PURGE_EVENT bit to
signal the thread that either the timeout happened or an RX interrupt arrived,
so the thread can check what it should do. It also disables NAPI, so the guest
can't transmit, but leaves the interrupts on, so it can resurrect.
Only the queues which brought down the interface can enable it again, the bit
QUEUE_STATUS_RX_STALLED makes sure of that.
Signed-off-by: Zoltan Kiss <zoltan.kiss@citrix.com>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
Cc: netdev@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Cc: xen-devel@lists.xenproject.org
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'lib/memory-notifier-error-inject.c')
0 files changed, 0 insertions, 0 deletions
