Page MenuHomeFreeBSD

tcp: improve sending of TTL/hoplimit and DSCP
ClosedPublic

Authored by tuexen on Jun 5 2023, 10:46 AM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Dec 31, 6:27 PM
Unknown Object (File)
Sat, Dec 28, 10:07 PM
Unknown Object (File)
Mon, Dec 9, 6:28 PM
Unknown Object (File)
Wed, Dec 4, 1:09 AM
Unknown Object (File)
Nov 29 2024, 5:52 AM
Unknown Object (File)
Nov 20 2024, 10:54 AM
Unknown Object (File)
Sep 3 2024, 11:34 AM
Unknown Object (File)
Sep 2 2024, 5:05 AM

Details

Summary

This patch improves the sending of TCP segments with user specified TTL/hoplimit or DSCP. For IPv6, the code within the IPv6 code is always used.

Test Plan

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

sys/netinet/tcp_stacks/rack.c
18837

shouldn't this be symetrical to the ip6_output above? At least in the base stack, inp->inp_options seem to be used

sys/netinet/tcp_subr.c
2214

Detto?

sys/netinet/tcp_stacks/rack.c
18837

This is related to IPv4 options. I don't think the RACK stack support this right now. If needed, we can fix that separately. Any particular IPv4 options you have in mind?

sys/netinet/tcp_subr.c
2214

I think this just means that the base stack handles IPv4 options inconsistently. If this is a problem, we can fix that separately.

No particular ipv4 option; guess it shows that IPv4 options are not really relevant (but with ipv6, that aspect did change). Agree - if problems arise with ipv4 lets make a separate diff.

This revision is now accepted and ready to land.Jun 5 2023, 12:35 PM
sys/netinet/tcp_subr.c
2053–2060

Better use "if (inp != NULL)" for readability.

2054

Looks IPTOS_ECN_CE can't be included in inp->inp_ip_tos, so we don't need this line. If I am right, we can simplify the code as below:

if (inp != NULL) {
        ip->ip_tos = inp->inp_ip_tos;
        ip->ip_ttl = inp->inp_ip_ttl;
} else {
        ip->ip_tos = ect;
        ip->ip_ttl = V_ip_defttl;
}

Address most of cc's comments.

This revision now requires review to proceed.Jun 5 2023, 2:27 PM
tuexen added inline comments.
sys/netinet/tcp_subr.c
2053–2060

Done.

2054

Right now you are correct, that ect is zero here, but this might change once ECN++ is implemented. So let us keep the code prepared for this.

sys/netinet/tcp_subr.c
2054

Looks IPTOS_ECN_CE can't be included in inp->inp_ip_tos, so we don't need this line. If I am right, we can simplify the code as below:

if (inp != NULL) {
        ip->ip_tos = inp->inp_ip_tos;
        ip->ip_ttl = inp->inp_ip_ttl;
} else {
        ip->ip_tos = ect;
        ip->ip_ttl = V_ip_defttl;
}

Withdraw my above comment. Looks ECN and DSCP are separated. Based on Richard's commit in 3b0ee680507a and my read, I didn't find a place where inp->inp_ip_tos can contain any ECN bits. So if just be cautious, the code can be:

if (inp != NULL) {
        KASSERT((inp->inp_ip_tos & IPTOS_ECN_MASK) == 0, ("inp_ip_tos contains ECN bits"));
        ip->ip_tos = inp->inp_ip_tos | ect;
        ip->ip_ttl = inp->inp_ip_ttl;
} else {
        ip->ip_tos = ect;
        ip->ip_ttl = V_ip_defttl;
}
tuexen added inline comments.
sys/netinet/tcp_subr.c
2054

Lets do this in a consistent way. Other places also clear the ENC bits before applying the new ones.

If we want to remove this and replace it by an KASSERT, then do this separately and consistently in all places. This would catch error in main code paths and not only in one special path.

cc added inline comments.
sys/netinet/tcp_subr.c
2054

Sounds good to me. Would you take this path in a next change? Or I can take this work for such checks in main code path.

This revision is now accepted and ready to land.Jun 5 2023, 7:12 PM
This revision was automatically updated to reflect the committed changes.
tuexen marked an inline comment as done.