]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
net: fec: fec_enet_rx_queue(): replace manual VLAN header calculation with skb_vlan_e...
authorMarc Kleine-Budde <mkl@pengutronix.de>
Wed, 18 Jun 2025 12:00:08 +0000 (14:00 +0200)
committerJakub Kicinski <kuba@kernel.org>
Thu, 19 Jun 2025 22:27:53 +0000 (15:27 -0700)
For better readability and maintainability, use the provided helper function
skb_vlan_eth_hdr() to replace manual the VLAN header calculation, and change
the type of vlan_header to struct vlan_ethhdr to take into account that the
Ethernet header plus VLAN header is returned.

Reviewed-by: Frank Li <Frank.Li@nxp.com>
Reviewed-by: Wei Fang <wei.fang@nxp.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
Link: https://patch.msgid.link/20250618-fec-cleanups-v4-8-c16f9a1af124@pengutronix.de
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/freescale/fec_main.c

index 9e4164fc0cd1dfd5529eeb21b1594da12458166e..45dd96f4786e98d8ae24f5be816548d55f91aa12 100644 (file)
@@ -1859,8 +1859,7 @@ fec_enet_rx_queue(struct net_device *ndev, u16 queue_id, int budget)
                    fep->bufdesc_ex &&
                    (ebdp->cbd_esc & cpu_to_fec32(BD_ENET_RX_VLAN))) {
                        /* Push and remove the vlan tag */
-                       struct vlan_hdr *vlan_header =
-                                       (struct vlan_hdr *) (data + ETH_HLEN);
+                       struct vlan_ethhdr *vlan_header = skb_vlan_eth_hdr(skb);
                        vlan_tag = ntohs(vlan_header->h_vlan_TCI);
 
                        vlan_packet_rcvd = true;