Enumerations | |
enum | hwloc_cpubind_policy_t { HWLOC_CPUBIND_PROCESS, HWLOC_CPUBIND_THREAD, HWLOC_CPUBIND_STRICT } |
Process/Thread binding policy. More... | |
Functions | |
HWLOC_DECLSPEC int | hwloc_set_cpubind (hwloc_topology_t topology, hwloc_const_cpuset_t set, int policy) |
Bind current process or thread on cpus given in cpuset set . | |
HWLOC_DECLSPEC int | hwloc_get_cpubind (hwloc_topology_t topology, hwloc_cpuset_t set, int policy) |
Get current process or thread binding. | |
HWLOC_DECLSPEC int | hwloc_set_proc_cpubind (hwloc_topology_t topology, hwloc_pid_t pid, hwloc_const_cpuset_t set, int policy) |
Bind a process pid on cpus given in cpuset set . | |
HWLOC_DECLSPEC int | hwloc_get_proc_cpubind (hwloc_topology_t topology, hwloc_pid_t pid, hwloc_cpuset_t set, int policy) |
Get the current binding of process pid . | |
HWLOC_DECLSPEC int | hwloc_set_thread_cpubind (hwloc_topology_t topology, hwloc_thread_t tid, hwloc_const_cpuset_t set, int policy) |
Bind a thread tid on cpus given in cpuset set . | |
HWLOC_DECLSPEC int | hwloc_get_thread_cpubind (hwloc_topology_t topology, hwloc_thread_t tid, hwloc_cpuset_t set, int policy) |
Get the current binding of thread tid . |
It is often useful to call hwloc_cpuset_singlify() first so that a single CPU remains in the set. This way, the process will not even migrate between different CPUs. Some OSes also only support that kind of binding.
The most portable version that should be preferred over the others, whenever possible, is
hwloc_set_cpubind(topology, set, 0),
as it just binds the current program, assuming it is monothread, or
hwloc_set_cpubind(topology, set, HWLOC_CPUBIND_THREAD),
which binds the current thread of the current program (which may be multithreaded).
Process/Thread binding policy.
These flags can be used to refine the binding policy.
The default (0) is to bind the current process, assumed to be mono-thread, in a non-strict way. This is the most portable way to bind as all OSes usually provide it.
HWLOC_DECLSPEC int hwloc_get_cpubind | ( | hwloc_topology_t | topology, | |
hwloc_cpuset_t | set, | |||
int | policy | |||
) |
Get current process or thread binding.
HWLOC_DECLSPEC int hwloc_get_proc_cpubind | ( | hwloc_topology_t | topology, | |
hwloc_pid_t | pid, | |||
hwloc_cpuset_t | set, | |||
int | policy | |||
) |
Get the current binding of process pid
.
policy
. HWLOC_DECLSPEC int hwloc_get_thread_cpubind | ( | hwloc_topology_t | topology, | |
hwloc_thread_t | tid, | |||
hwloc_cpuset_t | set, | |||
int | policy | |||
) |
Get the current binding of thread tid
.
policy
. HWLOC_DECLSPEC int hwloc_set_cpubind | ( | hwloc_topology_t | topology, | |
hwloc_const_cpuset_t | set, | |||
int | policy | |||
) |
Bind current process or thread on cpus given in cpuset set
.
HWLOC_DECLSPEC int hwloc_set_proc_cpubind | ( | hwloc_topology_t | topology, | |
hwloc_pid_t | pid, | |||
hwloc_const_cpuset_t | set, | |||
int | policy | |||
) |
Bind a process pid
on cpus given in cpuset set
.
policy
. HWLOC_DECLSPEC int hwloc_set_thread_cpubind | ( | hwloc_topology_t | topology, | |
hwloc_thread_t | tid, | |||
hwloc_const_cpuset_t | set, | |||
int | policy | |||
) |
Bind a thread tid
on cpus given in cpuset set
.
policy
.