Page MenuHomeFreeBSD

Mark more nodes as CTLFLAG_MPSAFE or CTLFLAG_NEEDGIANT (M of N)
ClosedPublic

Authored by kaktus on Feb 11 2020, 9:02 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 13, 9:06 AM
Unknown Object (File)
Mon, Jan 13, 8:43 AM
Unknown Object (File)
Mon, Jan 13, 6:42 AM
Unknown Object (File)
Dec 11 2024, 11:54 AM
Unknown Object (File)
Nov 14 2024, 8:10 AM
Unknown Object (File)
Oct 2 2024, 11:24 PM
Unknown Object (File)
Sep 4 2024, 8:29 PM
Unknown Object (File)
Sep 2 2024, 6:14 AM

Details

Summary

r357614 added CTLFLAG_NEEDGIANT to make it easier to find nodes that are still not MPSAFE (or already are but aren’t properly marked). Use it in preparation for a general review of all nodes.
This is non-functional change that adds annotations to SYSCTL_NODE and SYSCTL_PROC nodes using one of the soon-to-be-required flags.

You’re asked for a review based on src/MAINTAINERS entry.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

I believe all sysctls in vmm/ can be safely marked as MPSAFE.

Mark the nodes as MPSAFE.

Again, wait some limited time for somebody from bhyve, then commit.

This revision is now accepted and ready to land.Feb 13 2020, 5:01 PM

Generally looks fine. Only weirdness is having to mark SYSCTL_NODE()'s with MPSAFE. A SYSCTL_NODE without an explicit handler (so handler set to NULL) is inherently MPSAFE, and it'd be nice to adjust the assertions to special case that to avoid adding churn since eventually once al sysctls are safe we will go through and remove all the CTLFLAG_MPSAFE flags.