| 
|  | pthread_rad_attach(3)Contents |  
        pthread_rad_attach, pthread_rad_bind - Attaches or binds a
       thread to a  NUMA  Resource  Affinity  Domain  (libpthread
       library)
       #include <numa.h>
       int pthread_rad_attach(
               pthread_t thread,
               radset_t radset,
               ulong_t flags ); int pthread_rad_bind(
               pthread_t thread,
               radset_t radset,
               ulong_t flags );
       Identifies the thread to be attached or bound to the specified
 set of Resource Affinity Domains (RADs).  Identifies
       the  RAD  set  to  which  the  thread is to be attached or
       bound.
       The  pthread_rad_attach()  function  attaches  the  thread
       specified  by the thread argument to the RAD set specified
       by the radset argument.
       The pthread_rad_bind() function binds the specified thread
       to the specified RAD set.
       While  both functions assign a home RAD for the thread, an
       attach operation allows remote  execution  on  other  RADs
       while  a  bind  operation  restricts execution to the home
       RAD. In the following paragraphs,  the  term  "assign"  is
       used  when  the  description  refers  equally  to both the
       attach and the bind operations.
       The home RAD for the thread will be selected by the system
       scheduler  from among the RADs included in radset based on
       current system load balance and the  flags  argument.  The
       overflow  set (mattr_radset) for the thread will be set to
       radset.
       The following symbolic values are defined  for  the  flags
       argument: The requested assignments are mandatory. If this
       option is not set, the system will consider the request to
       be  a  "hint"  and  may  take  no action for the specified
       thread.  The thread has small memory requirements, so  the
       system  should  (for  the  home RAD) favor those RADs with
       light CPU loads, independent of  their  available  memory.
       The  thread  has  large memory requirements, so the system
       should (for the home  RAD)  favor  those  RADs  with  more
       available memory, independent of their CPU loads.
       If the caller does not have partition administration privilege
 and if the radset argument contains  RADs  that  are
       not  in the caller's partition, an error will be returned.
       The value for the radset argument could be  obtained  from
       an  nloc()  call to assign or migrate the process to a RAD
       close (or closer) to a particular resource. When  obtained
       in  this  manner, the radset value will identify RADs that
       were in the caller's partition at the time of  the  nloc()
       call. The partition configuration could change between the
       call   to   nloc()    and    a    subsequent    call    to
       pthread_rad_attach(),  resulting  in an error. An application
 should be prepared to handle this error, even  though
       it should not be a frequent occurrence.
       Success.   Failure.  In this case, the integer value indicates
 the type of error. Possible errors are  as  follows:
       The  thread  is  hard attached (RAD_INSIST) to RADs or has
       memory wired (locked) on its current RAD such that it cannot
  be migrated to the specified RAD set.  One of more of
       the RADs in the radset argument or options  in  the  flags
       argument  are  invalid.   RAD_INSIST  and RAD_MIGRATE were
       specified, and  the  thread  cannot  be  migrated  because
       insufficient  memory  exists  on RADs in the specified RAD
       set.  The caller does not have appropriate  privileges  to
       assign  threads  to  RADs  in  the specified RAD set.  The
       thread specified by thread does not exist.
       None.
 
       Functions: nloc(3), pthread_rad_detach(3)
                                            pthread_rad_attach(3)
[ Back ] |