Page MenuHomeFreeBSD

[1/2] kern: cpuset: allow cpuset_create() to take an allocated *setp
ClosedPublic

Authored by kevans on Nov 20 2020, 7:53 PM.
Tags
None
Referenced Files
F107098359: D27297.diff
Fri, Jan 10, 2:20 AM
Unknown Object (File)
Fri, Jan 3, 9:10 AM
Unknown Object (File)
Sat, Dec 21, 4:02 PM
Unknown Object (File)
Thu, Dec 19, 7:05 AM
Unknown Object (File)
Dec 1 2024, 10:35 PM
Unknown Object (File)
Dec 1 2024, 10:35 PM
Unknown Object (File)
Dec 1 2024, 10:34 PM
Unknown Object (File)
Dec 1 2024, 9:44 PM
Subscribers

Details

Summary

Currently, it must always allocate a new set to be used for passing to _cpuset_create, but it doesn't have to. This is purely kern_cpuset.c internal and it's sparsely used, so just change it to use *setp if it's not-NULL and modify the two consumers to pass in the address of a NULL cpuset.

This paves the way for consumers that want the unr allocation without the possibility of sleeping as long as they've done their due diligence to ensure that the mask will properly apply atop the supplied parent (i.e. avoiding the free_unr() in the last failure path).

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable