Page MenuHomeFreeBSD

Fix bugs in DCTCP on TCP events
ClosedPublic

Authored by rscheff on Jun 7 2019, 12:49 PM.
Tags
None
Referenced Files
F108373833: D20550.diff
Fri, Jan 24, 6:37 AM
Unknown Object (File)
Tue, Jan 21, 9:46 PM
Unknown Object (File)
Mon, Jan 20, 4:28 AM
Unknown Object (File)
Sun, Jan 19, 3:31 PM
Unknown Object (File)
Fri, Jan 17, 5:20 PM
Unknown Object (File)
Dec 21 2024, 8:37 AM
Unknown Object (File)
Dec 19 2024, 11:45 AM
Unknown Object (File)
Dec 13 2024, 2:06 AM
Subscribers

Details

Summary
DCTCP reactions to after_idle and post_recovery would disable
themselves after the first call.
Also, have consistent fall-through to NewReno for non-ECN
sessions.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 24749
Build 23510: arc lint + arc unit

Event Timeline

Comment from Midori (original author of this code):

Thank you for your message and improving dctcp implementation. The description of two bugfix request makes sense. I have two comments. First, remove white space at line126 in the D20550 patch before submission. Second, you
should remove a change at line353 in the D20550 patch. If I understand correctly, it does not affect performance. Please point out if there is my misunderstanding.

sys/netinet/cc/cc_dctcp.c
127

remove white space at line126 in the D20550 patch before submission

353

MidorI: remove a change at line353 in the D20550 patch. If I understand correctly, it does not affect performance

R: If other parts of the code decided to send out an ACK right away (e.g. leaving zero-window episodes), we should not clear the ACKNOW flag here.

  • - missed rename of variable
sys/netinet/cc/cc_dctcp.c
127

Leaving whitespace, as that separates different ack types.

using sacked data (CCV(ccv, sackhint.delivered_data) here depends on the RFC6675 chain of patched (D18892, D18985).

This revision is now accepted and ready to land.Jul 29 2019, 9:08 AM
sys/netinet/cc/cc_dctcp.c
294

This should read

newreno_cc_algo.cong_signal(ccv, type);