lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Date:   Fri, 13 Apr 2018 09:45:00 +0300
From:   Elad Nachman <eladv6@...il.com>
To:     netdev@...r.kernel.org, davem@...emloft.net
Subject: [PATCH] net: stmmac: fix missing support for 802.1AD tag on reception

stmmac reception handler calls stmmac_rx_vlan() to strip the vlan before 
calling napi_gro_receive().

The function assumes VLAN tagged frames are always tagged with 802.1Q 
protocol,
and assigns ETH_P_8021Q to the skb by hard-coding the parameter on call 
to __vlan_hwaccel_put_tag() .

This causes packets not to be passed to the VLAN slave if it was created 
with 802.1AD protocol
(ip link add link eth0 eth0.100 type vlan proto 802.1ad id 100).

This fix passes the protocol from the VLAN header into 
__vlan_hwaccel_put_tag()
instead of using the hard-coded value of ETH_P_8021Q.

Signed-off-by: Elad Nachman <eladn@...at.com>

---

--- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c	2018-04-11 
17:04:00.586057300 +0300

+++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c	2018-04-11 
17:05:33.601992400 +0300

@@ -3293,17 +3293,19 @@ dma_map_err:



  static void stmmac_rx_vlan(struct net_device *dev, struct sk_buff *skb)

  {

-	struct ethhdr *ehdr;

+	struct vlan_ethhdr *veth;

  	u16 vlanid;

+	__be16 vlan_proto;



  	if ((dev->features & NETIF_F_HW_VLAN_CTAG_RX) ==

  	    NETIF_F_HW_VLAN_CTAG_RX &&

  	    !__vlan_get_tag(skb, &vlanid)) {

  		/* pop the vlan tag */

-		ehdr = (struct ethhdr *)skb->data;

-		memmove(skb->data + VLAN_HLEN, ehdr, ETH_ALEN * 2);

+		veth = (struct vlan_ethhdr *)skb->data;

+		vlan_proto = veth->h_vlan_proto;

+		memmove(skb->data + VLAN_HLEN, veth, ETH_ALEN * 2);

  		skb_pull(skb, VLAN_HLEN);

-		__vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), vlanid);

+		__vlan_hwaccel_put_tag(skb, vlan_proto, vlanid);

  	}

  }

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