NAME
— domainset functions and operationSYNOPSIS
#include <sys/_domainset.h>#include <sys/domainset.h>
struct domainset { domainset_t ds_mask; uint16_t ds_policy; domainid_t ds_prefer; ... };
struct domainset *
DOMAINSET_FIXED(domain); struct domainset *
DOMAINSET_RR(); struct domainset *
DOMAINSET_PREF(domain); struct domainset *
domainset_create(const struct domainset *key); int
sysctl_handle_domainset(SYSCTL_HANDLER_ARGS);
DESCRIPTION
The API provides memory domain allocation policy for NUMA machines. Each domainset contains a bitmask of allowed domains, an integer policy, and an optional preferred domain. Together, these specify a search order for memory allocations as well as the ability to restrict threads and objects to a subset of available memory domains for system partitioning and resource management. Every thread in the system and optionally every vm_object_t, which is used to represent files and other memory sources, has a reference to a struct domainset. The domainset associated with the object is consulted first and the system falls back to the thread policy if none exists. The allocation policy has the following possible values:DOMAINSET_POLICY_ROUNDROBIN
- Memory is allocated from each domain in the mask in a round-robin fashion. This distributes bandwidth evenly among available domains. This policy can specify a single domain for a fixed allocation.
DOMAINSET_POLICY_FIRSTTOUCH
- Memory is allocated from the node that it is first accessed on. Allocation falls back to round-robin if the current domain is not in the allowed set or is out of memory. This policy optimizes for locality but may give pessimal results if the memory is accessed from many CPUs that are not in the local domain.
DOMAINSET_POLICY_PREFER
- Memory is allocated from the node in the prefer member. The preferred node must be set in the allowed mask. If the preferred node is out of memory the allocation falls back to round-robin among allowed sets.
DOMAINSET_POLICY_INTERLEAVE
- Memory is allocated in a striped fashion with multiple pages allocated to each domain in the set according to the offset within the object. The strip width is object dependent and may be as large as a super-page (2MB on amd64). This gives good distribution among memory domains while keeping system efficiency higher and is preferential to round-robin for general use.
M_WAITOK
request. The
domainset_create() function takes a partially
filled in domainset as a key and returns a valid domainset or NULL. It is
critical that consumers not use domainsets that have not been returned by this
function. domainset is an immutable type that is shared among all matching
keys and must not be modified after return.
The sysctl_handle_domainset() function is provided
as a convenience for modifying or viewing domainsets that are not accessible
via cpuset(2). It is intended for use with
sysctl(9).
SEE ALSO
cpuset(1), cpuset(2), cpuset_setdomain(2), bitset(9)HISTORY
<sys/domainset.h> first appeared in FreeBSD 12.0.October 30, 2018 | Debian |