Page MenuHomeFreeBSD

lio_listio: Don't post a completion notification if none was requested
ClosedPublic

Authored by markj on Jul 15 2021, 6:11 PM.
Tags
None
Referenced Files
F102434861: D31197.diff
Tue, Nov 12, 5:45 AM
Unknown Object (File)
Sat, Oct 26, 4:36 PM
Unknown Object (File)
Sat, Oct 19, 8:30 PM
Unknown Object (File)
Mon, Oct 14, 7:31 PM
Unknown Object (File)
Oct 12 2024, 10:24 AM
Unknown Object (File)
Oct 12 2024, 10:24 AM
Unknown Object (File)
Oct 12 2024, 10:23 AM
Unknown Object (File)
Oct 12 2024, 10:10 AM
Subscribers

Details

Summary

One is allowed to use LIO_NOWAIT without specifying a sigevent. In this
case, lj->lioj_signal is left uninitialized, but several code paths
examine liov_signal.sigev_notify to figure out which notification to
post. Unconditionally initialize that field to SIGEV_NONE.

Add a dumb test case which triggers the bug.

Reported by: KMSAN+syzkaller
MFC after: 2 weeks
Sponsored by: The FreeBSD Foundation

Diff Detail

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