Page MenuHomeFreeBSD

cpuset_setdomain(2): Ensure that the set is a subset of all_domains.
ClosedPublic

Authored by markj on Aug 30 2019, 8:24 PM.
Tags
None
Referenced Files
F153271371: D21477.id61491.diff
Mon, Apr 20, 4:24 AM
F153263349: D21477.id.diff
Mon, Apr 20, 3:23 AM
Unknown Object (File)
Sat, Apr 18, 9:59 AM
Unknown Object (File)
Wed, Apr 15, 8:42 PM
Unknown Object (File)
Tue, Apr 14, 7:29 PM
Unknown Object (File)
Tue, Apr 14, 2:27 PM
Unknown Object (File)
Tue, Apr 14, 6:30 AM
Unknown Object (File)
Mon, Apr 6, 1:32 PM
Subscribers

Details

Summary

Userspace is allowed to provide a mask of up to 256 bits. In the
kernel, the domain mask is 64 bits wide even though MAXMEMDOM is 8.
cpuset_setdomain() returns EINVAL if any bits beyond the first 64 are
set; go further and return an error if any bits outside of
all_domains are set.

domainset_empty_vm() assumes that the input set is a subset of
all_domains, since it iterates over the set and populates the ds_order
table. The problem became more noticeable after r351547.

We could instead silently mask off bits that are not present in
all_domains. However, since we already check for domain IDs >= 64
and return EINVAL if any are present, I don't see why we should
be inconsistent for domain IDs < 64.

Test Plan

Peter reported the bug and tested an earlier version of the patch.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 26197
Build 24702: arc lint + arc unit