[PATCH net-next] net: account for encap headers in qdisc pkt len

Fengyuan Gong posted 1 patch 3 months, 1 week ago
net/core/dev.c       | 5 ++++-
net/sched/sch_cake.c | 5 ++++-
2 files changed, 8 insertions(+), 2 deletions(-)
[PATCH net-next] net: account for encap headers in qdisc pkt len
Posted by Fengyuan Gong 3 months, 1 week ago
Refine qdisc_pkt_len_init to include headers up through
the inner transport header when computing header size
for encapsulations. Also refine net/sched/sch_cake.c
borrowed from qdisc_pkt_len_init().

Signed-off-by: Fengyuan Gong <gfengyuan@google.com>
---
 net/core/dev.c       | 5 ++++-
 net/sched/sch_cake.c | 5 ++++-
 2 files changed, 8 insertions(+), 2 deletions(-)

diff --git a/net/core/dev.c b/net/core/dev.c
index 11da1e272ec20..dfec541f68e3a 100644
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -3944,7 +3944,10 @@ static void qdisc_pkt_len_init(struct sk_buff *skb)
 		unsigned int hdr_len;
 
 		/* mac layer + network layer */
-		hdr_len = skb_transport_offset(skb);
+		if (!skb->encapsulation)
+			hdr_len = skb_transport_offset(skb);
+		else
+			hdr_len = skb_inner_transport_offset(skb);
 
 		/* + transport layer */
 		if (likely(shinfo->gso_type & (SKB_GSO_TCPV4 | SKB_GSO_TCPV6))) {
diff --git a/net/sched/sch_cake.c b/net/sched/sch_cake.c
index 48dd8c88903fe..dbcfb948c8670 100644
--- a/net/sched/sch_cake.c
+++ b/net/sched/sch_cake.c
@@ -1407,7 +1407,10 @@ static u32 cake_overhead(struct cake_sched_data *q, const struct sk_buff *skb)
 		return cake_calc_overhead(q, len, off);
 
 	/* borrowed from qdisc_pkt_len_init() */
-	hdr_len = skb_transport_offset(skb);
+	if (!skb->encapsulation)
+		hdr_len = skb_transport_offset(skb);
+	else
+		hdr_len = skb_inner_transport_offset(skb);
 
 	/* + transport layer */
 	if (likely(shinfo->gso_type & (SKB_GSO_TCPV4 |
-- 
2.50.0.727.gbf7dc18ff4-goog
Re: [PATCH net-next] net: account for encap headers in qdisc pkt len
Posted by Cong Wang 3 months ago
On Wed, Jul 02, 2025 at 04:07:41PM +0000, Fengyuan Gong wrote:
> diff --git a/net/core/dev.c b/net/core/dev.c
> index 11da1e272ec20..dfec541f68e3a 100644
> --- a/net/core/dev.c
> +++ b/net/core/dev.c
> @@ -3944,7 +3944,10 @@ static void qdisc_pkt_len_init(struct sk_buff *skb)
>  		unsigned int hdr_len;
>  
>  		/* mac layer + network layer */
> -		hdr_len = skb_transport_offset(skb);
> +		if (!skb->encapsulation)
> +			hdr_len = skb_transport_offset(skb);
> +		else
> +			hdr_len = skb_inner_transport_offset(skb);

This pattern seems repeated in a few places, other than the two you are
patching, I saw another one:

2465 static netdev_features_t hns3_features_check(struct sk_buff *skb,
2466                                              struct net_device *dev,
2467                                              netdev_features_t features)
2468 {
2469 #define HNS3_MAX_HDR_LEN        480U
2470 #define HNS3_MAX_L4_HDR_LEN     60U
2471 
2472         size_t len;
2473 
2474         if (skb->ip_summed != CHECKSUM_PARTIAL)
2475                 return features;
2476 
2477         if (skb->encapsulation)
2478                 len = skb_inner_transport_offset(skb);
2479         else
2480                 len = skb_transport_offset(skb);


Maybe worth a helper now?

Thanks!
Re: [PATCH net-next] net: account for encap headers in qdisc pkt len
Posted by Willem de Bruijn 3 months ago
Cong Wang wrote:
> On Wed, Jul 02, 2025 at 04:07:41PM +0000, Fengyuan Gong wrote:
> > diff --git a/net/core/dev.c b/net/core/dev.c
> > index 11da1e272ec20..dfec541f68e3a 100644
> > --- a/net/core/dev.c
> > +++ b/net/core/dev.c
> > @@ -3944,7 +3944,10 @@ static void qdisc_pkt_len_init(struct sk_buff *skb)
> >  		unsigned int hdr_len;
> >  
> >  		/* mac layer + network layer */
> > -		hdr_len = skb_transport_offset(skb);
> > +		if (!skb->encapsulation)
> > +			hdr_len = skb_transport_offset(skb);
> > +		else
> > +			hdr_len = skb_inner_transport_offset(skb);
> 
> This pattern seems repeated in a few places, other than the two you are
> patching, I saw another one:
> 
> 2465 static netdev_features_t hns3_features_check(struct sk_buff *skb,
> 2466                                              struct net_device *dev,
> 2467                                              netdev_features_t features)
> 2468 {
> 2469 #define HNS3_MAX_HDR_LEN        480U
> 2470 #define HNS3_MAX_L4_HDR_LEN     60U
> 2471 
> 2472         size_t len;
> 2473 
> 2474         if (skb->ip_summed != CHECKSUM_PARTIAL)
> 2475                 return features;
> 2476 
> 2477         if (skb->encapsulation)
> 2478                 len = skb_inner_transport_offset(skb);
> 2479         else
> 2480                 len = skb_transport_offset(skb);

From a quick grep, this is the only other case, right?
 
> Maybe worth a helper now?

If only one more, I wouldn't respin for that.
Re: [PATCH net-next] net: account for encap headers in qdisc pkt len
Posted by Toke Høiland-Jørgensen 3 months ago
Fengyuan Gong <gfengyuan@google.com> writes:

> Refine qdisc_pkt_len_init to include headers up through
> the inner transport header when computing header size
> for encapsulations. Also refine net/sched/sch_cake.c
> borrowed from qdisc_pkt_len_init().
>
> Signed-off-by: Fengyuan Gong <gfengyuan@google.com>

Acked-by: Toke Høiland-Jørgensen <toke@redhat.com>
Re: [PATCH net-next] net: account for encap headers in qdisc pkt len
Posted by Willem de Bruijn 3 months, 1 week ago
Fengyuan Gong wrote:
> Refine qdisc_pkt_len_init to include headers up through
> the inner transport header when computing header size
> for encapsulations. Also refine net/sched/sch_cake.c
> borrowed from qdisc_pkt_len_init().
> 
> Signed-off-by: Fengyuan Gong <gfengyuan@google.com>

Reviewed-by: Willem de Bruijn <willemb@google.com>
Re: [PATCH net-next] net: account for encap headers in qdisc pkt len
Posted by Eric Dumazet 3 months, 1 week ago
On Wed, Jul 2, 2025 at 9:53 AM Willem de Bruijn
<willemdebruijn.kernel@gmail.com> wrote:
>
> Fengyuan Gong wrote:
> > Refine qdisc_pkt_len_init to include headers up through
> > the inner transport header when computing header size
> > for encapsulations. Also refine net/sched/sch_cake.c
> > borrowed from qdisc_pkt_len_init().
> >
> > Signed-off-by: Fengyuan Gong <gfengyuan@google.com>
>
> Reviewed-by: Willem de Bruijn <willemb@google.com>

Reviewed-by: Eric Dumazet <edumazet@google.com>