Merge ra.kernel.org:/pub/scm/linux/kernel/git/torvalds/linux
All conflicts were trivial overlapping changes, so reasonably easy to resolve. Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
@@ -1994,7 +1994,7 @@ int tcp_recvmsg(struct sock *sk, struct msghdr *msg, size_t len, int nonblock,
|
||||
* shouldn't happen.
|
||||
*/
|
||||
if (WARN(before(*seq, TCP_SKB_CB(skb)->seq),
|
||||
"recvmsg bug: copied %X seq %X rcvnxt %X fl %X\n",
|
||||
"TCP recvmsg seq # bug: copied %X, seq %X, rcvnxt %X, fl %X\n",
|
||||
*seq, TCP_SKB_CB(skb)->seq, tp->rcv_nxt,
|
||||
flags))
|
||||
break;
|
||||
@@ -2009,7 +2009,7 @@ int tcp_recvmsg(struct sock *sk, struct msghdr *msg, size_t len, int nonblock,
|
||||
if (TCP_SKB_CB(skb)->tcp_flags & TCPHDR_FIN)
|
||||
goto found_fin_ok;
|
||||
WARN(!(flags & MSG_PEEK),
|
||||
"recvmsg bug 2: copied %X seq %X rcvnxt %X fl %X\n",
|
||||
"TCP recvmsg seq # bug 2: copied %X, seq %X, rcvnxt %X, fl %X\n",
|
||||
*seq, TCP_SKB_CB(skb)->seq, tp->rcv_nxt, flags);
|
||||
}
|
||||
|
||||
@@ -2555,6 +2555,8 @@ int tcp_disconnect(struct sock *sk, int flags)
|
||||
|
||||
tcp_clear_xmit_timers(sk);
|
||||
__skb_queue_purge(&sk->sk_receive_queue);
|
||||
tp->copied_seq = tp->rcv_nxt;
|
||||
tp->urg_data = 0;
|
||||
tcp_write_queue_purge(sk);
|
||||
tcp_fastopen_active_disable_ofo_check(sk);
|
||||
skb_rbtree_purge(&tp->out_of_order_queue);
|
||||
@@ -2815,14 +2817,17 @@ static int do_tcp_setsockopt(struct sock *sk, int level,
|
||||
case TCP_REPAIR:
|
||||
if (!tcp_can_repair_sock(sk))
|
||||
err = -EPERM;
|
||||
else if (val == 1) {
|
||||
else if (val == TCP_REPAIR_ON) {
|
||||
tp->repair = 1;
|
||||
sk->sk_reuse = SK_FORCE_REUSE;
|
||||
tp->repair_queue = TCP_NO_QUEUE;
|
||||
} else if (val == 0) {
|
||||
} else if (val == TCP_REPAIR_OFF) {
|
||||
tp->repair = 0;
|
||||
sk->sk_reuse = SK_NO_REUSE;
|
||||
tcp_send_window_probe(sk);
|
||||
} else if (val == TCP_REPAIR_OFF_NO_WP) {
|
||||
tp->repair = 0;
|
||||
sk->sk_reuse = SK_NO_REUSE;
|
||||
} else
|
||||
err = -EINVAL;
|
||||
|
||||
@@ -3714,8 +3719,7 @@ int tcp_abort(struct sock *sk, int err)
|
||||
struct request_sock *req = inet_reqsk(sk);
|
||||
|
||||
local_bh_disable();
|
||||
inet_csk_reqsk_queue_drop_and_put(req->rsk_listener,
|
||||
req);
|
||||
inet_csk_reqsk_queue_drop(req->rsk_listener, req);
|
||||
local_bh_enable();
|
||||
return 0;
|
||||
}
|
||||
|
Reference in New Issue
Block a user