svn commit: r365589 - in stable/12/sys/netinet: . tcp_stacks
Michael Tuexen
tuexen at FreeBSD.org
Thu Sep 10 16:59:55 UTC 2020
Author: tuexen
Date: Thu Sep 10 16:59:54 2020
New Revision: 365589
URL: https://svnweb.freebsd.org/changeset/base/365589
Log:
MFC r357100:
The server side of TCP fast open relies on the delayed ACK timer to allow
including user data in the SYN-ACK. When DSACK support was added in
r347382, an immediate ACK was sent even for the received SYN with
user data. This patch fixes that and allows again to send user data with
the SYN-ACK.
Modified:
stable/12/sys/netinet/tcp_input.c
stable/12/sys/netinet/tcp_stacks/rack_bbr_common.c
Directory Properties:
stable/12/ (props changed)
Modified: stable/12/sys/netinet/tcp_input.c
==============================================================================
--- stable/12/sys/netinet/tcp_input.c Thu Sep 10 16:47:12 2020 (r365588)
+++ stable/12/sys/netinet/tcp_input.c Thu Sep 10 16:59:54 2020 (r365589)
@@ -2299,7 +2299,7 @@ tcp_do_segment(struct mbuf *m, struct tcphdr *th, stru
/*
* DSACK - add SACK block for dropped range
*/
- if (tp->t_flags & TF_SACK_PERMIT) {
+ if ((todrop > 0) && (tp->t_flags & TF_SACK_PERMIT)) {
tcp_update_sack_list(tp, th->th_seq,
th->th_seq + todrop);
/*
Modified: stable/12/sys/netinet/tcp_stacks/rack_bbr_common.c
==============================================================================
--- stable/12/sys/netinet/tcp_stacks/rack_bbr_common.c Thu Sep 10 16:47:12 2020 (r365588)
+++ stable/12/sys/netinet/tcp_stacks/rack_bbr_common.c Thu Sep 10 16:59:54 2020 (r365589)
@@ -495,7 +495,7 @@ ctf_drop_checks(struct tcpopt *to, struct mbuf *m, str
/*
* DSACK - add SACK block for dropped range
*/
- if (tp->t_flags & TF_SACK_PERMIT) {
+ if ((todrop > 0) && (tp->t_flags & TF_SACK_PERMIT)) {
tcp_update_sack_list(tp, th->th_seq, th->th_seq + tlen);
/*
* ACK now, as the next in-sequence segment
More information about the svn-src-all
mailing list