Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp246985pxb; Wed, 13 Jan 2021 02:35:27 -0800 (PST) X-Google-Smtp-Source: ABdhPJwTR6GJE3q0Krb6/lg74+AHVc8B5wZpgT9CiqB3cgASbsQrb+QALzA0BXRU0qx9w+CQEb2W X-Received: by 2002:a50:c3c5:: with SMTP id i5mr1251040edf.166.1610534127248; Wed, 13 Jan 2021 02:35:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610534127; cv=none; d=google.com; s=arc-20160816; b=nnKA4s0wvigaE9s9NCwKu+sxtVoY+5Ekp3TxmmoQAxLqjevwvSyms8Jq1N736miWly hcriKpo/OR0YSjkCgpbkLvYScBPTkCfAGVmTM5VvIeGVfFKdHiV7TVSCKDYUMgVDWVxN Keb9EVzxwLYJh14yjtMZpkkhZP/oA7L08AT6BGuQp8axUV8iBaFFiuS3200dLhOLsic8 bT1TSBEuZrFXUoWffpQpH8xUS+5gKLDS4WN4WrFCI69WmHKnoVLlsE/ppWZi0/S0UwyC cIZukGslvEPRdfVQBZAbLXryi6tatqu8gDAQqdWG6q2Mtd+jxYU34QaDmKceaZUMo0EP lp/g== 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 :message-id:subject:reply-to:cc:from:to:dkim-signature:date; bh=EpolZpTKC5oUdKcjdBe4f+ZlCuhQ3GPo5fWCiOJXzzo=; b=iog5ihzOSg7C49LQn40RyEqpZvKJdWKOssp28xLUYeshNZInd0O22+Yf1VbockoBtl HqOkcy/lQafZhOHe055NwFgFkXwoJiPB/2eElcizgsAxDFSd/Y0ZlbOls2z1j4tkRtaD 9XPH/+KJgB4w4lfLcxjbEfTHZ3J6U5J8xQiHHyQZmeutCvV/KwA30Sp/U/JONdM+tB+K r0IYYiIlpJLohSB4eHKUXzZPgWyiurspb3h8dXpHZsayyDHOzZTYg+wJKm9w13zM/qih 4sOi0RuqZA7KD5VNMhiUT1mVnyDJzOYo3U33Nh56GV0LDqWvSZYUYbCgEKMZq5c4VQW+ dNjQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@pm.me header.s=protonmail header.b=ESJ+CGIC; 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 30si813810edv.385.2021.01.13.02.35.03; Wed, 13 Jan 2021 02:35:27 -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=ESJ+CGIC; 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 S1726734AbhAMKdk (ORCPT + 99 others); Wed, 13 Jan 2021 05:33:40 -0500 Received: from mail-40136.protonmail.ch ([185.70.40.136]:40628 "EHLO mail-40136.protonmail.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725927AbhAMKdk (ORCPT ); Wed, 13 Jan 2021 05:33:40 -0500 Date: Wed, 13 Jan 2021 10:32:50 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=pm.me; s=protonmail; t=1610533977; bh=EpolZpTKC5oUdKcjdBe4f+ZlCuhQ3GPo5fWCiOJXzzo=; h=Date:To:From:Cc:Reply-To:Subject:From; b=ESJ+CGICyHNXyAKgaElVkQrx/j8flou2v19wfQB2Btb8PSNWKcf1FRUDK2eH16rVH xim7jt88xJjRNPu9dnf+0qZo4GxEzEycF80B5xl80NSFHpCw7GjmMK8nC1FEiXl55r NROmrXT8VrhUKsW0wclTeqyV9uh5NIHGSEl2AvIy37iS2EcdHCeu4bBlmeufeKdUe8 uyaw/KsR035fJf7ZK737shkcxpdERu5Imsu4PqQm1/8j+BXzpOVd/ftGTs0A4a50da QheM7mPIeR0JMmFmglx8usXx6uw8T4f18GGIrPJk8ePRy69biKSvFgs0kl4mJ/kkJH Xf1gbV06EbG6Q== To: "David S. Miller" , Jakub Kicinski From: Alexander Lobakin Cc: Alexander Duyck , Eric Dumazet , Edward Cree , Willem de Bruijn , Steffen Klassert , Dongseok Yi , Alexey Kuznetsov , Hideaki YOSHIFUJI , Alexander Lobakin , netdev@vger.kernel.org, linux-kernel@vger.kernel.org Reply-To: Alexander Lobakin Subject: [PATCH v2 net-next] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Message-ID: <20210113103232.4761-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 there is no socket -> we are on forwarding path. Plain UDP GRO forwarding even shows better performance than fraglisted UDP GRO in some cases due to not wasting one skbuff_head per every segment. Since v1 [0]: - drop redundant 'if (sk)' check (Alexander Duyck); - add a ref in the commit message to one more commit that was an important step for UDP GRO forwarding. [0] https://lore.kernel.org/netdev/20210112211536.261172-1-alobakin@pm.me Signed-off-by: Alexander Lobakin --- net/ipv4/udp_offload.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/net/ipv4/udp_offload.c b/net/ipv4/udp_offload.c index ff39e94781bf..6f5237a0d181 100644 --- a/net/ipv4/udp_offload.c +++ b/net/ipv4/udp_offload.c @@ -460,12 +460,12 @@ struct sk_buff *udp_gro_receive(struct list_head *hea= d, 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 || 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 -=09if (!sk || NAPI_GRO_CB(skb)->encap_mark || +=09if (NAPI_GRO_CB(skb)->encap_mark || =09 (skb->ip_summed !=3D CHECKSUM_PARTIAL && =09 NAPI_GRO_CB(skb)->csum_cnt =3D=3D 0 && =09 !NAPI_GRO_CB(skb)->csum_valid) || --=20 2.30.0