[RFC PATCH v1 0/2] virtio_net: Better low memory handling.
From: Mike Waychison
Date: Wed Jan 04 2012 - 17:52:29 EST
The following series applies to net-next.
The following series changes the low memory paths in virtio_net to allow
the driver to contribute to reclaim when memory is tight.
It attempts to rectify some performance problems we've seen where the
network performance drops significantly when memory is low. The working
theory is that while the driver contributes to memory pressure when
throughput is high, it does not contribute to reclaim when memory is
low.
The observed situation on an unmodified kernel is that a system with low
memory will in turn quickly stop being being able to refill the rx queue
with buffers, in turn causing packets to be dropped by the host OS while
the driver waits for somebody else to free up memory. The way the
process-context refill loop works, the memory subsystem is effectively
polled every half second when things look bleak, leading to significant
packet loss and congestion window collapse.
The first patch rectifies the "not contributing to reclaim" by letting
the driver try to allocate as GFP_KERNEL when run from process context.
The second patch is a bit more complicated. It essentially removes the
serialization that is currently in place built around enabling and
disabling napi polling, and replaces it by protecting the underlying
virtqueue accesses with a bottom-half spinlock. As well, in order to
continue allocating as GFP_KERNEL in the slow path allocation of buffers
and adding them to the virtqueue for device use is split apart. To try
and amortize the locking, batching is used.
This patchset seems to help the test setups that I'm playing with.
Example tests include using several bit-torrent clients within a VM and
watching the network throughputs on the host. Other similar workloads
(high network traffic, reasonably high disk IO causing memory pressure)
also appear to have throughput problems alleviated by these changes.
As a warning, I've only really tested this using the "small buffers"
paths. The devices I'm using do not yet support "mergeable" or "big"
receive buffers.
---
Mike Waychison (2):
virtio_net: Pass gfp flags when allocating rx buffers.
virtio_net: Don't disable napi on low memory.
drivers/net/virtio_net.c | 213 +++++++++++++++++++++++++++++++++++-----------
1 files changed, 162 insertions(+), 51 deletions(-)
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/