diff options
| author | Greg Kroah-Hartman <gregkh@google.com> | 2020-07-31 18:49:46 +0200 | 
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@google.com> | 2020-07-31 18:49:46 +0200 | 
| commit | 33ad987213fed441051a2f3ae773268d398f5f55 (patch) | |
| tree | 7710a1e2b45bc8530f18b74e37f6bf8c7606c673 /net | |
| parent | 8476df741c780591942ed5f73ed0de39badcb8c7 (diff) | |
| parent | e164d5f7b274f422f9cd4fa6a6638ea07c4969f1 (diff) | |
Merge 4.4.232 into android-4.4-p
Changes in 4.4.232
	pinctrl: amd: fix npins for uart0 in kerncz_groups
	mac80211: allow rx of mesh eapol frames with default rx key
	scsi: scsi_transport_spi: Fix function pointer check
	xtensa: fix __sync_fetch_and_{and,or}_4 declarations
	xtensa: update *pos in cpuinfo_op.next
	drivers/net/wan/lapbether: Fixed the value of hard_header_len
	net: sky2: initialize return of gm_phy_read
	drm/nouveau/i2c/g94-: increase NV_PMGR_DP_AUXCTL_TRANSACTREQ timeout
	SUNRPC reverting d03727b248d0 ("NFSv4 fix CLOSE not waiting for direct IO compeletion")
	perf/core: Fix locking for children siblings group read
	uprobes: Change handle_swbp() to send SIGTRAP with si_code=SI_KERNEL, to fix GDB regression
	ALSA: info: Drop WARN_ON() from buffer NULL sanity check
	ASoC: rt5670: Correct RT5670_LDO_SEL_MASK
	btrfs: fix double free on ulist after backref resolution failure
	x86/fpu: Disable bottom halves while loading FPU registers
	btrfs: fix mount failure caused by race with umount
	hippi: Fix a size used in a 'pci_free_consistent()' in an error handling path
	ax88172a: fix ax88172a_unbind() failures
	net: dp83640: fix SIOCSHWTSTAMP to update the struct with actual configuration
	net: smc91x: Fix possible memory leak in smc_drv_probe()
	scripts/decode_stacktrace: strip basepath from all paths
	regmap: dev_get_regmap_match(): fix string comparison
	usb: gadget: udc: gr_udc: fix memleak on error handling path in gr_ep_init()
	arm64: Use test_tsk_thread_flag() for checking TIF_SINGLESTEP
	x86: math-emu: Fix up 'cmp' insn for clang ias
	Revert "cifs: Fix the target file was deleted when rename failed."
	staging: wlan-ng: properly check endpoint types
	staging: comedi: addi_apci_1032: check INSN_CONFIG_DIGITAL_TRIG shift
	staging: comedi: ni_6527: fix INSN_CONFIG_DIGITAL_TRIG support
	staging: comedi: addi_apci_1500: check INSN_CONFIG_DIGITAL_TRIG shift
	staging: comedi: addi_apci_1564: check INSN_CONFIG_DIGITAL_TRIG shift
	serial: 8250: fix null-ptr-deref in serial8250_start_tx()
	serial: 8250_mtk: Fix high-speed baud rates clamping
	mm/memcg: fix refcount error while moving and swapping
	parisc: Add atomic64_set_release() define to avoid CPU soft lockups
	ath9k: Fix general protection fault in ath9k_hif_usb_rx_cb
	ath9k: Fix regression with Atheros 9271
	AX.25: Fix out-of-bounds read in ax25_connect()
	AX.25: Prevent out-of-bounds read in ax25_sendmsg()
	net-sysfs: add a newline when printing 'tx_timeout' by sysfs
	net: udp: Fix wrong clean up for IS_UDPLITE macro
	AX.25: Prevent integer overflows in connect and sendmsg
	tcp: allow at most one TLP probe per flight
	rxrpc: Fix sendmsg() returning EPIPE due to recvmsg() returning ENODATA
	ip6_gre: fix null-ptr-deref in ip6gre_init_net()
	drivers/net/wan/x25_asy: Fix to make it work
	Makefile: Fix GCC_TOOLCHAIN_DIR prefix for Clang cross compilation
	regmap: debugfs: check count when read regmap file
	xfs: set format back to extents if xfs_bmap_extents_to_btree
	tools/lib/subcmd/pager.c: do not alias select() params
	perf: Make perf able to build with latest libbfd
	perf tools: Fix snprint warnings for gcc 8
	perf annotate: Use asprintf when formatting objdump command line
	perf probe: Fix to check blacklist address correctly
	Linux 4.4.232
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
Change-Id: Id3f07fa9b926d859582a8f3aa50c7e4c0c847a77
Diffstat (limited to 'net')
| -rw-r--r-- | net/ax25/af_ax25.c | 10 | ||||
| -rw-r--r-- | net/core/net-sysfs.c | 2 | ||||
| -rw-r--r-- | net/ipv4/tcp_input.c | 11 | ||||
| -rw-r--r-- | net/ipv4/tcp_output.c | 13 | ||||
| -rw-r--r-- | net/ipv4/udp.c | 2 | ||||
| -rw-r--r-- | net/ipv6/ip6_gre.c | 11 | ||||
| -rw-r--r-- | net/ipv6/udp.c | 2 | ||||
| -rw-r--r-- | net/mac80211/rx.c | 26 | ||||
| -rw-r--r-- | net/rxrpc/ar-output.c | 2 | ||||
| -rw-r--r-- | net/rxrpc/ar-recvmsg.c | 2 | 
10 files changed, 59 insertions, 22 deletions
| diff --git a/net/ax25/af_ax25.c b/net/ax25/af_ax25.c index 02be8ee23271..64fede18aa33 100644 --- a/net/ax25/af_ax25.c +++ b/net/ax25/af_ax25.c @@ -1191,7 +1191,10 @@ static int __must_check ax25_connect(struct socket *sock,  	if (addr_len > sizeof(struct sockaddr_ax25) &&  	    fsa->fsa_ax25.sax25_ndigis != 0) {  		/* Valid number of digipeaters ? */ -		if (fsa->fsa_ax25.sax25_ndigis < 1 || fsa->fsa_ax25.sax25_ndigis > AX25_MAX_DIGIS) { +		if (fsa->fsa_ax25.sax25_ndigis < 1 || +		    fsa->fsa_ax25.sax25_ndigis > AX25_MAX_DIGIS || +		    addr_len < sizeof(struct sockaddr_ax25) + +		    sizeof(ax25_address) * fsa->fsa_ax25.sax25_ndigis) {  			err = -EINVAL;  			goto out_release;  		} @@ -1510,7 +1513,10 @@ static int ax25_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)  			struct full_sockaddr_ax25 *fsa = (struct full_sockaddr_ax25 *)usax;  			/* Valid number of digipeaters ? */ -			if (usax->sax25_ndigis < 1 || usax->sax25_ndigis > AX25_MAX_DIGIS) { +			if (usax->sax25_ndigis < 1 || +			    usax->sax25_ndigis > AX25_MAX_DIGIS || +			    addr_len < sizeof(struct sockaddr_ax25) + +			    sizeof(ax25_address) * usax->sax25_ndigis) {  				err = -EINVAL;  				goto out;  			} diff --git a/net/core/net-sysfs.c b/net/core/net-sysfs.c index 579d351f6ddd..c976fd132c3b 100644 --- a/net/core/net-sysfs.c +++ b/net/core/net-sysfs.c @@ -999,7 +999,7 @@ static ssize_t show_trans_timeout(struct netdev_queue *queue,  	trans_timeout = queue->trans_timeout;  	spin_unlock_irq(&queue->_xmit_lock); -	return sprintf(buf, "%lu", trans_timeout); +	return sprintf(buf, fmt_ulong, trans_timeout);  }  #ifdef CONFIG_XPS diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index a6edcdb98c74..ededaddb12b0 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c @@ -3518,10 +3518,8 @@ static void tcp_replace_ts_recent(struct tcp_sock *tp, u32 seq)  	}  } -/* This routine deals with acks during a TLP episode. - * We mark the end of a TLP episode on receiving TLP dupack or when - * ack is after tlp_high_seq. - * Ref: loss detection algorithm in draft-dukkipati-tcpm-tcp-loss-probe. +/* This routine deals with acks during a TLP episode and ends an episode by + * resetting tlp_high_seq. Ref: TLP algorithm in draft-ietf-tcpm-rack   */  static void tcp_process_tlp_ack(struct sock *sk, u32 ack, int flag)  { @@ -3530,7 +3528,10 @@ static void tcp_process_tlp_ack(struct sock *sk, u32 ack, int flag)  	if (before(ack, tp->tlp_high_seq))  		return; -	if (flag & FLAG_DSACKING_ACK) { +	if (!tp->tlp_retrans) { +		/* TLP of new data has been acknowledged */ +		tp->tlp_high_seq = 0; +	} else if (flag & FLAG_DSACKING_ACK) {  		/* This DSACK means original and TLP probe arrived; no loss */  		tp->tlp_high_seq = 0;  	} else if (after(ack, tp->tlp_high_seq)) { diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index 6086718958d9..26de4da6341f 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c @@ -2271,6 +2271,11 @@ void tcp_send_loss_probe(struct sock *sk)  	int pcount;  	int mss = tcp_current_mss(sk); +	/* At most one outstanding TLP */ +	if (tp->tlp_high_seq) +		goto rearm_timer; + +	tp->tlp_retrans = 0;  	skb = tcp_send_head(sk);  	if (skb) {  		if (tcp_snd_wnd_test(tp, skb, mss)) { @@ -2293,10 +2298,6 @@ void tcp_send_loss_probe(struct sock *sk)  		return;  	} -	/* At most one outstanding TLP retransmission. */ -	if (tp->tlp_high_seq) -		goto rearm_timer; -  	if (skb_still_in_host_queue(sk, skb))  		goto rearm_timer; @@ -2317,10 +2318,12 @@ void tcp_send_loss_probe(struct sock *sk)  	if (__tcp_retransmit_skb(sk, skb))  		goto rearm_timer; +	tp->tlp_retrans = 1; + +probe_sent:  	/* Record snd_nxt for loss detection. */  	tp->tlp_high_seq = tp->snd_nxt; -probe_sent:  	NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPLOSSPROBES);  	/* Reset s.t. tcp_rearm_rto will restart timer from now */  	inet_csk(sk)->icsk_pending = 0; diff --git a/net/ipv4/udp.c b/net/ipv4/udp.c index 5dc8a00fa2df..f6f50dfeb362 100644 --- a/net/ipv4/udp.c +++ b/net/ipv4/udp.c @@ -1559,7 +1559,7 @@ int udp_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)  	/*  	 * 	UDP-Lite specific tests, ignored on UDP sockets  	 */ -	if ((is_udplite & UDPLITE_RECV_CC)  &&  UDP_SKB_CB(skb)->partial_cov) { +	if ((up->pcflag & UDPLITE_RECV_CC)  &&  UDP_SKB_CB(skb)->partial_cov) {  		/*  		 * MIB statistics other than incrementing the error count are diff --git a/net/ipv6/ip6_gre.c b/net/ipv6/ip6_gre.c index 954267a2bd64..80e03a50d92d 100644 --- a/net/ipv6/ip6_gre.c +++ b/net/ipv6/ip6_gre.c @@ -1359,15 +1359,16 @@ static void ip6gre_destroy_tunnels(struct net *net, struct list_head *head)  static int __net_init ip6gre_init_net(struct net *net)  {  	struct ip6gre_net *ign = net_generic(net, ip6gre_net_id); +	struct net_device *ndev;  	int err; -	ign->fb_tunnel_dev = alloc_netdev(sizeof(struct ip6_tnl), "ip6gre0", -					  NET_NAME_UNKNOWN, -					  ip6gre_tunnel_setup); -	if (!ign->fb_tunnel_dev) { +	ndev = alloc_netdev(sizeof(struct ip6_tnl), "ip6gre0", +			    NET_NAME_UNKNOWN, ip6gre_tunnel_setup); +	if (!ndev) {  		err = -ENOMEM;  		goto err_alloc_dev;  	} +	ign->fb_tunnel_dev = ndev;  	dev_net_set(ign->fb_tunnel_dev, net);  	/* FB netdevice is special: we have one, and only one per netns.  	 * Allowing to move it to another netns is clearly unsafe. @@ -1387,7 +1388,7 @@ static int __net_init ip6gre_init_net(struct net *net)  	return 0;  err_reg_dev: -	ip6gre_dev_free(ign->fb_tunnel_dev); +	ip6gre_dev_free(ndev);  err_alloc_dev:  	return err;  } diff --git a/net/ipv6/udp.c b/net/ipv6/udp.c index 4569cb25acb5..74ba63b1883d 100644 --- a/net/ipv6/udp.c +++ b/net/ipv6/udp.c @@ -672,7 +672,7 @@ int udpv6_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)  	/*  	 * UDP-Lite specific tests, ignored on UDP sockets (see net/ipv4/udp.c).  	 */ -	if ((is_udplite & UDPLITE_RECV_CC)  &&  UDP_SKB_CB(skb)->partial_cov) { +	if ((up->pcflag & UDPLITE_RECV_CC)  &&  UDP_SKB_CB(skb)->partial_cov) {  		if (up->pcrlen == 0) {          /* full coverage was set  */  			net_dbg_ratelimited("UDPLITE6: partial coverage %d while full coverage %d requested\n", diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index a74a6ff18f91..886dce84e70c 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c @@ -1963,6 +1963,7 @@ static int ieee80211_802_1x_port_control(struct ieee80211_rx_data *rx)  static int ieee80211_drop_unencrypted(struct ieee80211_rx_data *rx, __le16 fc)  { +	struct ieee80211_hdr *hdr = (void *)rx->skb->data;  	struct sk_buff *skb = rx->skb;  	struct ieee80211_rx_status *status = IEEE80211_SKB_RXCB(skb); @@ -1973,6 +1974,31 @@ static int ieee80211_drop_unencrypted(struct ieee80211_rx_data *rx, __le16 fc)  	if (status->flag & RX_FLAG_DECRYPTED)  		return 0; +	/* check mesh EAPOL frames first */ +	if (unlikely(rx->sta && ieee80211_vif_is_mesh(&rx->sdata->vif) && +		     ieee80211_is_data(fc))) { +		struct ieee80211s_hdr *mesh_hdr; +		u16 hdr_len = ieee80211_hdrlen(fc); +		u16 ethertype_offset; +		__be16 ethertype; + +		if (!ether_addr_equal(hdr->addr1, rx->sdata->vif.addr)) +			goto drop_check; + +		/* make sure fixed part of mesh header is there, also checks skb len */ +		if (!pskb_may_pull(rx->skb, hdr_len + 6)) +			goto drop_check; + +		mesh_hdr = (struct ieee80211s_hdr *)(skb->data + hdr_len); +		ethertype_offset = hdr_len + ieee80211_get_mesh_hdrlen(mesh_hdr) + +				   sizeof(rfc1042_header); + +		if (skb_copy_bits(rx->skb, ethertype_offset, ðertype, 2) == 0 && +		    ethertype == rx->sdata->control_port_protocol) +			return 0; +	} + +drop_check:  	/* Drop unencrypted frames if key is set. */  	if (unlikely(!ieee80211_has_protected(fc) &&  		     !ieee80211_is_any_nullfunc(fc) && diff --git a/net/rxrpc/ar-output.c b/net/rxrpc/ar-output.c index 14c4e12c47b0..a1997f9a447a 100644 --- a/net/rxrpc/ar-output.c +++ b/net/rxrpc/ar-output.c @@ -533,7 +533,7 @@ static int rxrpc_send_data(struct rxrpc_sock *rx,  	/* this should be in poll */  	sk_clear_bit(SOCKWQ_ASYNC_NOSPACE, sk); -	if (sk->sk_err || (sk->sk_shutdown & SEND_SHUTDOWN)) +	if (sk->sk_shutdown & SEND_SHUTDOWN)  		return -EPIPE;  	more = msg->msg_flags & MSG_MORE; diff --git a/net/rxrpc/ar-recvmsg.c b/net/rxrpc/ar-recvmsg.c index b92beded7459..cb9affdb1e87 100644 --- a/net/rxrpc/ar-recvmsg.c +++ b/net/rxrpc/ar-recvmsg.c @@ -78,7 +78,7 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,  				release_sock(&rx->sk);  				if (continue_call)  					rxrpc_put_call(continue_call); -				return -ENODATA; +				return -EAGAIN;  			}  		} | 
