Page MenuHomeFreeBSD

aio: Interlock with listen(2)
ClosedPublic

Authored by markj on Sep 10 2021, 4:19 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 3, 5:08 AM
Unknown Object (File)
Fri, Dec 13, 8:21 AM
Unknown Object (File)
Fri, Dec 13, 7:47 AM
Unknown Object (File)
Nov 26 2024, 3:13 PM
Unknown Object (File)
Nov 25 2024, 7:55 PM
Unknown Object (File)
Nov 25 2024, 7:55 PM
Unknown Object (File)
Nov 25 2024, 7:55 PM
Unknown Object (File)
Nov 25 2024, 7:55 PM
Subscribers

Details

Summary

soo_aio_queue() did not handle the possibility that the provided socket
is a listening socket. Up until recently, to fix this one would have to
acquire the socket lock first and check, since the socket buffer locks
were destroyed by listen(2).

Now that the socket buffer locks belong to the socket, simply check
SOLISTENING(so) after acquiring them, and make listen(2) return an error
if any AIO jobs are enqueued on the socket.

Add a couple of simple regression test cases.

Note that this fixes things only for the default AIO implementation;
cxgbe has a separate pru_aio_queue implementation which needs to be
fixed.

Reported by: syzbot+c8aa122fa2c6a4e2a28b@syzkaller.appspotmail.com
Reported by: syzbot+39af117d43d4f0faf512@syzkaller.appspotmail.com

Diff Detail

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