In D53104#1217628, @adrian wrote:ok, so this looks fine, but I'm trying to remember where I used to assign the flowid/flowtype for a connection back in the day. On the mbuf side it used to be done in the driver side and then overriden by the network stack input path if it didn't match what was required (eg the magic required in ip reassembly, which is still there, but also to support completely software flow hashing.)
(remember way WAY back in the day the flowid/flowtype was also used by kip's flowdirector stuff for doing more explicit control over where flows went, and RSS just 'also' used it.)
- Queries
- All Stories
- Search
- Advanced Search
- Transactions
- Transaction Logs
 Feed  Advanced Search 
Advanced Search
Advanced Search
Yesterday
Yesterday
Thu, Oct 2
Thu, Oct 2
For reference, the Linux kernel recently changed it from 6MB to 32MB.
Tue, Sep 30
Tue, Sep 30
Thu, Sep 25
Thu, Sep 25
Sep 15 2025
Sep 15 2025
Sep 4 2025
Sep 4 2025
Aug 29 2025
Aug 29 2025
Looks good to me. I only have two minor suggestions.
Aug 13 2025
Aug 13 2025
Aug 12 2025
Aug 12 2025
Aug 11 2025
Aug 11 2025
In D7986#1184580, @kbowling wrote:@imp if I recall this was something we were looking at on my team at LLNW, if it were in Bugzilla I'd say "Close - OBE" is appropriate.
@cc since you've been working on CUBIC lately, the only thing possibly still relevant here is turning the first level if into the early returns.. it removes one level of indention which might help justify a couple other nearby style(9) fixes but it's not worth holding this review open.
Aug 8 2025
Aug 8 2025
Thanks for the following improvements:
Aug 6 2025
Aug 6 2025
Aug 5 2025
Aug 5 2025
cc added a comment to D51725: tcp: ensure that SACK hole->rxmit never ends up left of the hole with LRD.
I am ok with this patch. But I want to be sure how snd_recover shrinks. Is it because tp->snd_recover = tp->snd_recover_prev in CC_RTO_ERR? But that shall not be in SACK recovery.
Jul 21 2025
Jul 21 2025
Jul 7 2025
Jul 7 2025
Other than the fd is not used in the test code, I am good with this change.
Jun 30 2025
Jun 30 2025
Thanks for the elaboration. Looks good to me now.
Looks I am missing the context. Given the fact that the socket is in TCPS_TIME_WAIT while switching to the default stack, was this assert a day one issue that was not test covered before? Or was this panic caused by recent changes?
Jun 16 2025
Jun 16 2025
cc committed rGa2f579635f67: cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC. (authored by cc).
cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC.
cc updated the test plan for D49540: cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC..
Jun 13 2025
Jun 13 2025
Jun 11 2025
Jun 11 2025
May 14 2025
May 14 2025
cc updated the test plan for D49540: cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC..
May 1 2025
May 1 2025
cc updated the test plan for D49540: cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC..
cc updated the test plan for D49540: cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC..
Apr 21 2025
Apr 21 2025
Mar 27 2025
Mar 27 2025
cc updated the summary of D49540: cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC..
cc updated the summary of D49540: cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC..
cc updated the test plan for D49540: cc_cubic: sync to the new specification of RFC9438 for TCP CUBIC..
Mar 20 2025
Mar 20 2025
This is for the fast path fix. Just want to confirm with your that a second patch may be around to improve both of the fast and slow path?
Mar 17 2025
Mar 17 2025
cc committed rGa8d2bccb87d0: tcp cc: use tcp_compute_pipe() for pipe in xx_post_recovery() directly (authored by cc).
tcp cc: use tcp_compute_pipe() for pipe in xx_post_recovery() directly
Mar 5 2025
Mar 5 2025
cc updated the test plan for D49247: tcp cc: use tcp_compute_pipe() for pipe in xx_post_recovery() directly.
cc requested review of D49247: tcp cc: use tcp_compute_pipe() for pipe in xx_post_recovery() directly.
Feb 28 2025
Feb 28 2025
cc committed rG67787d200488: tcp: make inflight data (pipe) calculation consistent (authored by cc).
tcp: make inflight data (pipe) calculation consistent
Didn't see any surprising regression from my test result for this patch:
testD49047
Feb 21 2025
Feb 21 2025
code update based on Richard's comments
re-base, add a missing part and update based on Richard's comment in the meeting
Feb 20 2025
Feb 20 2025
cc_cubic: remove redundant code
Feb 19 2025
Feb 19 2025
In D49047#1118719, @glebius wrote:Question: why does this function returns signed value? And why some of the sackhint counters are signed?
There are several calls to tcp_compute_pipe() that did not check the V_tcp_do_newsack: 2 in tcp_output and 1 in tcp_input. Their behavior will change with revised SACK turned off. Commit message should explain why this is okay.
Feb 18 2025
Feb 18 2025
Feb 14 2025
Feb 14 2025
Feb 12 2025
Feb 12 2025
cc committed rG6156da866e7d: cc_cubic: remove redundant calls of tcp_fixed_maxseg() (authored by cc).
cc_cubic: remove redundant calls of tcp_fixed_maxseg()
Jan 31 2025
Jan 31 2025
Jan 8 2025
Jan 8 2025
Why not move the old_method: label above the stack variables' declaration? I think it may be cleaner to read.
Like this:
Jan 6 2025
Jan 6 2025
Dec 18 2024
Dec 18 2024
Dec 11 2024
Dec 11 2024
Dec 10 2024
Dec 10 2024
Additional comment:
Nov 25 2024
Nov 25 2024
Nov 19 2024
Nov 19 2024
cc added a comment to D47474: tcp: Use segment size excluding any options for all cwnd calculations.
update:
Looks this patch has some significant reduction on fragment (data_size % MSS) > 0 out of TSO data chunks: testD47474
TSO not enabled:
Nov 14 2024
Nov 14 2024
cc added a comment to D47474: tcp: Use segment size excluding any options for all cwnd calculations.
In D47474#1084985, @rscheff wrote:Well, I had the same thought - the full MSS (including options) is less frequently used, that the mss without options...
So, it would certainly be more efficient to store the MSS exkluding options in tcpcb, and calculating the MSS inkl. option space only where that is needed...
But that should a different Diff IMHO, as this one is more in the break/fix category.
cc added inline comments to D47474: tcp: Use segment size excluding any options for all cwnd calculations.
Nov 4 2024
Nov 4 2024
I think you meant the title be:
tcp: consistently set CWND to MSS => tcp: consistently set CWND to 1
in case of SYN/SYN ACK retransmissions => in case of SYN retransmissions
Oct 28 2024
Oct 28 2024
OK. I am approving it now as my test in https://wiki.freebsd.org/chengcui/testD43470 shows some improvement. Any bug related observations can be fixed later.
Oct 24 2024
Oct 24 2024
Also, please correct the SUMMARY section:
Oct 23 2024
Oct 23 2024
In D30155#1076291, @kbowling wrote:In D30155#1075233, @cc wrote:From my test result in testD30155, I didn't find any significant improvement under my eyes:
- no significant difference in ping latency
- no significant iperf3 performance improvement due to bad performance (3.x Gbps) in FreeBSD 15-current vs. (9.x Gbps) in stock Linux kernel 5.15.
Thanks for the results @cc. Something seems very strange with the throughput there, the main system I am testing is a xeon-d that is much less than 1/4th as powerful and can line rate both directions no issues and I also have an older 2x Xeon E5-2695 v2 (two NUMA domains) without throughput limitations. I will see if I can find my emulab credentials and take a look there, it seems like these might be 4-way NUMA machines but it is not expected to me that that would cause this magnitude of throughput issues, especially at the 10gbit data rate.
Oct 22 2024
Oct 22 2024
Oct 21 2024
Oct 21 2024
cc requested review of D47218: tcp cc: re-organize newreno functions into parts that can be re-used.
Oct 17 2024
Oct 17 2024
cc updated the summary of D47130: tcp: remove the `goto drop` label by reusing equivalences in tcp_do_segment()..
cc updated the diff for D47130: tcp: remove the `goto drop` label by reusing equivalences in tcp_do_segment()..
update code based on discussion
From my test result in testD30155, I didn't find any significant improvement under my eyes:
Oct 16 2024
Oct 16 2024
Better now. But it can be cleaner.
cc added inline comments to D47130: tcp: remove the `goto drop` label by reusing equivalences in tcp_do_segment()..
cc updated the diff for D47130: tcp: remove the `goto drop` label by reusing equivalences in tcp_do_segment()..
Add the __inline keyword to avoid overhead when possible.
Oct 15 2024
Oct 15 2024
cc requested review of D47130: tcp: remove the `goto drop` label by reusing equivalences in tcp_do_segment()..
My current concern is that the definition and the usage of the super set macro TH_FLAGS or TCPF_ALL are inconsistent. For example, TH_ECE is in TH_FLAGS, but TH_ECN is in TCPF_ALL.
In D30155#1073639, @kbowling wrote:Ok this is a bit messy code and comment wise but I have the new algorithm working in what I believe to be the correct way with some bug fixes versus the origin and would like some data to see how to proceed before tidying everything up.
@cc it looks like emulab has ix(4) on d820s nodes, would you be willing to take a look at these 3 options similar to the e1000 test?
- Default in HEAD/STABLE: sysctl dev.ix.<N>.enable_aim=0
- New algorithm (on by default with this patch) sysctl dev.ix.<N>.enable_aim=1
- Old algorithm (FreeBSD <10) sysctl dev.ix.<N>.enable_aim=2
Oct 14 2024
Oct 14 2024
I current concern is that new code for the TH_AE shall be in a separate patch, so that this patch can be a pure big non-functional change.
Oct 11 2024
Oct 11 2024
Need code update.
Because of commit 440f4ba18e3a, please re-base.
Oct 10 2024
Oct 10 2024
By the way based on my test, I didn't find this statement In addition, cwnd used to be 1 MSS right after RTO, increasing to 2 MSS more recently. to be true in your SUMMARY section. Also Address this by setting up snd_recover just in cc_cong_signal. needs to be revised.
With the provided packetdrill scripts before/after the fix, my test result is in my wiki: testD43355.
Oct 9 2024
Oct 9 2024
cc added inline comments to D43355: tcp: fix erroneous transmission selection after RTO w/ SACK incoming.