Page MenuHomeFreeBSD

unix/dgram: return EAGAIN instead of ENOBUFS when O_NONBLOCK set
ClosedPublic

Authored by glebius on Feb 6 2022, 6:33 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Feb 26, 2:59 AM
Unknown Object (File)
Feb 8 2026, 12:40 PM
Unknown Object (File)
Feb 8 2026, 3:40 AM
Unknown Object (File)
Jan 30 2026, 4:30 PM
Unknown Object (File)
Jan 25 2026, 6:47 AM
Unknown Object (File)
Dec 31 2025, 3:27 PM
Unknown Object (File)
Nov 27 2025, 7:57 AM
Unknown Object (File)
Nov 25 2025, 9:41 PM
Subscribers

Details

Summary

This is behavior what some programs expect and what Linux does. For
example nginx expects EAGAIN when sending messages to /var/run/log,
which it connects to with O_NONBLOCK. Particularly with nginx the
problem is magnified by the fact that a ENOBUFS on send(2) is also
logged, so situation creates a log-bomb - a failed log message
triggers another log message.

Diff Detail

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

Event Timeline

I think this is probably ok. EAGAIN is the usual error value for this case. I thought this would break our syslog(3), which explicitly checks for ENOBUFS, but it uses a blocking socket.

This revision is now accepted and ready to land.Feb 6 2022, 10:35 PM