diff options
Diffstat (limited to 'net/ipv4/tcp_ipv4.c')
| -rw-r--r-- | net/ipv4/tcp_ipv4.c | 25 | 
1 files changed, 10 insertions, 15 deletions
| diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c index 744afb4fbf84..29f398ec7d68 100644 --- a/net/ipv4/tcp_ipv4.c +++ b/net/ipv4/tcp_ipv4.c @@ -692,6 +692,7 @@ static void tcp_v4_send_reset(const struct sock *sk, struct sk_buff *skb)  		arg.bound_dev_if = sk->sk_bound_dev_if;  	arg.tos = ip_hdr(skb)->tos; +	arg.uid = sock_net_uid(net, sk && sk_fullsock(sk) ? sk : NULL);  	ip_send_unicast_reply(*this_cpu_ptr(net->ipv4.tcp_sk),  			      skb, &TCP_SKB_CB(skb)->header.h4.opt,  			      ip_hdr(skb)->saddr, ip_hdr(skb)->daddr, @@ -713,8 +714,8 @@ release_sk1:     outside socket context is ugly, certainly. What can I do?   */ -static void tcp_v4_send_ack(struct net *net, -			    struct sk_buff *skb, u32 seq, u32 ack, +static void tcp_v4_send_ack(const struct sock *sk, struct sk_buff *skb, +			    u32 seq, u32 ack,  			    u32 win, u32 tsval, u32 tsecr, int oif,  			    struct tcp_md5sig_key *key,  			    int reply_flags, u8 tos) @@ -729,6 +730,7 @@ static void tcp_v4_send_ack(struct net *net,  			];  	} rep;  	struct ip_reply_arg arg; +	struct net *net = sock_net(sk);  	memset(&rep.th, 0, sizeof(struct tcphdr));  	memset(&arg, 0, sizeof(arg)); @@ -777,6 +779,7 @@ static void tcp_v4_send_ack(struct net *net,  	if (oif)  		arg.bound_dev_if = oif;  	arg.tos = tos; +	arg.uid = sock_net_uid(net, sk_fullsock(sk) ? sk : NULL);  	ip_send_unicast_reply(*this_cpu_ptr(net->ipv4.tcp_sk),  			      skb, &TCP_SKB_CB(skb)->header.h4.opt,  			      ip_hdr(skb)->saddr, ip_hdr(skb)->daddr, @@ -790,8 +793,7 @@ static void tcp_v4_timewait_ack(struct sock *sk, struct sk_buff *skb)  	struct inet_timewait_sock *tw = inet_twsk(sk);  	struct tcp_timewait_sock *tcptw = tcp_twsk(sk); -	tcp_v4_send_ack(sock_net(sk), skb, -			tcptw->tw_snd_nxt, tcptw->tw_rcv_nxt, +	tcp_v4_send_ack(sk, skb, tcptw->tw_snd_nxt, tcptw->tw_rcv_nxt,  			tcptw->tw_rcv_wnd >> tw->tw_rcv_wscale,  			tcp_time_stamp + tcptw->tw_ts_offset,  			tcptw->tw_ts_recent, @@ -810,17 +812,9 @@ static void tcp_v4_reqsk_send_ack(const struct sock *sk, struct sk_buff *skb,  	/* sk->sk_state == TCP_LISTEN -> for regular TCP_SYN_RECV  	 * sk->sk_state == TCP_SYN_RECV -> for Fast Open.  	 */ -	u32 seq = (sk->sk_state == TCP_LISTEN) ? tcp_rsk(req)->snt_isn + 1 : -					     tcp_sk(sk)->snd_nxt; - -	/* RFC 7323 2.3 -	 * The window field (SEG.WND) of every outgoing segment, with the -	 * exception of <SYN> segments, MUST be right-shifted by -	 * Rcv.Wind.Shift bits: -	 */ -	tcp_v4_send_ack(sock_net(sk), skb, seq, -			tcp_rsk(req)->rcv_nxt, -			req->rsk_rcv_wnd >> inet_rsk(req)->rcv_wscale, +	tcp_v4_send_ack(sk, skb, (sk->sk_state == TCP_LISTEN) ? +			tcp_rsk(req)->snt_isn + 1 : tcp_sk(sk)->snd_nxt, +			tcp_rsk(req)->rcv_nxt, req->rsk_rcv_wnd,  			tcp_time_stamp,  			req->ts_recent,  			0, @@ -2385,6 +2379,7 @@ struct proto tcp_prot = {  	.destroy_cgroup		= tcp_destroy_cgroup,  	.proto_cgroup		= tcp_proto_cgroup,  #endif +	.diag_destroy		= tcp_abort,  };  EXPORT_SYMBOL(tcp_prot); | 
