


When using the World Model (Section The World Model), a set of attributes that describe the execution environment is attached to the communicator MPI_COMM_WORLD when MPI is initialized. The values of these attributes can be inquired by using the function MPI_COMM_GET_ATTR described in Section Caching and in Section Attributes. It is erroneous to delete these attributes, free their keys, or change their values.
The list of predefined attribute keys include
These predefined attributes do not change value between MPI initialization ( MPI_INIT) and MPI completion ( MPI_FINALIZE), and cannot be updated or deleted by users.
 
 
 
 Advice to users.  
 
Note that in the C binding, the value returned by these attributes is a   
 pointer to an  int containing the requested value.  
 ( End of advice to users.) 
 
The required parameter values are discussed in more detail below:  






Tag values range from 0 to the value returned for MPI_TAG_UB, inclusive. These values are guaranteed to be unchanging during the execution of an MPI program. In addition, the tag upper bound value must be at least 32767. An MPI implementation is free to make the value of MPI_TAG_UB larger than this; for example, the value 230-1 is also a valid value for MPI_TAG_UB.
In the Sessions Model, the attribute MPI_TAG_UB is attached to all communicators created by MPI_COMM_CREATE_FROM_GROUP and MPI_INTERCOMM_CREATE_FROM_GROUPS, with the same value on all MPI processes in the communicator. In the World Model, the attribute MPI_TAG_UB has the same value on all MPI processes of MPI_COMM_WORLD.






The value returned for MPI_IO is the rank of an MPI process that can provide language-standard I/O facilities. For Fortran, this means that all of the Fortran I/O operations are supported (e.g., OPEN, REWIND, WRITE). For C, this means that all of the ISO C I/O operations are supported (e.g., fopen, fprintf, lseek).
If every MPI process can provide language-standard I/O, then the value MPI_ANY_SOURCE will be returned. Otherwise, if the calling MPI process can provide language-standard I/O its rank in the group of the communicator will be returned. Otherwise, if some MPI process can provide language-standard I/O then the rank of one such MPI process in the group of the communicator will be returned. The same value need not be returned by all MPI processes. If no MPI process can provide language-standard I/O, then the value MPI_PROC_NULL will bereturned.
 
 
 
 Advice to users.  
 
Note that input is not collective, and this attribute does  not indicate  
which  MPI process can or does provide input.  
 ( End of advice to users.) 
 






The value returned for MPI_WTIME_IS_GLOBAL is 1 if clocks at all MPI processes in MPI_COMM_WORLD are synchronized, 0 otherwise. A collection of clocks is considered synchronized if explicit effort has been taken to synchronize them. The expectation is that the variation in time, as measured by calls to MPI_WTIME, will be less then one half the round-trip time for an MPI message of length zero. If time is measured at an MPI process just before a send and at another MPI process just after a matching receive, the second time should be always higher than the first one.
The attribute MPI_WTIME_IS_GLOBAL need not be present when the clocks are not synchronized (however, the attribute key MPI_WTIME_IS_GLOBAL is always valid). This attribute may be associated with communicators other then MPI_COMM_WORLD.
The attribute MPI_WTIME_IS_GLOBAL has the same value on all MPI processes of MPI_COMM_WORLD.






| MPI_GET_PROCESSOR_NAME(name, resultlen) | |
| OUT name | A unique specifier for the actual (as opposed to virtual) node. | 
| OUT resultlen | Length (in printable characters) of the result returned in name | 
This routine returns the name of the processor on which it was called at the moment of the call. The name is a character string for maximum flexibility. From this value it must be possible to identify a specific piece of hardware; possible values include ``processor 9 in rack 4 of mpp.cs.org'' and ``231'' (where 231 is the actual processor number in the running homogeneous system). The argument name must represent storage that is at least MPI_MAX_PROCESSOR_NAME characters long. MPI_GET_PROCESSOR_NAME may write up to this many characters into name.
The number of characters actually written is returned in the output argument, resultlen. In C, a null character is additionally stored at name[resultlen]. The value of resultlen cannot be larger than MPI_MAX_PROCESSOR_NAME-1. In Fortran, name is padded on the right with blank characters. The value of resultlen cannot be larger than MPI_MAX_PROCESSOR_NAME.
 
 
 
 Rationale.  
 
This function allows  MPI implementations that do process  
migration to return the current processor.  Note that nothing in  MPI   
 requires or defines process migration; this definition of  
 MPI_GET_PROCESSOR_NAME simply allows such an implementation.  
 ( End of rationale.) 
 
 
 
 Advice to users.  
 
The user must provide at least  MPI_MAX_PROCESSOR_NAME space  
to write the processor name---processor names can be this long.  The user  
should examine the   
output   
argument,  resultlen, to determine  
the actual length of the name.  
 ( End of advice to users.) 
 






