net/core/dev.c | 5 ++++- net/sched/sch_cake.c | 5 ++++- 2 files changed, 8 insertions(+), 2 deletions(-)
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
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!
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.
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>
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>
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>
© 2016 - 2025 Red Hat, Inc.