2005-03-14 20:57:21 +00:00
/*
2005-11-05 19:57:48 +00:00
* Copyright ( c ) 2004 - 2005 The Trustees of Indiana University and Indiana
* University Research and Technology
* Corporation . All rights reserved .
* Copyright ( c ) 2004 - 2005 The University of Tennessee and The University
* of Tennessee Research Foundation . All rights
* reserved .
2005-03-14 20:57:21 +00:00
* Copyright ( c ) 2004 - 2005 High Performance Computing Center Stuttgart ,
* University of Stuttgart . All rights reserved .
2005-03-24 12:43:37 +00:00
* Copyright ( c ) 2004 - 2005 The Regents of the University of California .
* All rights reserved .
2006-07-04 20:12:35 +00:00
* Copyright ( c ) 2006 Cisco Systems , Inc . All rights reserved .
2005-03-14 20:57:21 +00:00
* $ COPYRIGHT $
*
* Additional copyrights may follow
*
* $ HEADER $
*/
# include "orte_config.h"
2008-02-28 01:57:57 +00:00
# include "orte/constants.h"
2005-03-14 20:57:21 +00:00
2009-04-29 00:49:23 +00:00
# ifdef HAVE_STRING_H
# include <string.h>
# endif
2008-06-18 03:15:56 +00:00
# if !ORTE_DISABLE_FULL_SUPPORT
2006-02-12 01:33:29 +00:00
# include "opal/mca/mca.h"
2009-02-14 02:26:12 +00:00
# include "opal/util/output.h"
2006-02-12 01:33:29 +00:00
# include "opal/mca/base/base.h"
# include "opal/mca/base/mca_base_param.h"
2009-08-11 02:51:27 +00:00
# include "opal/mca/paffinity/paffinity.h"
2005-03-14 20:57:21 +00:00
2009-08-11 02:51:27 +00:00
# include "orte/runtime/orte_globals.h"
2006-10-03 17:40:00 +00:00
2006-09-14 21:29:51 +00:00
# include "orte/mca/rmaps/base/rmaps_private.h"
2008-06-18 03:15:56 +00:00
# endif
2006-02-12 01:33:29 +00:00
# include "orte/mca/rmaps/base/base.h"
2005-03-14 20:57:21 +00:00
/*
* The following file was created by configure . It contains extern
* statements and the definition of an array of pointers to each
* component ' s public mca_base_component_t struct .
*/
2005-07-04 18:24:58 +00:00
# include "orte/mca/rmaps/base/static-components.h"
2005-03-14 20:57:21 +00:00
2008-06-18 03:15:56 +00:00
# if ORTE_DISABLE_FULL_SUPPORT
/* have to include a bogus function here so that
* the build system sees at least one function
* in the library
*/
int orte_rmaps_base_open ( void )
{
return ORTE_SUCCESS ;
}
# else
2005-03-14 20:57:21 +00:00
/*
2006-09-14 21:29:51 +00:00
* Global variables
2005-03-14 20:57:21 +00:00
*/
2006-09-14 21:29:51 +00:00
orte_rmaps_base_t orte_rmaps_base ;
2005-03-14 20:57:21 +00:00
/*
2006-09-14 21:29:51 +00:00
* Declare the RMAPS module to hold the API function pointers
2005-03-14 20:57:21 +00:00
*/
2008-02-28 01:57:57 +00:00
orte_rmaps_t orte_rmaps = {
2006-10-07 15:45:24 +00:00
orte_rmaps_base_map_job ,
2008-02-28 01:57:57 +00:00
orte_rmaps_base_get_job_map
2006-09-14 21:29:51 +00:00
} ;
2005-03-14 20:57:21 +00:00
/**
* Function for finding and opening either all MCA components , or the one
* that was specifically requested via a MCA parameter .
*/
int orte_rmaps_base_open ( void )
{
2008-02-28 01:57:57 +00:00
int param , value ;
2006-10-07 15:45:24 +00:00
char * policy ;
2008-09-23 15:46:34 +00:00
bool btmp ;
2005-03-14 20:57:21 +00:00
2008-02-28 01:57:57 +00:00
/* init the globals */
orte_rmaps_base . active_module = NULL ;
/* Debugging / verbose output. Always have stream open, with
verbose set by the mca open system . . . */
2008-06-09 14:53:58 +00:00
orte_rmaps_base . rmaps_output = opal_output_open ( NULL ) ;
2005-03-14 20:57:21 +00:00
2005-10-07 22:24:52 +00:00
/* Are we scheduling by node or by slot? */
2006-07-04 20:12:35 +00:00
param = mca_base_param_reg_string_name ( " rmaps " , " base_schedule_policy " ,
2009-08-11 02:51:27 +00:00
" Scheduling Policy for RMAPS. [slot (default) | socket | board | node] " ,
2007-01-18 17:15:19 +00:00
false , false , " unspec " , & policy ) ;
2006-10-10 19:41:22 +00:00
2009-08-11 02:51:27 +00:00
if ( 0 = = strcmp ( policy , " socket " ) ) {
ORTE_SET_MAPPING_POLICY ( ORTE_MAPPING_BYSOCKET ) ;
} else if ( 0 = = strcmp ( policy , " board " ) ) {
ORTE_SET_MAPPING_POLICY ( ORTE_MAPPING_BYBOARD ) ;
2007-01-18 17:15:19 +00:00
} else if ( 0 = = strcmp ( policy , " node " ) ) {
2009-08-11 02:51:27 +00:00
ORTE_SET_MAPPING_POLICY ( ORTE_MAPPING_BYNODE ) ;
2005-10-07 22:24:52 +00:00
}
2009-08-11 02:51:27 +00:00
/* if nothing was specified, leave it alone - we already set it
* in orterun
*/
2005-10-07 22:24:52 +00:00
2009-08-11 02:51:27 +00:00
/* check for procs/xxx directives */
2006-10-07 19:50:12 +00:00
param = mca_base_param_reg_int_name ( " rmaps " , " base_pernode " ,
2006-12-12 00:54:05 +00:00
" Launch one ppn as directed " ,
false , false , ( int ) false , & value ) ;
2009-08-11 02:51:27 +00:00
if ( value ) {
2008-02-28 01:57:57 +00:00
orte_rmaps_base . npernode = 1 ;
2009-08-11 02:51:27 +00:00
}
/* #procs/node */
param = mca_base_param_reg_int_name ( " rmaps " , " base_n_pernode " ,
" Launch n procs/node " ,
false , false , - 1 , & value ) ;
if ( 0 < value ) {
2008-02-28 01:57:57 +00:00
orte_rmaps_base . npernode = value ;
2006-10-07 19:50:12 +00:00
}
2009-08-11 02:51:27 +00:00
/* #procs/board */
param = mca_base_param_reg_int_name ( " rmaps " , " base_n_perboard " ,
" Launch n procs/board " ,
false , false , - 1 , & orte_rmaps_base . nperboard ) ;
if ( 0 < orte_rmaps_base . nperboard ) {
ORTE_ADD_MAPPING_POLICY ( ORTE_MAPPING_NPERXXX ) ;
}
/* #procs/socket */
param = mca_base_param_reg_int_name ( " rmaps " , " base_n_persocket " ,
" Launch n procs/socket " ,
false , false , - 1 , & orte_rmaps_base . npersocket ) ;
if ( 0 < orte_rmaps_base . npersocket ) {
ORTE_ADD_MAPPING_POLICY ( ORTE_MAPPING_NPERXXX ) ;
2009-09-22 15:41:03 +00:00
/* force bind to socket */
ORTE_SET_BINDING_POLICY ( ORTE_BIND_TO_SOCKET ) ;
2009-08-11 02:51:27 +00:00
}
/* Do we want to loadbalance the job */
param = mca_base_param_reg_int_name ( " rmaps " , " base_loadbalance " ,
" Balance total number of procs across all allocated nodes " ,
false , false , ( int ) false , & value ) ;
orte_rmaps_base . loadbalance = OPAL_INT_TO_BOOL ( value ) ;
/* #cpus/rank to use */
param = mca_base_param_reg_int_name ( " rmaps " , " base_cpus_per_rank " ,
" Number of cpus to use for each rank [1-2**15 (default=1)] " ,
2009-08-30 14:30:36 +00:00
false , false , 1 , NULL ) ;
mca_base_param_reg_syn_name ( param , " rmaps " , " base_cpus_per_rank " , false ) ;
mca_base_param_lookup_int ( param , & value ) ;
2009-08-11 02:51:27 +00:00
orte_rmaps_base . cpus_per_rank = value ;
2009-08-26 02:01:49 +00:00
/* if the cpus/rank > 1, then we have to bind to cores UNLESS the binding has
* already been set to something else
*/
2009-08-11 02:51:27 +00:00
if ( 1 < orte_rmaps_base . cpus_per_rank ) {
2009-08-26 02:01:49 +00:00
ORTE_XSET_BINDING_POLICY ( ORTE_BIND_TO_CORE ) ;
2009-08-11 02:51:27 +00:00
}
/* stride to use */
param = mca_base_param_reg_int_name ( " rmaps " , " base_stride " ,
" When binding multiple cores to a rank, the step size to use between cores [1-2**15 (default: 1)] " ,
false , false , 1 , & value ) ;
orte_rmaps_base . stride = value ;
2008-07-28 14:18:36 +00:00
/* did the user provide a slot list? */
param = mca_base_param_reg_string_name ( " rmaps " , " base_slot_list " ,
" List of processor IDs to bind MPI processes to (e.g., used in conjunction with rank files) [default=NULL] " ,
false , false , NULL , & orte_rmaps_base . slot_list ) ;
2009-08-13 16:08:43 +00:00
/* ensure we flag mapping by user */
if ( NULL ! = orte_rmaps_base . slot_list | |
NULL ! = orte_rankfile ) {
ORTE_ADD_MAPPING_POLICY ( ORTE_MAPPING_BYUSER ) ;
}
2006-07-04 20:12:35 +00:00
/* Should we schedule on the local node or not? */
2007-03-24 16:16:16 +00:00
mca_base_param_reg_int_name ( " rmaps " , " base_no_schedule_local " ,
" If false, allow scheduling MPI applications on the same node as mpirun (default). If true, do not schedule any MPI applications on the same node as mpirun " ,
false , false , ( int ) false , & value ) ;
2008-04-09 22:10:53 +00:00
if ( value ) {
2009-08-11 02:51:27 +00:00
orte_default_mapping_policy | = ORTE_MAPPING_NO_USE_LOCAL ;
2008-04-09 22:10:53 +00:00
}
2006-07-04 20:12:35 +00:00
2006-07-10 14:10:21 +00:00
/* Should we oversubscribe or not? */
2008-02-28 01:57:57 +00:00
/** default condition that allows oversubscription */
2006-07-10 14:10:21 +00:00
mca_base_param_reg_int_name ( " rmaps " , " base_no_oversubscribe " ,
2007-03-24 16:16:16 +00:00
" If true, then do not allow oversubscription of nodes - mpirun will return an error if there aren't enough nodes to launch all processes without oversubscribing " ,
false , false , ( int ) false , & value ) ;
2008-02-28 01:57:57 +00:00
if ( value ) {
2006-07-10 14:10:21 +00:00
orte_rmaps_base . oversubscribe = false ;
2008-02-28 01:57:57 +00:00
} else {
orte_rmaps_base . oversubscribe = true ;
2006-07-10 14:10:21 +00:00
}
2006-11-17 19:06:10 +00:00
/* should we display the map after determining it? */
2007-08-18 03:05:45 +00:00
mca_base_param_reg_int_name ( " rmaps " , " base_display_map " ,
2006-11-17 19:06:10 +00:00
" Whether to display the process map after it is computed " ,
false , false , ( int ) false , & value ) ;
2008-02-28 01:57:57 +00:00
orte_rmaps_base . display_map = OPAL_INT_TO_BOOL ( value ) ;
2006-07-10 14:10:21 +00:00
2008-09-23 15:46:34 +00:00
/* should we display a detailed (developer-quality) version of the map after determining it? */
mca_base_param_reg_int_name ( " rmaps " , " base_display_devel_map " ,
" Whether to display a developer-detail process map after it is computed " ,
false , false , ( int ) false , & value ) ;
btmp = OPAL_INT_TO_BOOL ( value ) ;
if ( btmp ) {
orte_rmaps_base . display_map = true ;
orte_devel_level_output = true ;
}
2005-03-14 20:57:21 +00:00
/* Open up all the components that we can find */
if ( ORTE_SUCCESS ! =
2005-08-15 18:25:35 +00:00
mca_base_components_open ( " rmaps " , orte_rmaps_base . rmaps_output ,
mca_rmaps_base_static_components ,
2008-02-28 01:57:57 +00:00
& orte_rmaps_base . available_components , true ) ) {
2005-03-14 20:57:21 +00:00
return ORTE_ERROR ;
}
/* All done */
return ORTE_SUCCESS ;
}
2008-06-18 03:15:56 +00:00
# endif /* ORTE_DISABLE_FULL_SUPPORT */