Page MenuHomeFreeBSD

tcp: pass maxseg around instead of locally calculating anew
ClosedPublic

Authored by rscheff on Jan 21 2024, 7:06 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 13, 7:33 PM
Unknown Object (File)
Sun, Dec 29, 3:56 AM
Unknown Object (File)
Dec 13 2024, 8:51 AM
Unknown Object (File)
Nov 29 2024, 4:08 PM
Unknown Object (File)
Nov 24 2024, 10:40 AM
Unknown Object (File)
Nov 18 2024, 5:24 AM
Unknown Object (File)
Nov 18 2024, 2:28 AM
Unknown Object (File)
Nov 18 2024, 2:19 AM
Subscribers

Details

Summary

Improve slowpath processing (reordering, retransmissions)
slightly by passing maxseg, once calculated, around. This typically
saves one of two calls to tcp_maxseg() which is relatively complex.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

I'm fine with the patch as is, but here is some idea you may consider.

Current code will call either tcp_sack_partialack() or tcp_do_prr_ack() and only once. It is:

if (foo) {
                if (bar)
                                tcp_do_prr_ack(tp, th, &to, sack_changed,
                                    (maxseg ? maxseg : tcp_maxseg(tp)));
                else
                                tcp_sack_partialack(tp, th,
                                    (maxseg ? maxseg : tcp_maxseg(tp)));
} else if (baz)
                        tcp_do_prr_ack(tp, th, &to, SACK_CHANGE,
                            (maxseg ? maxseg : tcp_maxseg(tp)));

However, we might have another function interested in maxseg or either of the existing functions called twice. If that happens we are doing two calls to tcp_maxseg() again. So alternative code would be a prototype that passes pointer to maxseg on the stack of caller and allows callee to update it if it is 0.

void
tcp_do_prr_ack(struct tcpcb *tp, struct tcphdr *th, struct tcpopt *to, sackstatus_t sack_changed, u_int *maxseg)
{
         if (*maxseg == 0)
                *maxseg = tcp_maxseg(tp)
  • update uninitialized maxseg for posterity
  • update uninitialized maxseg for posterity (no ptrs)
  • go back to passing a pointer but don't touch body of functions
This revision is now accepted and ready to land.Jan 24 2024, 7:15 AM
sys/netinet/tcp_input.c
1532

The "maxseg" won't be assigned a value after line#2793. So I am wondering why not initialize/zero it in the beginning. There may be techniques that make sure it is always zero, but at least zero it here removes uncertainty.

2793

The "maxseg", in my understanding, won't be assigned a value after line#2793.

  • properly initialize maxseg again
This revision now requires review to proceed.Jan 24 2024, 2:36 PM
rscheff added inline comments.
sys/netinet/tcp_input.c
1532

Thanks. This got somehow dropped between revisions.

This revision is now accepted and ready to land.Jan 24 2024, 2:51 PM
This revision was automatically updated to reflect the committed changes.
rscheff marked an inline comment as done.