Page MenuHomeFreeBSD

rtsock: fix socket closure.
ClosedPublic

Authored by melifaro on Jan 15 2023, 1:40 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 10 2024, 5:38 AM
Unknown Object (File)
Nov 28 2024, 8:13 AM
Unknown Object (File)
Nov 20 2024, 5:08 PM
Unknown Object (File)
Nov 19 2024, 5:33 AM
Unknown Object (File)
Nov 19 2024, 3:00 AM
Unknown Object (File)
Nov 10 2024, 4:54 PM
Unknown Object (File)
Nov 6 2024, 10:39 AM
Unknown Object (File)
Nov 2 2024, 12:18 AM
Subscribers

Details

Summary

Currently close(2) erroneously return EOPNOTSUPP for PF_ROUTE sockets. It happened after making rtsock socket implementation self-contained.

Current rtsock code marks socket as connected in rts_attach(). soclose() tries to disconnect such socket using .pr_disconnect callback.
rtsock does not implement this callback, resulting in the default method being substituted. This default method returns ENOTSUPP, failing soclose() logic.

This diff restores the previous behaviour by adding custom pr_disconnect() returning ENOTCONN.

Diff Detail

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

Event Timeline

Alexander, thanks a lot for quick fix of my mistake!

This revision is now accepted and ready to land.Jan 15 2023, 6:34 PM
This revision was automatically updated to reflect the committed changes.