Page MenuHomeFreeBSD

protosw: cleanup protocols that existed merely to provide pr_input
ClosedPublic

Authored by glebius on Aug 28 2022, 7:02 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 24, 7:27 PM
Unknown Object (File)
Thu, Jan 23, 6:26 PM
Unknown Object (File)
Fri, Dec 27, 3:18 AM
Unknown Object (File)
Dec 5 2024, 3:49 PM
Unknown Object (File)
Nov 22 2024, 4:08 PM
Unknown Object (File)
Nov 15 2024, 12:32 PM
Unknown Object (File)
Nov 15 2024, 12:15 PM
Unknown Object (File)
Nov 15 2024, 11:01 AM
Subscribers

Details

Summary

Since 4.4BSD the protosw was used to implement socket types created
by socket(2) syscall and at the same to demultiplex incoming IPv4
datagrams (later copied to IPv6). This story ended with 78b1fc05b20.

These entries (e.g. IPPROTO_ICMP) in inetsw that were added to catch
packets in ip_input(), they would also be returned by pffindproto()
if user says socket(AF_INET, SOCK_RAW, IPPROTO_ICMP). Thus, for raw
sockets to work correctly, all the entries were pointing at raw_usrreq
differentiating only in the value of pr_protocol.

With 78b1fc05b20 all these entries are no longer needed, as ip_protox
is independent of protosw. Any socket syscall requesting SOCK_RAW type
would end up with rip_protosw. And this protosw has its pr_protocol
set to 0, allowing to mark socket with any protocol.

For IPv6 raw socket the change required two small fixes:
o Validate user provided protocol value
o Always use protocol number stored in inp in rip6_attach, instead

of protosw value, which is now always 0.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 47159
Build 44046: arc lint + arc unit