Message ID | 20211220145027.2784293-1-willemdebruijn.kernel@gmail.com (mailing list archive) |
---|---|
State | Accepted |
Commit | 1ed1d592113959f00cc552c3b9f47ca2d157768f |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | [net] net: skip virtio_net_hdr_set_proto if protocol already set | expand |
Hello: This patch was applied to netdev/net.git (master) by Jakub Kicinski <kuba@kernel.org>: On Mon, 20 Dec 2021 09:50:27 -0500 you wrote: > From: Willem de Bruijn <willemb@google.com> > > virtio_net_hdr_set_proto infers skb->protocol from the virtio_net_hdr > gso_type, to avoid packets getting dropped for lack of a proto type. > > Its protocol choice is a guess, especially in the case of UFO, where > the single VIRTIO_NET_HDR_GSO_UDP label covers both UFOv4 and UFOv6. > > [...] Here is the summary with links: - [net] net: skip virtio_net_hdr_set_proto if protocol already set https://git.kernel.org/netdev/net/c/1ed1d5921139 You are awesome, thank you!
diff --git a/include/linux/virtio_net.h b/include/linux/virtio_net.h index 22dd48c82560..a960de68ac69 100644 --- a/include/linux/virtio_net.h +++ b/include/linux/virtio_net.h @@ -25,6 +25,9 @@ static inline bool virtio_net_hdr_match_proto(__be16 protocol, __u8 gso_type) static inline int virtio_net_hdr_set_proto(struct sk_buff *skb, const struct virtio_net_hdr *hdr) { + if (skb->protocol) + return 0; + switch (hdr->gso_type & ~VIRTIO_NET_HDR_GSO_ECN) { case VIRTIO_NET_HDR_GSO_TCPV4: case VIRTIO_NET_HDR_GSO_UDP: