kernel: generic: patch: 802.2+LLC - set transport_header offset
authorAntonio Pastor <antonio.pastor@gmail.com>
Fri, 20 Dec 2024 16:28:45 +0000 (11:28 -0500)
committerRobert Marko <robimarko@gmail.com>
Sat, 28 Dec 2024 10:18:36 +0000 (11:18 +0100)
commit76a546a83a68459b88a14b3382a58740daf5bf00
tree9c50cdeb3af1cb458a401ec918a87a84b27a93b5
parent5b4a081f472cd97fd13739bb48c32fb015368def
kernel: generic: patch: 802.2+LLC - set transport_header offset

Conversion to DSA broke 802.2+LLC+SNAP packet processing. Frames
received by napi_complete_done with GRO and DSA have transport_header
set two bytes short, or pointing 2 bytes before network_header &
skb->data. As snap_rcv expects transport_header to point to SNAP
header (OID:PID) after LLC processing advances offset over LLC header
(llc_rcv & llc_fixup_skb), code doesn't find a match and packet is
dropped.

Image built at this commit operates properly:
  86dadeba48 - generic: add patch for GPON-ONU-34-20BI quirk
Image built at following commit exhibits the issue:
  337e36e0ef - ipq806x: convert each device to DSA implementation

As issue is LLC specific, to avoid impacting non-LLC traffic, and to
follow up on original assumption made on kernel commit fda55eca5a33
("net: introduce skb_transport_header_was_set()") stating "network
stacks usually reset the transport header anyway", llc_fixup_skb to
reset and advance the offset. llc_fixup_skb already assumes the LLC
header is at skb->data, and by definition SNAP header immediately
follows.

Signed-off-by: Antonio Pastor <antonio.pastor@gmail.com>
Link: https://github.com/openwrt/openwrt/pull/17220
Signed-off-by: Robert Marko <robimarko@gmail.com>
(cherry picked from commit da7ab64f1f6d72597a1c8a8bb3b57409227bc635)
target/linux/generic/backport-6.6/902-net-llc-reset-skb-transport_header.patch [new file with mode: 0644]