Page MenuHomeFreeBSD

unix/stream: fix EVFILT_WRITE after we did shutdown(2)
ClosedPublic

Authored by glebius on Sep 1 2025, 10:04 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Oct 10, 3:39 PM
Unknown Object (File)
Fri, Oct 10, 3:39 PM
Unknown Object (File)
Fri, Oct 10, 3:39 PM
Unknown Object (File)
Fri, Oct 10, 9:26 AM
Unknown Object (File)
Wed, Sep 24, 12:12 PM
Unknown Object (File)
Sep 21 2025, 7:19 PM
Unknown Object (File)
Sep 18 2025, 8:05 PM
Unknown Object (File)
Sep 18 2025, 7:42 PM
Subscribers

Details

Summary

When fixing bug 286692, the change eafe5967ac558, that fixed a case when
peer side does close(), also had regressed a case when our side does
shutdown(SHUT_WR). These actually are two independent code paths, and the
eafe5967ac558 shouldn't have touched the second block. The removal of
'kn->kn_flags |= EV_EOF' was incorrect and the statement on original
behavior in the commit message was also incorrect.

Do not add back so_error setting, since I failed to find a test case that
would return anything but 0 in kevent.fflags when run on stable/14.

This was found with help of https://github.com/tokio-rs/mio. Add a test
case into our test suite for that.

Fixes: eafe5967ac558de142d91660e18e9238289890e3

Diff Detail

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