Commit 26cde9f7 authored by Herbert Xu's avatar Herbert Xu Committed by David S. Miller

udp: Fix bogus UFO packet generation

It has been reported that the new UFO software fallback path
fails under certain conditions with NFS.  I tracked the problem
down to the generation of UFO packets that are smaller than the
MTU.  The software fallback path simply discards these packets.

This patch fixes the problem by not generating such packets on
the UFO path.
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
Reviewed-by: default avatarMichael S. Tsirkin <mst@redhat.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 13fea6d4
...@@ -873,8 +873,10 @@ int ip_append_data(struct sock *sk, ...@@ -873,8 +873,10 @@ int ip_append_data(struct sock *sk,
!exthdrlen) !exthdrlen)
csummode = CHECKSUM_PARTIAL; csummode = CHECKSUM_PARTIAL;
skb = skb_peek_tail(&sk->sk_write_queue);
inet->cork.length += length; inet->cork.length += length;
if (((length> mtu) || !skb_queue_empty(&sk->sk_write_queue)) && if (((length > mtu) || (skb && skb_is_gso(skb))) &&
(sk->sk_protocol == IPPROTO_UDP) && (sk->sk_protocol == IPPROTO_UDP) &&
(rt->u.dst.dev->features & NETIF_F_UFO)) { (rt->u.dst.dev->features & NETIF_F_UFO)) {
err = ip_ufo_append_data(sk, getfrag, from, length, hh_len, err = ip_ufo_append_data(sk, getfrag, from, length, hh_len,
...@@ -892,7 +894,7 @@ int ip_append_data(struct sock *sk, ...@@ -892,7 +894,7 @@ int ip_append_data(struct sock *sk,
* adding appropriate IP header. * adding appropriate IP header.
*/ */
if ((skb = skb_peek_tail(&sk->sk_write_queue)) == NULL) if (!skb)
goto alloc_new_skb; goto alloc_new_skb;
while (length > 0) { while (length > 0) {
...@@ -1121,7 +1123,8 @@ ssize_t ip_append_page(struct sock *sk, struct page *page, ...@@ -1121,7 +1123,8 @@ ssize_t ip_append_page(struct sock *sk, struct page *page,
return -EINVAL; return -EINVAL;
inet->cork.length += size; inet->cork.length += size;
if ((sk->sk_protocol == IPPROTO_UDP) && if ((size + skb->len > mtu) &&
(sk->sk_protocol == IPPROTO_UDP) &&
(rt->u.dst.dev->features & NETIF_F_UFO)) { (rt->u.dst.dev->features & NETIF_F_UFO)) {
skb_shinfo(skb)->gso_size = mtu - fragheaderlen; skb_shinfo(skb)->gso_size = mtu - fragheaderlen;
skb_shinfo(skb)->gso_type = SKB_GSO_UDP; skb_shinfo(skb)->gso_type = SKB_GSO_UDP;
......
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