Page MenuHomeFreeBSD

ktls: Fix error/mode confusion in TCP_*TLS_MODE getsockopt handlers
ClosedPublic

Authored by markj on Sep 15 2021, 7:59 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 14, 3:16 AM
Unknown Object (File)
Dec 3 2024, 4:12 PM
Unknown Object (File)
Nov 25 2024, 12:47 PM
Unknown Object (File)
Nov 22 2024, 12:44 AM
Unknown Object (File)
Nov 17 2024, 10:49 PM
Unknown Object (File)
Oct 24 2024, 11:08 PM
Unknown Object (File)
Oct 14 2024, 12:52 PM
Unknown Object (File)
Sep 30 2024, 5:33 AM
Subscribers

Details

Summary

ktls_get_(rx|tx)_mode() can return an errno value or a TLS mode, so
errors are effectively hidden. Fix this. Convert to the new socket
buffer locking macros while here.

Note that the socket buffer lock is not needed to synchronize the
SOLISTENING check here, we can rely on the PCB lock, acquired in
tcp_usr_listen().

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 41537
Build 38426: arc lint + arc unit

Event Timeline

markj requested review of this revision.Sep 15 2021, 7:59 PM

I think this is fine, just one thought.

sys/netinet/tcp_usrreq.c
2566

Did you consider doing the SOLISTENING check here instead of in the ktls_get_*_mode() routines?

sys/netinet/tcp_usrreq.c
2566

Hmm, not really. I noticed that other ktls_* routines check for listening sockets and the TCP socket option (wow there's a lot of them...) handlers generally do not, so it made sense to me to keep things consistent.

sys/netinet/tcp_usrreq.c
2566

Ok. Either way is fine with me.

This revision was not accepted when it landed; it landed in state Needs Review.Sep 17 2021, 7:13 PM
This revision was automatically updated to reflect the committed changes.