| 
|  | pthread_use_only_cpu(3)Contents |  
        pthread_use_only_cpu  - Restricts a thread to running only
       on the specified CPU. If that CPU is unavailable  for  any
       reason, the thread will not run
       #include <cpuset.h> #include <sys/types.h>
       int pthread_use_only_cpu(
               pthread_t thread,
               cpuid_t cpu_id,
               long flag );
       DECthreads POSIX 1003.1c Library (libpthread.so)
        Thread  to  be  restricted  to use only the specified CPU.
       Currently only PTHREAD_BINDCPU_INFLEXIBLE is defined,  and
       must be specified.
       This  routine  restricts  thread to cpu_id, preventing the
       thread  from  utilizing  any  other  available   processor
       resources  even  when  cpu_id  may be busy for an extended
       time with other work or is otherwise unavailable.
       This function can be  used  only  with  System  Contention
       Scope  (SCS)  threads,  that is, threads that were created
       using an attributes object with the scope attribute set to
       PTHREAD_SCOPE_SYSTEM.
       Specifying a cpu_id value of CPU_NONE removes the restriction
 from the thread, allowing it to again take  advantage
       of  any available CPU when the CPU on which it last ran is
       busy.
       cpu_id will become unavailable if the corresponding CPU is
       removed  from  the  processor  set in which the process is
       running or if it is taken off-line.  In  this  event,  any
       thread  that  is  restricted  to cpu_id will not run until
       pthread_use_only_cpu is  called  from  another  thread  to
       change or remove the thread's restriction.
       Threads  that  have  not been restricted to a specific CPU
       using this function are typically scheduled to run on  the
       CPU  they  last  used, in order to take advantage of valid
       cache and translation buffer  (TB)  entries.  However,  if
       that  CPU  remains  busy  with other work, the threads may
       instead be run on another CPU if available.  This  default
       behavior is the most effective except in extremely unusual
       circumstances, so this function should be used  only  with
       great caution.  Improper use of this function can substantially
 degrade application performance;  proper  use  will
       rarely improve performance measurably (if at all).
       This routine does not prevent cpu_id from performing other
       work. Restricting a thread to a CPU is  rarely  beneficial
       to  an  application since other threads of equal or higher
       priority may be run by cpu_id, and, in  addition  to  preventing
  thread  from executing, this activity will likely
       invalidate cache and TB entries used  by  thread,  thereby
       removing the principal advantages of having restricted the
       thread. Furthermore, giving a thread a very high  priority
       is  not  sufficient  to  guarantee  exclusive use of a CPU
       since page faults, interrupts, or blocking system calls of
       even  very  short  duration  can  permit  other threads to
       obtain the CPU. To obtain exclusive use of a CPU, see  the
       processor_sets(4) reference page.
       If an error condition occurs, the target thread's scheduling
  restrictions  remain  unchanged,  and  this   routine
       returns  an  integer  value  indicating the type of error.
       Possible return values are as follows: Successful  completion.
   The  value  specified by cpu_id is invalid, or the
       flag is invalid.  The specified thread is a  Process  Contention
  Scope  thread.   The  specified  thread  does not
       exist.
       None
 
       Functions:    pthread_create(3),     pthread_attr_init(3),
       pthread_attr_setscope(3),              pthread_rad_bind(3)
       pthread_rad_attach(3), processor_sets(3)
       Manuals: Guide to DECthreads and Programmer's Guide
                                          pthread_use_only_cpu(3)
[ Back ] |