tcp: fastopen: call tcp_fin() if FIN present in SYNACK
When we acknowledge a FIN, it is not enough to ack the sequence number
and queue the skb into receive queue. We also have to call tcp_fin()
to properly update socket state and send proper poll() notifications.
It seems we also had the problem if we received a SYN packet with the
FIN flag set, but it does not seem an urgent issue, as no known
implementation can do that.
Fixes: 61d2bcae99
("tcp: fastopen: accept data/FIN present in SYNACK message")
Signed-off-by: Eric Dumazet <edumazet@google.com>
Cc: Yuchung Cheng <ycheng@google.com>
Cc: Neal Cardwell <ncardwell@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
9a23ac475c
commit
e3e17b773b
|
@ -568,6 +568,7 @@ void tcp_rearm_rto(struct sock *sk);
|
|||
void tcp_synack_rtt_meas(struct sock *sk, struct request_sock *req);
|
||||
void tcp_reset(struct sock *sk);
|
||||
void tcp_skb_mark_lost_uncond_verify(struct tcp_sock *tp, struct sk_buff *skb);
|
||||
void tcp_fin(struct sock *sk);
|
||||
|
||||
/* tcp_timer.c */
|
||||
void tcp_init_xmit_timers(struct sock *);
|
||||
|
|
|
@ -154,6 +154,9 @@ void tcp_fastopen_add_skb(struct sock *sk, struct sk_buff *skb)
|
|||
* as we certainly are not changing upper 32bit value (0)
|
||||
*/
|
||||
tp->bytes_received = skb->len;
|
||||
|
||||
if (TCP_SKB_CB(skb)->tcp_flags & TCPHDR_FIN)
|
||||
tcp_fin(sk);
|
||||
}
|
||||
|
||||
static struct sock *tcp_fastopen_create_child(struct sock *sk,
|
||||
|
|
|
@ -3995,7 +3995,7 @@ void tcp_reset(struct sock *sk)
|
|||
*
|
||||
* If we are in FINWAIT-2, a received FIN moves us to TIME-WAIT.
|
||||
*/
|
||||
static void tcp_fin(struct sock *sk)
|
||||
void tcp_fin(struct sock *sk)
|
||||
{
|
||||
struct tcp_sock *tp = tcp_sk(sk);
|
||||
|
||||
|
|
Loading…
Reference in New Issue