0404444dbe
- mca_base_param_file_prefix (Default: NULL) This is the fullname of the "-am" mpirun option. Used to specify a ':' separated list of AMCA parameter set files. - mca_base_param_file_path (Default: $SYSCONFDIR/amca-param-sets/:$CWD) The path to search for AMCA files with relative paths. A warning will be printed if the AMCA file cannot be found. * Added a new function "mca_base_param_recache_files" the re-reads the file configurations. This is used internally to help bootstrap the MCA system. * Added a new orterun/mpirun command line option '-am' that aliases for the mca_base_param_file_prefix MCA parameter * Exposed the opal_path_access function as it is generally useful in other places in the code. * New function "opal_cmd_line_make_opt_mca" which will allow you to append a new command line option with MCA parameter identifiers to set at the same time. Previously this could only be done at command line declaration time. * Added a new directory under the $pkgdatadir named "amca-param-sets" where all the 'shipped with' Open MPI AMCA parameter sets are placed. This is the first place to search for AMCA sets with relative paths. * An example.conf AMCA parameter set file is located in contrib/amca-param-sets/. * Jeff Squyres contributed an OpenIB AMCA set for benchmarking. Note: You will need to autogen with this commit as it adds a configure param. Sorry :( This commit was SVN r13867.
179 строки
4.9 KiB
C
179 строки
4.9 KiB
C
/*
|
|
* 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.
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
* University of Stuttgart. All rights reserved.
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
* All rights reserved.
|
|
* $COPYRIGHT$
|
|
*
|
|
* Additional copyrights may follow
|
|
*
|
|
* $HEADER$
|
|
*/
|
|
|
|
#include "opal_config.h"
|
|
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
#include "opal/util/cmd_line.h"
|
|
#include "opal/util/argv.h"
|
|
#include "opal/util/opal_environ.h"
|
|
#include "opal/mca/base/base.h"
|
|
#include "opal/constants.h"
|
|
|
|
|
|
/*
|
|
* Private variables
|
|
*/
|
|
|
|
/*
|
|
* Private functions
|
|
*/
|
|
static int process_arg(const char *param, const char *value,
|
|
char ***params, char ***values);
|
|
static void add_to_env(char **params, char **values, char ***env);
|
|
|
|
|
|
/*
|
|
* Add -mca to the possible command line options list
|
|
*/
|
|
int mca_base_cmd_line_setup(opal_cmd_line_t *cmd)
|
|
{
|
|
int ret = OPAL_SUCCESS;
|
|
|
|
ret = opal_cmd_line_make_opt3(cmd, '\0', "mca", "mca", 2,
|
|
"Pass context-specific MCA parameters; they are considered global if --gmca is not used and only one context is specified (arg0 is the parameter name; arg1 is the parameter value)");
|
|
if (OPAL_SUCCESS != ret) {
|
|
return ret;
|
|
}
|
|
|
|
ret = opal_cmd_line_make_opt3(cmd, '\0', "gmca", "gmca", 2,
|
|
"Pass global MCA parameters that are applicable to all contexts (arg0 is the parameter name; arg1 is the parameter value)");
|
|
|
|
if (OPAL_SUCCESS != ret) {
|
|
return ret;
|
|
}
|
|
|
|
{
|
|
opal_cmd_line_init_t entry =
|
|
{"mca", "base", "param_file_prefix", '\0', "am", NULL, 1,
|
|
NULL, OPAL_CMD_LINE_TYPE_STRING,
|
|
"Aggregate MCA parameter set file list"
|
|
};
|
|
ret = opal_cmd_line_make_opt_mca(cmd, entry);
|
|
if (OPAL_SUCCESS != ret) {
|
|
return ret;
|
|
}
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
|
|
/*
|
|
* Look for and handle any -mca options on the command line
|
|
*/
|
|
int mca_base_cmd_line_process_args(opal_cmd_line_t *cmd,
|
|
char ***context_env, char ***global_env)
|
|
{
|
|
int i, num_insts;
|
|
char **params;
|
|
char **values;
|
|
|
|
/* If no relevant parameters were given, just return */
|
|
|
|
if (!opal_cmd_line_is_taken(cmd, "mca") &&
|
|
!opal_cmd_line_is_taken(cmd, "gmca")) {
|
|
return OPAL_SUCCESS;
|
|
}
|
|
|
|
/* Handle app context-specific parameters */
|
|
|
|
num_insts = opal_cmd_line_get_ninsts(cmd, "mca");
|
|
params = values = NULL;
|
|
for (i = 0; i < num_insts; ++i) {
|
|
process_arg(opal_cmd_line_get_param(cmd, "mca", i, 0),
|
|
opal_cmd_line_get_param(cmd, "mca", i, 1),
|
|
¶ms, &values);
|
|
}
|
|
if (NULL != params) {
|
|
add_to_env(params, values, context_env);
|
|
opal_argv_free(params);
|
|
opal_argv_free(values);
|
|
}
|
|
|
|
/* Handle global parameters */
|
|
|
|
num_insts = opal_cmd_line_get_ninsts(cmd, "gmca");
|
|
params = values = NULL;
|
|
for (i = 0; i < num_insts; ++i) {
|
|
process_arg(opal_cmd_line_get_param(cmd, "gmca", i, 0),
|
|
opal_cmd_line_get_param(cmd, "gmca", i, 1),
|
|
¶ms, &values);
|
|
}
|
|
if (NULL != params) {
|
|
add_to_env(params, values, global_env);
|
|
opal_argv_free(params);
|
|
opal_argv_free(values);
|
|
}
|
|
|
|
/* All done */
|
|
|
|
return OPAL_SUCCESS;
|
|
}
|
|
|
|
|
|
/*
|
|
* Process a single MCA argument.
|
|
*/
|
|
static int process_arg(const char *param, const char *value,
|
|
char ***params, char ***values)
|
|
{
|
|
int i;
|
|
char *new_str;
|
|
|
|
/* Look to see if we've already got an -mca argument for the same
|
|
param. Check against the list of MCA param's that we've
|
|
already saved arguments for. */
|
|
|
|
for (i = 0; NULL != *params && NULL != (*params)[i]; ++i) {
|
|
if (0 == strcmp(param, (*params)[i])) {
|
|
asprintf(&new_str, "%s,%s", (*values)[i], value);
|
|
free((*values)[i]);
|
|
(*values)[i] = new_str;
|
|
|
|
return OPAL_SUCCESS;
|
|
}
|
|
}
|
|
|
|
/* If we didn't already have an value for the same param, save
|
|
this one away */
|
|
|
|
opal_argv_append_nosize(params, param);
|
|
opal_argv_append_nosize(values, value);
|
|
|
|
return OPAL_SUCCESS;
|
|
}
|
|
|
|
|
|
static void add_to_env(char **params, char **values, char ***env)
|
|
{
|
|
int i;
|
|
char *name;
|
|
|
|
/* Loop through all the args that we've gotten and make env
|
|
vars of the form OMPI_MCA_*=value. */
|
|
|
|
for (i = 0; NULL != params && NULL != params[i]; ++i) {
|
|
name = mca_base_param_environ_variable(params[i], NULL, NULL);
|
|
opal_setenv(name, values[i], true, env);
|
|
free(name);
|
|
}
|
|
}
|