Commit 47cf8899 authored by Pavel Begunkov's avatar Pavel Begunkov Committed by Paolo Abeni

net: unify alloclen calculation for paged requests

Consolidate alloclen and pagedlen calculation for zerocopy and normal
paged requests. The current non-zerocopy paged version can a bit
overallocate and unnecessary copy a small chunk of data into the linear
part.

Cc: Willem de Bruijn <willemb@google.com>
Link: https://lore.kernel.org/netdev/CA+FuTSf0+cJ9_N_xrHmCGX_KoVCWcE0YQBdtgEkzGvcLMSv7Qw@mail.gmail.com/Signed-off-by: default avatarPavel Begunkov <asml.silence@gmail.com>
Link: https://lore.kernel.org/r/b0e4edb7b91f171c7119891d3c61040b8c56596e.1661428921.git.asml.silence@gmail.comSigned-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
parent d287532e
...@@ -1109,10 +1109,7 @@ static int __ip_append_data(struct sock *sk, ...@@ -1109,10 +1109,7 @@ static int __ip_append_data(struct sock *sk,
(fraglen + alloc_extra < SKB_MAX_ALLOC || (fraglen + alloc_extra < SKB_MAX_ALLOC ||
!(rt->dst.dev->features & NETIF_F_SG))) !(rt->dst.dev->features & NETIF_F_SG)))
alloclen = fraglen; alloclen = fraglen;
else if (!zc) { else {
alloclen = min_t(int, fraglen, MAX_HEADER);
pagedlen = fraglen - alloclen;
} else {
alloclen = fragheaderlen + transhdrlen; alloclen = fragheaderlen + transhdrlen;
pagedlen = datalen - transhdrlen; pagedlen = datalen - transhdrlen;
} }
......
...@@ -1648,10 +1648,7 @@ static int __ip6_append_data(struct sock *sk, ...@@ -1648,10 +1648,7 @@ static int __ip6_append_data(struct sock *sk,
(fraglen + alloc_extra < SKB_MAX_ALLOC || (fraglen + alloc_extra < SKB_MAX_ALLOC ||
!(rt->dst.dev->features & NETIF_F_SG))) !(rt->dst.dev->features & NETIF_F_SG)))
alloclen = fraglen; alloclen = fraglen;
else if (!zc) { else {
alloclen = min_t(int, fraglen, MAX_HEADER);
pagedlen = fraglen - alloclen;
} else {
alloclen = fragheaderlen + transhdrlen; alloclen = fragheaderlen + transhdrlen;
pagedlen = datalen - transhdrlen; pagedlen = datalen - transhdrlen;
} }
......
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