linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v4 net-next 0/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets
@ 2021-01-22 18:19 Alexander Lobakin
  2021-01-22 18:19 ` [PATCH v4 net-next 1/2] net: introduce a netdev feature for UDP GRO forwarding Alexander Lobakin
                   ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: Alexander Lobakin @ 2021-01-22 18:19 UTC (permalink / raw)
  To: David S. Miller, Jakub Kicinski
  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, netdev

This series allows to form UDP GRO packets in cases without sockets
(for forwarding). To not change the current datapath, this is
performed only when the new corresponding netdev feature is enabled
via Ethtool (and fraglisted GRO is disabled).
Prior to this point, only fraglisted UDP GRO was available. Plain UDP
GRO shows better forwarding performance when a target NIC is capable
of GSO UDP offload.

Since v3 [2]:
 - rename introduced netdev feature to reflect that it targets
   forwarding and don't touch fraglisted GRO at all (Willem de Bruijn).

Since v2 [1]:
 - convert to a series;
 - new: add new netdev_feature to explicitly enable/disable UDP GRO
   when there is no socket, defaults to off (Paolo Abeni).

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
[1] https://lore.kernel.org/netdev/20210113103232.4761-1-alobakin@pm.me
[2] https://lore.kernel.org/netdev/20210118193122.87271-1-alobakin@pm.me

Alexander Lobakin (2):
  net: introduce a netdev feature for UDP GRO forwarding
  udp: allow forwarding of plain (non-fraglisted) UDP GRO packets

 include/linux/netdev_features.h | 4 +++-
 net/ethtool/common.c            | 1 +
 net/ipv4/udp_offload.c          | 3 ++-
 3 files changed, 6 insertions(+), 2 deletions(-)

-- 
2.30.0



^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH v4 net-next 1/2] net: introduce a netdev feature for UDP GRO forwarding
  2021-01-22 18:19 [PATCH v4 net-next 0/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Alexander Lobakin
@ 2021-01-22 18:19 ` Alexander Lobakin
  2021-01-22 18:20 ` [PATCH v4 net-next 2/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Alexander Lobakin
  2021-01-24  5:20 ` [PATCH v4 net-next 0/2] " patchwork-bot+netdevbpf
  2 siblings, 0 replies; 5+ messages in thread
From: Alexander Lobakin @ 2021-01-22 18:19 UTC (permalink / raw)
  To: David S. Miller, Jakub Kicinski
  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, netdev

Introduce a new netdev feature, NETIF_F_GRO_UDP_FWD, to allow user
to turn UDP GRO on and off for forwarding.
Defaults to off to not change current datapath.

Suggested-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: Alexander Lobakin <alobakin@pm.me>
---
 include/linux/netdev_features.h | 4 +++-
 net/ethtool/common.c            | 1 +
 2 files changed, 4 insertions(+), 1 deletion(-)

