diff options
author | David Vrabel <david.vrabel@citrix.com> | 2015-09-08 14:25:14 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-09-09 12:34:35 -0700 |
commit | 1d5d48523900a4b0f25d6b52f1a93c84bd671186 (patch) | |
tree | c95e0fefd5685977313ff4c0794d22906a163253 /net | |
parent | 9b57ab8b58571ee57030210b74e2aabd1a18cff2 (diff) | |
download | talos-op-linux-1d5d48523900a4b0f25d6b52f1a93c84bd671186.tar.gz talos-op-linux-1d5d48523900a4b0f25d6b52f1a93c84bd671186.zip |
xen-netback: require fewer guest Rx slots when not using GSO
Commit f48da8b14d04ca87ffcffe68829afd45f926ec6a (xen-netback: fix
unlimited guest Rx internal queue and carrier flapping) introduced a
regression.
The PV frontend in IPXE only places 4 requests on the guest Rx ring.
Since netback required at least (MAX_SKB_FRAGS + 1) slots, IPXE could
not receive any packets.
a) If GSO is not enabled on the VIF, fewer guest Rx slots are required
for the largest possible packet. Calculate the required slots
based on the maximum GSO size or the MTU.
This calculation of the number of required slots relies on
1650d5455bd2 (xen-netback: always fully coalesce guest Rx packets)
which present in 4.0-rc1 and later.
b) Reduce the Rx stall detection to checking for at least one
available Rx request. This is fine since we're predominately
concerned with detecting interfaces which are down and thus have
zero available Rx requests.
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
Reviewed-by: Wei Liu <wei.liu2@citrix.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
0 files changed, 0 insertions, 0 deletions