Page MenuHomeFreeBSD

Restore the ability to deregister an eventhandler callback from within the callback.
ClosedPublic

Authored by ian on Oct 1 2017, 8:41 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Aug 13, 7:18 PM
Unknown Object (File)
Fri, Aug 8, 1:04 AM
Unknown Object (File)
Jul 6 2025, 6:45 AM
Unknown Object (File)
Jul 5 2025, 10:28 AM
Unknown Object (File)
Jul 3 2025, 8:36 PM
Unknown Object (File)
Jul 2 2025, 6:03 AM
Unknown Object (File)
Jun 29 2025, 4:12 AM
Unknown Object (File)
Jun 28 2025, 12:52 PM
Subscribers

Details

Summary

When the EVENTHANDLER(9) subsystem was created, it was a documented feature that an eventhandler callback function could safely deregister itself. In r200652 that feature was inadvertantly broken by adding drain-wait logic to eventhandler_deregister(), so that it would be safe to unload a module upon return from deregistering its event handlers.

There are now 145 callers of EVENTHANDLER_DEREGISTER(), and it's likely many of them are depending on the drain-wait logic that has been in place for 8 years. So instead of creating a separate eventhandler_drain() and adding it to some or all of those 145 call sites, this creates a separate eventhandler_drain_nowait() function for the specific purpose of deregistering a callback from within the running callback.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 11837

Event Timeline

I don't see anything horrible here.

This revision is now accepted and ready to land.Oct 1 2017, 9:58 PM
This revision was automatically updated to reflect the committed changes.