diff --git a/include/linux/netdev_features.h b/include/linux/netdev_features.h
index 934de56644e7..c06d6aaba9df 100644
--- a/include/linux/netdev_features.h
+++ b/include/linux/netdev_features.h
@@ -84,6 +84,7 @@ enum {
 	NETIF_F_GRO_FRAGLIST_BIT,	/* Fraglist GRO */
 
 	NETIF_F_HW_MACSEC_BIT,		/* Offload MACsec operations */
+	NETIF_F_GRO_UDP_FWD_BIT,	/* Allow UDP GRO for forwarding */
 
 	/*
 	 * Add your fresh new feature above and remember to update
@@ -157,6 +158,7 @@ enum {
 #define NETIF_F_GRO_FRAGLIST	__NETIF_F(GRO_FRAGLIST)
 #define NETIF_F_GSO_FRAGLIST	__NETIF_F(GSO_FRAGLIST)
 #define NETIF_F_HW_MACSEC	__NETIF_F(HW_MACSEC)
+#define NETIF_F_GRO_UDP_FWD	__NETIF_F(GRO_UDP_FWD)
 
 /* Finds the next feature with the highest number of the range of start till 0.
  */
@@ -234,7 +236,7 @@ static inline int find_next_netdev_feature(u64 feature, unsigned long start)
 #define NETIF_F_SOFT_FEATURES	(NETIF_F_GSO | NETIF_F_GRO)
 
 /* Changeable features with no special hardware requirements that defaults to off. */
-#define NETIF_F_SOFT_FEATURES_OFF	NETIF_F_GRO_FRAGLIST
+#define NETIF_F_SOFT_FEATURES_OFF	(NETIF_F_GRO_FRAGLIST | NETIF_F_GRO_UDP_FWD)
 
 #define NETIF_F_VLAN_FEATURES	(NETIF_F_HW_VLAN_CTAG_FILTER | \
 				 NETIF_F_HW_VLAN_CTAG_RX | \
diff --git a/net/ethtool/common.c b/net/ethtool/common.c
index 24036e3055a1..181220101a6e 100644
--- a/net/ethtool/common.c
+++ b/net/ethtool/common.c
@@ -68,6 +68,7 @@ const char netdev_features_strings[NETDEV_FEATURE_COUNT][ETH_GSTRING_LEN] = {
 	[NETIF_F_HW_TLS_RX_BIT] =	 "tls-hw-rx-offload",
 	[NETIF_F_GRO_FRAGLIST_BIT] =	 "rx-gro-list",
 	[NETIF_F_HW_MACSEC_BIT] =	 "macsec-hw-offload",
+	[NETIF_F_GRO_UDP_FWD_BIT] =	 "rx-udp-gro-forwarding",
 };
 
 const char
-- 
2.30.0



^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH v4 net-next 2/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets
  2021-01-22 18:19 [PATCH v4 net-next 0/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Alexander Lobakin
  2021-01-22 18:19 ` [PATCH v4 net-next 1/2] net: introduce a netdev feature for UDP GRO forwarding Alexander Lobakin
@ 2021-01-22 18:20 ` Alexander Lobakin
  2021-01-22 18:31   ` Willem de Bruijn
  2021-01-24  5:20 ` [PATCH v4 net-next 0/2] " patchwork-bot+netdevbpf
  2 siblings, 1 reply; 5+ messages in thread
From: Alexander Lobakin @ 2021-01-22 18:20 UTC (permalink / raw)
  To: David S. Miller, Jakub Kicinski
  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, netdev

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 <alobakin@pm.me>
---
 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,
 	if (skb->dev->features & NETIF_F_GRO_FRAGLIST)
 		NAPI_GRO_CB(skb)->is_flist = sk ? !udp_sk(sk)->gro_enabled: 1;
 
-	if ((sk && udp_sk(sk)->gro_enabled) || NAPI_GRO_CB(skb)->is_flist) {
+	if ((!sk && (skb->dev->features & NETIF_F_GRO_UDP_FWD)) ||
+	    (sk && udp_sk(sk)->gro_enabled) || NAPI_GRO_CB(skb)->is_flist) {
 		pp = call_gro_receive(udp_gro_receive_segment, head, skb);
 		return pp;
 	}
-- 
2.30.0



^ permalink raw reply related	[flat|nested] 5+ messages in thread

* Re: [PATCH v4 net-next 2/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets
  2021-01-22 18:20 ` [PATCH v4 net-next 2/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Alexander Lobakin
@ 2021-01-22 18:31   ` Willem de Bruijn
  0 siblings, 0 replies; 5+ messages in thread
From: Willem de Bruijn @ 2021-01-22 18:31 UTC (permalink / raw)
  To: Alexander Lobakin
  Cc: David S. Miller, Jakub Kicinski, Hideaki YOSHIFUJI,
	Steffen Klassert, Alexander Duyck, Paolo Abeni, Igor Russkikh,
	Mauro Carvalho Chehab, Miaohe Lin, Antoine Tenart,
	Michal Kubecek, Andrew Lunn, Meir Lichtinger, Aya Levin,
	Florian Fainelli, linux-kernel, Network Development

On Fri, Jan 22, 2021 at 1:20 PM Alexander Lobakin <alobakin@pm.me> wrote:
>
> 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 <alobakin@pm.me>

Acked-by: Willem de Bruijn <willemb@google.com>

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH v4 net-next 0/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets
  2021-01-22 18:19 [PATCH v4 net-next 0/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Alexander Lobakin
  2021-01-22 18:19 ` [PATCH v4 net-next 1/2] net: introduce a netdev feature for UDP GRO forwarding Alexander Lobakin
  2021-01-22 18:20 ` [PATCH v4 net-next 2/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Alexander Lobakin
@ 2021-01-24  5:20 ` patchwork-bot+netdevbpf
  2 siblings, 0 replies; 5+ messages in thread
From: patchwork-bot+netdevbpf @ 2021-01-24  5:20 UTC (permalink / raw)
  To: Alexander Lobakin
  Cc: davem, kuba, yoshfuji, willemb, steffen.klassert,
	alexander.duyck, pabeni, irusskikh, mchehab+huawei, linmiaohe,
	atenart, mkubecek, andrew, meirl, ayal, f.fainelli, linux-kernel,
	netdev

Hello:

This series was applied to netdev/net-next.git (refs/heads/master):

On Fri, 22 Jan 2021 18:19:36 +0000 you wrote:
> This series allows to form UDP GRO packets in cases without sockets
> (for forwarding). To not change the current datapath, this is
> performed only when the new corresponding netdev feature is enabled
> via Ethtool (and fraglisted GRO is disabled).
> Prior to this point, only fraglisted UDP GRO was available. Plain UDP
> GRO shows better forwarding performance when a target NIC is capable
> of GSO UDP offload.
> 
> [...]

Here is the summary with links:
  - [v4,net-next,1/2] net: introduce a netdev feature for UDP GRO forwarding
    https://git.kernel.org/netdev/net-next/c/6f1c0ea133a6
  - [v4,net-next,2/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets
    https://git.kernel.org/netdev/net-next/c/36707061d6ba

You are awesome, thank you!
--
Deet-doot-dot, I am a bot.
https://korg.docs.kernel.org/patchwork/pwbot.html



^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2021-01-24  5:21 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-01-22 18:19 [PATCH v4 net-next 0/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Alexander Lobakin
2021-01-22 18:19 ` [PATCH v4 net-next 1/2] net: introduce a netdev feature for UDP GRO forwarding Alexander Lobakin
2021-01-22 18:20 ` [PATCH v4 net-next 2/2] udp: allow forwarding of plain (non-fraglisted) UDP GRO packets Alexander Lobakin
2021-01-22 18:31   ` Willem de Bruijn
2021-01-24  5:20 ` [PATCH v4 net-next 0/2] " patchwork-bot+netdevbpf

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).