diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2014-12-30 10:45:47 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-12-30 10:45:47 -0800 | 
| commit | 2c90331cf5ed1d648a711b9483e173aaaf2c4a9b (patch) | |
| tree | b8232ac9d2abb7dd7877498b5ab1647e138be46d /drivers/net/vxlan.c | |
| parent | 6ab1e8de9f953c789d5dd231a7d6e96f1ddfa8b1 (diff) | |
| parent | dc97a1a9477f969e34b38ca9d9cd231cb93ebea2 (diff) | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Pull networking fixes from David Miller:
 1) Fix double SKB free in bluetooth 6lowpan layer, from Jukka Rissanen.
 2) Fix receive checksum handling in enic driver, from Govindarajulu
    Varadarajan.
 3) Fix NAPI poll list corruption in virtio_net and caif_virtio, from
    Herbert Xu.  Also, add code to detect drivers that have this mistake
    in the future.
 4) Fix doorbell endianness handling in mlx4 driver, from Amir Vadai.
 5) Don't clobber IP6CB() before xfrm6_policy_check() is called in TCP
    input path,f rom Nicolas Dichtel.
 6) Fix MPLS action validation in openvswitch, from Pravin B Shelar.
 7) Fix double SKB free in vxlan driver, also from Pravin.
 8) When we scrub a packet, which happens when we are switching the
    context of the packet (namespace, etc.), we should reset the
    secmark.  From Thomas Graf.
 9) ->ndo_gso_check() needs to do more than return true/false, it also
    has to allow the driver to clear netdev feature bits in order for
    the caller to be able to proceed properly.  From Jesse Gross.
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net: (62 commits)
  genetlink: A genl_bind() to an out-of-range multicast group should not WARN().
  netlink/genetlink: pass network namespace to bind/unbind
  ne2k-pci: Add pci_disable_device in error handling
  bonding: change error message to debug message in __bond_release_one()
  genetlink: pass multicast bind/unbind to families
  netlink: call unbind when releasing socket
  netlink: update listeners directly when removing socket
  genetlink: pass only network namespace to genl_has_listeners()
  netlink: rename netlink_unbind() to netlink_undo_bind()
  net: Generalize ndo_gso_check to ndo_features_check
  net: incorrect use of init_completion fixup
  neigh: remove next ptr from struct neigh_table
  net: xilinx: Remove unnecessary temac_property in the driver
  net: phy: micrel: use generic config_init for KSZ8021/KSZ8031
  net/core: Handle csum for CHECKSUM_COMPLETE VXLAN forwarding
  openvswitch: fix odd_ptr_err.cocci warnings
  Bluetooth: Fix accepting connections when not using mgmt
  Bluetooth: Fix controller configuration with HCI_QUIRK_INVALID_BDADDR
  brcmfmac: Do not crash if platform data is not populated
  ipw2200: select CFG80211_WEXT
  ...
Diffstat (limited to 'drivers/net/vxlan.c')
| -rw-r--r-- | drivers/net/vxlan.c | 34 | 
1 files changed, 24 insertions, 10 deletions
| diff --git a/drivers/net/vxlan.c b/drivers/net/vxlan.c index 49d9f2291998..7fbd89fbe107 100644 --- a/drivers/net/vxlan.c +++ b/drivers/net/vxlan.c @@ -1579,8 +1579,10 @@ static int vxlan6_xmit_skb(struct vxlan_sock *vs,  	bool udp_sum = !udp_get_no_check6_tx(vs->sock->sk);  	skb = udp_tunnel_handle_offloads(skb, udp_sum); -	if (IS_ERR(skb)) -		return -EINVAL; +	if (IS_ERR(skb)) { +		err = -EINVAL; +		goto err; +	}  	skb_scrub_packet(skb, xnet); @@ -1590,12 +1592,16 @@ static int vxlan6_xmit_skb(struct vxlan_sock *vs,  	/* Need space for new headers (invalidates iph ptr) */  	err = skb_cow_head(skb, min_headroom); -	if (unlikely(err)) -		return err; +	if (unlikely(err)) { +		kfree_skb(skb); +		goto err; +	}  	skb = vlan_hwaccel_push_inside(skb); -	if (WARN_ON(!skb)) -		return -ENOMEM; +	if (WARN_ON(!skb)) { +		err = -ENOMEM; +		goto err; +	}  	vxh = (struct vxlanhdr *) __skb_push(skb, sizeof(*vxh));  	vxh->vx_flags = htonl(VXLAN_FLAGS); @@ -1606,6 +1612,9 @@ static int vxlan6_xmit_skb(struct vxlan_sock *vs,  	udp_tunnel6_xmit_skb(vs->sock, dst, skb, dev, saddr, daddr, prio,  			     ttl, src_port, dst_port);  	return 0; +err: +	dst_release(dst); +	return err;  }  #endif @@ -1621,7 +1630,7 @@ int vxlan_xmit_skb(struct vxlan_sock *vs,  	skb = udp_tunnel_handle_offloads(skb, udp_sum);  	if (IS_ERR(skb)) -		return -EINVAL; +		return PTR_ERR(skb);  	min_headroom = LL_RESERVED_SPACE(rt->dst.dev) + rt->dst.header_len  			+ VXLAN_HLEN + sizeof(struct iphdr) @@ -1629,8 +1638,10 @@ int vxlan_xmit_skb(struct vxlan_sock *vs,  	/* Need space for new headers (invalidates iph ptr) */  	err = skb_cow_head(skb, min_headroom); -	if (unlikely(err)) +	if (unlikely(err)) { +		kfree_skb(skb);  		return err; +	}  	skb = vlan_hwaccel_push_inside(skb);  	if (WARN_ON(!skb)) @@ -1776,9 +1787,12 @@ static void vxlan_xmit_one(struct sk_buff *skb, struct net_device *dev,  				     tos, ttl, df, src_port, dst_port,  				     htonl(vni << 8),  				     !net_eq(vxlan->net, dev_net(vxlan->dev))); - -		if (err < 0) +		if (err < 0) { +			/* skb is already freed. */ +			skb = NULL;  			goto rt_tx_error; +		} +  		iptunnel_xmit_stats(err, &dev->stats, dev->tstats);  #if IS_ENABLED(CONFIG_IPV6)  	} else { | 