| MPI_GET_HW_RESOURCE_INFO(hw_info) | |
| OUT hw_info | info object created (handle) | 
MPI_GET_HW_RESOURCE_INFO is a local procedure that returns an info object containing information pertaining to the hardware platform on which the calling MPI process is executing at the moment of the call. This information is stored as ( key, value) pairs where each key is the name of a hardware resource type and its value is set to true if the calling MPI process is restricted to a single instance of a hardware resource of that type and false otherwise. The order in which the keys are stored in hw_info is unspecified. This procedure will return different information for MPI processes that are restricted to different hardware resources. Otherwise, info objects with identical ( key, value) pairs are returned. The user is responsible for freeing hw_info via MPI_INFO_FREE.
 
 
 
 Advice to users.  
 
The information returned in the info object might reflect the ``hardware'' resources presented to the application by  
  a virtualized environment and may be restricted by access permissions or other constraints like environment  
  variables and OS settings.  
 ( End of advice to users.) 
 
The keys stored in the  hw_info object have a  Uniform Resource Identifier (URI) format.  
The first part of the URI indicates the key provider and the second part conforms to the format used by  
this key provider. The key provider  "mpi://" is reserved for exclusive use by the  MPI standard.  
 
 
 
 Advice  
        to implementors.  
 
Key provider names could be derived from  MPI implementation names (e.g.,  "mpich://",  "openmpi://"),  
  from names of external libraries or pieces of software (e.g.,  "hwloc://",  "pmix://"), from names  
  of programming or execution models (e.g.,  "openmp://"), from resource manager names (e.g.,  "slurm://")  
  or from hardware vendor names.  
 ( End of advice to implementors.) 
 
 
 
 Advice to users.  
Users should be cautious when using such keys because comparisons between different providers may not be always meaningful or relevant. Also, the same hardware resource can be listed by multiple providers under different names.
One provider could convey types that represent individual hardware resource instances---for example, "provider_1://core/FF53C8A9" or "provider_1://numanode/2"---while another provider could provide types that represent categories or locations of hardware resources---for example, "provider_2://core" or "provider_2://numanode".
 
It is anticipated that types that represent categories  
  or locations will be more useful for  MPI_COMM_SPLIT_TYPE  
  than types that represent individual resources.  
 ( End of advice to users.) 
 
 
 
 Advice to users.  
  
 
The keys stored in the info object returned by this procedure can be used in  
   MPI_COMM_SPLIT_TYPE with the   split_type value   MPI_COMM_TYPE_HW_GUIDED  
  or  MPI_COMM_TYPE_RESOURCE_GUIDED as key  values for the info key  mpi_hw_resource_type.  
 ( End of advice to users.) 
 
Subsequent calls to  MPI_GET_HW_RESOURCE_INFO may return different information throughout the execution  
of the program because an  MPI process can be relocated (e.g., migrated or have its hardware restrictions changed).  
 
 Example  
  
 Splitting  MPI_COMM_WORLD into subcommunicators according to  
 NUMANode from the hwloc provider.  
 
  MPI_Info hw_info; 
  MPI_Comm hw_comm; 
  int      nb_keys  = 0, flag = 0; 
  int      is_found = 0, is_restricted = 0;  
  int      valuelen = 6; // max length between "false" and "true" + 1  
  char    *value    = calloc(valuelen, sizeof(char)); 
  char    *hw_type  = calloc((MPI_MAX_INFO_KEY+1), sizeof(char)); 
   
  MPI_Get_hw_resource_info(&hw_info); 
   
  MPI_Info_get_nkeys(hw_info, &nb_keys);   
  for(int index = 0 ; index < nb_keys ; index++){ 
    MPI_Info_get_nthkey(hw_info, index, hw_type); 
    MPI_Info_get_string(hw_info, hw_type, &valuelen, value, &flag);      
    if(strcmp(hw_type, "hwloc://NUMANode") == 0){ 
      is_found = 1; 
      if(strcmp(value,"true") == 0) 
        is_restricted = 1; 
      break; // Resource of type NUMANode found 
    } 
  } 
 
  // The calling MPI process is restricted to a resource 
  // of the chosen type (NUMANode) 
  if(is_found  && is_restricted){ 
    MPI_Info split_info; 
    int rank; 
     
    MPI_Info_create(&split_info); 
     
    // hw_type now serves as value for the "mpi_hw_resource_type" key 
    MPI_Info_set(split_info, "mpi_hw_resource_type", hw_type); 
 
    MPI_Comm_rank(MPI_COMM_WORLD, &rank); 
    MPI_Comm_split_type(MPI_COMM_WORLD, MPI_COMM_TYPE_RESOURCE_GUIDED, 
                        rank, split_info, &hw_comm); 
 
    // Check and use hw_comm from this point if it's a valid 
    // communicator or different from MPI_COMM_SELF or MPI_COMM_WORLD. 
  } else { 
    // If resource is not found or not restricted to it, 
    // the calling MPI process does not participate to the call 
    // hence the use of MPI_UNDEFINED as split_type and     
    // MPI_COMM_NULL is produced as output communicator 
     
    MPI_Comm_split_type(MPI_COMM_WORLD, MPI_UNDEFINED, 
                        -1, MPI_INFO_NULL, &hw_comm);        
  }   
 
  
  


