NAME¶
get_mempolicy - retrieve NUMA memory policy for a process
SYNOPSIS¶
#include <numaif.h>
int get_mempolicy(int *mode, unsigned long *nodemask,
unsigned long maxnode, unsigned long addr,
unsigned long flags);
Link with -lnuma.
DESCRIPTION¶
get_mempolicy() retrieves the NUMA policy of the calling process or of a
memory address, depending on the setting of
flags.
A NUMA machine has different memory controllers with different distances to
specific CPUs. The memory policy defines from which node memory is allocated
for the process.
If
flags is specified as 0, then information about the calling process's
default policy (as set by
set_mempolicy(2)) is returned. The policy
returned [
mode and
nodemask] may be used to restore the
process's policy to its state at the time of the call to
get_mempolicy() using
set_mempolicy(2).
If
flags specifies
MPOL_F_MEMS_ALLOWED (available since Linux
2.6.24), the
mode argument is ignored and the set of nodes [memories]
that the process is allowed to specify in subsequent calls to
mbind(2)
or
set_mempolicy(2) [in the absence of any
mode flags] is
returned in
nodemask. It is not permitted to combine
MPOL_F_MEMS_ALLOWED with either
MPOL_F_ADDR or
MPOL_F_NODE.
If
flags specifies
MPOL_F_ADDR, then information is returned about
the policy governing the memory address given in
addr. This policy may
be different from the process's default policy if
mbind(2) or one of
the helper functions described in
numa(3) has been used to establish a
policy for the memory range containing
addr.
If the
mode argument is not NULL, then
get_mempolicy() will store
the policy mode and any optional
mode flags of the requested NUMA
policy in the location pointed to by this argument. If
nodemask is not
NULL, then the nodemask associated with the policy will be stored in the
location pointed to by this argument.
maxnode specifies the number of
node IDs that can be stored into
nodemask—that is, the maximum
node ID plus one. The value specified by
maxnode is always rounded to a
multiple of
sizeof(unsigned long).
If
flags specifies both
MPOL_F_NODE and
MPOL_F_ADDR,
get_mempolicy() will return the node ID of the node on which the
address
addr is allocated into the location pointed to by
mode.
If no page has yet been allocated for the specified address,
get_mempolicy() will allocate a page as if the process had performed a
read [load] access to that address, and return the ID of the node where that
page was allocated.
If
flags specifies
MPOL_F_NODE, but not
MPOL_F_ADDR, and
the process's current policy is
MPOL_INTERLEAVE, then
get_mempolicy() will return in the location pointed to by a non-NULL
mode argument, the node ID of the next node that will be used for
interleaving of internal kernel pages allocated on behalf of the process.
These allocations include pages for memory-mapped files in process memory
ranges mapped using the
mmap(2) call with the
MAP_PRIVATE flag
for read accesses, and in memory ranges mapped with the
MAP_SHARED flag
for all accesses.
Other flag values are reserved.
For an overview of the possible policies see
set_mempolicy(2).
RETURN VALUE¶
On success,
get_mempolicy() returns 0; on error, -1 is returned and
errno is set to indicate the error.
ERRORS¶
- EFAULT
- Part of all of the memory range specified by nodemask and
maxnode points outside your accessible address space.
- EINVAL
- The value specified by maxnode is less than the number of node IDs
supported by the system. Or flags specified values other than
MPOL_F_NODE or MPOL_F_ADDR; or flags specified
MPOL_F_ADDR and addr is NULL, or flags did not
specify MPOL_F_ADDR and addr is not NULL. Or, flags
specified MPOL_F_NODE but not MPOL_F_ADDR and the current
process policy is not MPOL_INTERLEAVE. Or, flags specified
MPOL_F_MEMS_ALLOWED with either MPOL_F_ADDR or
MPOL_F_NODE. (And there are other EINVAL cases.)
VERSIONS¶
The
get_mempolicy() system call was added to the Linux kernel in version
2.6.7.
This system call is Linux-specific.
NOTES¶
For information on library support, see
numa(7).
SEE ALSO¶
getcpu(2),
mbind(2),
mmap(2),
set_mempolicy(2),
numa(3),
numa(7),
numactl(8)
COLOPHON¶
This page is part of release 3.74 of the Linux
man-pages project. A
description of the project, information about reporting bugs, and the latest
version of this page, can be found at
http://www.kernel.org/doc/man-pages/.