Page MenuHomeFreeBSD

Fix some TCP fast open issues
ClosedPublic

Authored by tuexen on Jul 28 2018, 4:35 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Dec 21, 2:34 AM
Unknown Object (File)
Nov 29 2024, 5:27 PM
Unknown Object (File)
Nov 18 2024, 3:34 AM
Unknown Object (File)
Nov 18 2024, 3:20 AM
Unknown Object (File)
Nov 18 2024, 3:02 AM
Unknown Object (File)
Nov 18 2024, 2:31 AM
Unknown Object (File)
Nov 18 2024, 2:12 AM
Unknown Object (File)
Nov 18 2024, 12:40 AM
Subscribers

Details

Summary

Whenever a TCP server with TCP fast open enabled, calls recv, send, and close before the TCP-ACK segment has been received, the TCP connection is just dropped and the reception of the TCP-ACK segment triggers the sending of a TCP RST segment.

Whenever a TCP server with TCP fast open enabled, calls recv, send, send, and close before the TCP-ACK segment has been received, the first byte provided in the second send call is not transferred.

Whenever a TCP client with TCP fast open enabled calls sendto followed by close the TCP connection was just dropped.

The second problem shows up when using thttpd with fast open enabled and requesting a CGI script.

This patch fixes the above issues.

Test Plan

Run the attached packetdrill scripts. They should pass and all fail without this patch.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 18396

Event Timeline

jtl added a subscriber: jtl.
jtl added inline comments.
sys/netinet/tcp_output.c
231

It looks like the comment is now stale.

This revision is now accepted and ready to land.Jul 28 2018, 11:28 PM

Update the comments as suggested by jtl@.

This revision now requires review to proceed.Jul 29 2018, 7:05 AM
sys/netinet/tcp_output.c
231

You are correct. I updated the comments.

This revision is now accepted and ready to land.Jul 29 2018, 8:52 AM
This revision was automatically updated to reflect the committed changes.