Page MenuHomeFreeBSD

In g_newprovider_event() return if G_P_WITHER is set
ClosedPublic

Authored by trasz on Nov 23 2020, 1:21 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Nov 23, 2:37 AM
Unknown Object (File)
Sat, Nov 22, 1:33 PM
Unknown Object (File)
Wed, Nov 19, 6:39 AM
Unknown Object (File)
Fri, Nov 7, 5:33 AM
Unknown Object (File)
Thu, Oct 30, 7:12 PM
Unknown Object (File)
Wed, Oct 29, 3:41 PM
Unknown Object (File)
Oct 26 2025, 12:25 PM
Unknown Object (File)
Oct 21 2025, 2:36 PM
Subscribers

Details

Summary

In g_newprovider_event() return if G_P_WITHER is set.

This fixes a failed assertion in scenario where the provider
disappears, disk_gone() gets called, and at the exact same
time something else closes the device node triggering a retaste.

Diff Detail

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

Event Timeline

trasz requested review of this revision.Nov 23 2020, 1:21 PM
trasz created this revision.

Looks good. Few places that call it also check for G_PF_WITHER, but they are using g_post_event() for it, that opens a race window.

This revision is now accepted and ready to land.Nov 23 2020, 2:42 PM