Page MenuHomeFreeBSD

divert(4): maintain own cb database and stop using inpcb KPI
ClosedPublic

Authored by glebius on Aug 28 2022, 7:09 AM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 21, 8:38 PM
Unknown Object (File)
Sat, Jan 11, 5:48 PM
Unknown Object (File)
Dec 8 2024, 2:18 PM
Unknown Object (File)
Nov 15 2024, 4:51 PM
Unknown Object (File)
Nov 15 2024, 3:14 PM
Unknown Object (File)
Nov 15 2024, 12:18 PM
Unknown Object (File)
Oct 6 2024, 12:20 PM
Unknown Object (File)
Oct 6 2024, 12:20 PM
Subscribers

Details

Summary

Here go cons of using inpcb for divert:

  • divert(4) uses only 16 bits (local port) out of struct inpcb, which is 424 bytes today.
  • The inpcb KPI isn't able to provide hashing for divert(4), thus it uses global inpcb list for lookups.
  • divert(4) uses INET-specific part of the KPI, making INET a requirement for IPDIVERT.

Maintain our own very simple hash lookup database instead. It
has mutex protection for write and epoch protection for lookups.
Since now so->so_pcb no longer points to struct inpcb, don't
initialize protosw methods to methods that belong to PF_INET.
Also, drop support for setting options on a divert socket. My
review of software in base and ports confirms that this has no
use and unlikely worked before.

Diff Detail

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