Home | History | Annotate | Line # | Download | only in librt
pset.3 revision 1.1
 $NetBSD: pset.3,v 1.1 2008/03/10 19:00:21 rmind Exp $

Copyright (c) 2008 The NetBSD Foundation, Inc.
All rights reserved.

This code is derived from software contributed to The NetBSD Foundation
by Mindaugas Rasiukevicius <rmind at NetBSD org>.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:
1. Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
3. All advertising materials mentioning features or use of this software
must display the following acknowledgement:
This product includes software developed by the NetBSD
Foundation, Inc. and its contributors.
4. Neither the name of The NetBSD Foundation nor the names of its
contributors may be used to endorse or promote products derived
from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.

.Dd March 10, 2008 .Dt PSET 3 .Os .Sh NAME .Nm pset_create , .Nm pset_assign , .Nm pset_bind , .Nm pset_destroy .Nd processor sets .Sh SYNOPSIS n sys/pset.h .Ft int .Fn pset_create "psetid_t *psid" .Ft int .Fn pset_assign "psetid_t psid" "cpuid_t cpuid" "psetid_t *opsid" .Ft int .Fn pset_bind "psetid_t psid" "idtype_t type" "id_t id" "psetid_t *opsid" .Ft int .Fn pset_destroy "psetid_t psid" .Sh DESCRIPTION The processor sets API provides the possibility to bind processes or threads to specific processors or groups of processors. This section describes the functions used to control processor sets. .Ss FUNCTIONS l -tag -width compact t Fn pset_create psid Creates a processor set, and returns its ID into .Fa psid . t Fn pset_assign psid cpu opsid Assigns the processor specified by .Fa cpuid to the processor set specified by .Fa psid . Stores the current processor set ID of the processor or .Dv PS_NONE into .Fa opsid , if the pointer is not .Dv NULL .

p If .Fa psid is set to .Dv PS_QUERY , then the current processor set ID will be returned into .Fa psid , and no assignment will be performed.

p If .Fa psid is set to .Dv PS_MYID , then the processor set ID of the calling process will be used, and .Fa psid will be ignored.

p If .Fa psid is set to .Dv PS_NONE , any assignment to the processor will be cleared. t Fn pset_bind psid type id opsid Binds the target specified by .Fa id to the processor set specified by .Fa psid . The current processor set ID to which the target is bound or .Dv PS_NONE will be returned in .Fa opsid , if the pointer is not .Dv NULL . .Nx supports the following types of targets specified by .Fa type : l -tag -width P_PID t Dv P_PID Process identified by the PID. t Dv P_LWPID Thread of the calling process indentified by the LID. .El

p If .Fa psid is set to .Dv PS_QUERY , then the current processor set ID to which the target is bound or .Dv PS_NONE will be returned in .Fa opsid , and no binding will be performed. If .Fa psid is set to .Dv PS_MYID , then the processor set ID of the calling process will be used.

p If .Fa psid is set to .Dv PS_NONE , the specified target will be unbound from the processor set. t Fn pset_destroy psid Destroys the processor set specified by .Fa psid . Before destroying the processor set, all related assignments of the processors will be cleared, and all bound threads will be unbound.

p If .Fa psid is .Dv PS_MYID , the processor set ID of the caller thread will be used. .El .Ss NOTES The .Fa pset_bind function can return the current processor set ID to which the target is bound, or .Dv PS_NONE . However, for example, the process may have many threads, which could be bound to different processor sets. In such a case it is unspecified which thread will be used to return the information. .Sh RETURN VALUES Upon successful completion these functions return 0. Otherwise, -1 is returned and .Va errno is set to indicate the error. .Sh ERRORS The .Fn pset_create function fails if: l -tag -width Er t Bq Er ENOMEM No memory is available for creation of the processor set, or limit of the allowed count of the processor sets was reached. t Bq Er EPERM The calling process is not the super-user. .El

p The .Fn pset_assign function fails if: l -tag -width Er t Bq Er EBUSY Another operation is performing on the processor set. t Bq Er EINVAL .Fa psid or .Fa cpuid are invalid. t Bq Er EPERM The calling process is not the super-user, and .Fa psid is not .Dv PS_QUERY . .El

p The .Fn pset_bind function fails if: l -tag -width Er t Bq Er EBUSY Another operation is performing on the processor set. t Bq Er EINVAL .Fa psid or .Fa type are invalid. t Bq Er EPERM The calling process is not the super-user, and .Fa psid is not .Dv PS_QUERY . t Bq Er ESRCH The specified target was not found. .El

p The .Fn pset_destroy function fails if: l -tag -width Er t Bq Er EBUSY Another operation is performing on the processor set. t Bq Er EPERM The calling process is not the super-user. .El .Sh SEE ALSO .Xr sched 3 , .Xr schedctl 8 .Sh HISTORY The processor sets appeared in .Nx 5.0 . .Sh BUGS Currently, these functions are valid and work correctly only with the SCHED_M2 thread scheduler implementation.