mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-27 04:13:53 -06:00
tap: safe sndbuf default
With current sndbuf default value, a blocked target guest can prevent another guest from transmitting any packets. While current sndbuf value (1M) is reported to help some UDP based workloads, the default should be safe (0). Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
466b58648a
commit
f157ed202e
2 changed files with 10 additions and 5 deletions
|
@ -82,12 +82,17 @@ int tap_open(char *ifname, int ifname_size, int *vnet_hdr, int vnet_hdr_required
|
|||
return fd;
|
||||
}
|
||||
|
||||
/* sndbuf should be set to a value lower than the tx queue
|
||||
* capacity of any destination network interface.
|
||||
/* sndbuf implements a kind of flow control for tap.
|
||||
* Unfortunately when it's enabled, and packets are sent
|
||||
* to other guests on the same host, the receiver
|
||||
* can lock up the transmitter indefinitely.
|
||||
*
|
||||
* To avoid packet loss, sndbuf should be set to a value lower than the tx
|
||||
* queue capacity of any destination network interface.
|
||||
* Ethernet NICs generally have txqueuelen=1000, so 1Mb is
|
||||
* a good default, given a 1500 byte MTU.
|
||||
* a good value, given a 1500 byte MTU.
|
||||
*/
|
||||
#define TAP_DEFAULT_SNDBUF 1024*1024
|
||||
#define TAP_DEFAULT_SNDBUF 0
|
||||
|
||||
int tap_set_sndbuf(int fd, QemuOpts *opts)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue