Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1257781pxb; Fri, 22 Jan 2021 10:45:10 -0800 (PST) X-Google-Smtp-Source: ABdhPJz56Vc82ZIi6J+zdbWS4DgDn0P9FP7uBfrz9pASoKVU22nU1S5ygsN/LUvikA+liifAOsUU X-Received: by 2002:a17:906:33c5:: with SMTP id w5mr55185eja.319.1611341110237; Fri, 22 Jan 2021 10:45:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611341110; cv=none; d=google.com; s=arc-20160816; b=X2iR9/lvRci3PnAsfVSlmPO9y8jTg2YGVwY1G4aGGCrJC3nVdnPO7/RCf56BtBNfpc gloeNCXbiSP7b5y7t0GQqGuevnDFUufgLwMwSRynW3dcFUxXucE+yepZ0NT3zZptgMPp T1o6yooMrcwYSUORC2ybHb91LNSZ5CIm5uyyyJLqiyT3HafeyDUpynMOM9K8dRX6UG4p qFKIkLe2Qh/6P8xATtZbzX+CRxiTKJ9yWZF5i86bcL+h+CexjlkkOnkjh7bfOZLMCL1L jqe7S6ezqM351j/6xUQOfxQSapdhL3THe8UcSYHeXIgz9Wyd3l6uKb5b+JpECqM2iAAc ZVsw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:reply-to:cc:from:to :dkim-signature:date; bh=3Se3t8/e965C8Ew1Ejqh+IdWYEkkWugaOHxVVDEiiPE=; b=dqhKFH9Q5/cUY5bCRdtDm6rJEPdJyk1iJ+XKskZGQFSoGqx/sK/1gY+gq/Nf7FTKQi gmYw0ltpRySRuxlI2jIXkju2RkPmNifzHMvaZrGLnj8hACQQSDH3Rouy3slEcF/EEOFn SQb20ZNXa1W2ETD7F4rJW+nItSX7fNC4PwWkB6bBf/NKsy37Oc+xOCKyVv+jyKsrVryB WPauLUJ1QnmFPjczGk5hU2EmDaCkJ9yLUcKFnFmVlIUFVdzHw4Cr6UIZVmdZf/QDl4Eq 1yeZsTkNddFtjylsz0lQikT/Gd84fCnXIv6b9lhsjoAN74iRi8MKbfI8Nv0QmkteDFJU Ce9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@pm.me header.s=protonmail header.b=lm7E5XbF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=pm.me Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a73si3953218edf.23.2021.01.22.10.44.45; Fri, 22 Jan 2021 10:45:10 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@pm.me header.s=protonmail header.b=lm7E5XbF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=pm.me Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730049AbhAVSn2 (ORCPT + 99 others); Fri, 22 Jan 2021 13:43:28 -0500 Received: from mail-40134.protonmail.ch ([185.70.40.134]:25459 "EHLO mail-40134.protonmail.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729752AbhAVSV0 (ORCPT ); Fri, 22 Jan 2021 13:21:26 -0500 Date: Fri, 22 Jan 2021 18:20:02 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=pm.me; s=protonmail; t=1611339608; bh=3Se3t8/e965C8Ew1Ejqh+IdWYEkkWugaOHxVVDEiiPE=; h=Date:To:From:Cc:Reply-To:Subject:In-Reply-To:References:From; b=lm7E5XbFhVahxNDM4EjEp66omOhsJsLnftvpFpzO+JnkLwyBXrTHVZqRG8ZgFI8UT kfE7BAjn/WXX2yaY8Hoamrmv9Ir3N2re77CAcCND3ltetwXajlJet0gYr1hONOeXXC DHhPIixmweZZ6j+Q10ULPz+29e6Qj5vMfgJhHkBlPSWt+L4C1Y+/L0NgkEOpiPLMTS cgrv3IN7X9dLtvSO+uyvD0DvpjAv+dP3fmKFJgBxBc1t4FLExx2PDiTAhwbwt4EMbc PArgUgGwSJRvw+i7lMmsSs24MjWsE+d9jnKcb8OlkiEB+hNvHwCBBqY8/UZW7cx+s5 1X21JE2IDAukw== To: "David S. Miller" , Jakub Kicinski From: Alexander Lobakin Cc: Hideaki YOSHIFUJI , Willem de Bruijn , Steffen Klassert , Alexander Duyck , Paolo Abeni , Alexander Lobakin , Igor Russkikh , Mauro Carvalho Chehab , Miaohe Lin , Antoine Tenart , Michal Kubecek , Andrew Lunn , Meir Lichtinger , Aya Levin , Florian Fainelli , linux-kernel@vger.kernel.org, netdev@vger.kernel.org Reply-To: Alexander Lobakin Subject: [PATCH v4 net-next 2/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Message-ID: <20210122181909.36340-3-alobakin@pm.me> In-Reply-To: <20210122181909.36340-1-alobakin@pm.me> References: <20210122181909.36340-1-alobakin@pm.me> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-1.2 required=10.0 tests=ALL_TRUSTED,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF shortcircuit=no autolearn=disabled version=3.4.4 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on mailout.protonmail.ch Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit 9fd1ff5d2ac7 ("udp: Support UDP fraglist GRO/GSO.") actually not only added a support for fraglisted UDP GRO, but also tweaked some logics the way that non-fraglisted UDP GRO started to work for forwarding too. Commit 2e4ef10f5850 ("net: add GSO UDP L4 and GSO fraglists to the list of software-backed types") added GSO UDP L4 to the list of software GSO to allow virtual netdevs to forward them as is up to the real drivers. Tests showed that currently forwarding and NATing of plain UDP GRO packets are performed fully correctly, regardless if the target netdevice has a support for hardware/driver GSO UDP L4 or not. Add the last element and allow to form plain UDP GRO packets if we are on forwarding path, and the new NETIF_F_GRO_UDP_FWD is enabled on a receiving netdevice. If both NETIF_F_GRO_FRAGLIST and NETIF_F_GRO_UDP_FWD are set, fraglisted GRO takes precedence. This keeps the current behaviour and is generally more optimal for now, as the number of NICs with hardware USO offload is relatively small. Signed-off-by: Alexander Lobakin --- net/ipv4/udp_offload.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/net/ipv4/udp_offload.c b/net/ipv4/udp_offload.c index 1168d186cc43..41249705d9e9 100644 --- a/net/ipv4/udp_offload.c +++ b/net/ipv4/udp_offload.c @@ -460,7 +460,8 @@ struct sk_buff *udp_gro_receive(struct list_head *head,= struct sk_buff *skb, =09if (skb->dev->features & NETIF_F_GRO_FRAGLIST) =09=09NAPI_GRO_CB(skb)->is_flist =3D sk ? !udp_sk(sk)->gro_enabled: 1; =20 -=09if ((sk && udp_sk(sk)->gro_enabled) || NAPI_GRO_CB(skb)->is_flist) { +=09if ((!sk && (skb->dev->features & NETIF_F_GRO_UDP_FWD)) || +=09 (sk && udp_sk(sk)->gro_enabled) || NAPI_GRO_CB(skb)->is_flist) { =09=09pp =3D call_gro_receive(udp_gro_receive_segment, head, skb); =09=09return pp; =09} --=20 2.30.0