2004-01-11 04:41:21 +00:00
|
|
|
/*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2004-06-15 05:37:21 +00:00
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
*
|
|
|
|
* Run-time MCA parameter registration and lookup.
|
|
|
|
*/
|
2004-04-22 16:59:56 +00:00
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
#ifndef OMPI_MCA_BASE_PARAM_H
|
|
|
|
#define OMPI_MCA_BASE_PARAM_H
|
2004-01-11 04:41:21 +00:00
|
|
|
|
|
|
|
#include "mpi.h"
|
|
|
|
|
2004-06-15 05:37:21 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Types for MCA parameters.
|
2004-01-11 04:41:21 +00:00
|
|
|
*/
|
|
|
|
typedef union {
|
|
|
|
int intval;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< Integer value */
|
2004-01-11 04:41:21 +00:00
|
|
|
char *stringval;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< String value */
|
2004-01-11 04:41:21 +00:00
|
|
|
} mca_base_param_storage_t;
|
|
|
|
|
2004-06-15 05:37:21 +00:00
|
|
|
/**
|
|
|
|
* Special name used to indicate that this is an "info" value.
|
|
|
|
*/
|
2004-01-11 04:41:21 +00:00
|
|
|
#define MCA_BASE_PARAM_INFO ((void*) -1)
|
|
|
|
|
|
|
|
|
2004-06-15 05:37:21 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
*
|
2004-01-29 22:10:33 +00:00
|
|
|
* The following types are really in this public .h file so that
|
2004-06-07 15:33:53 +00:00
|
|
|
* ompi_info can see them. No one else should use them!
|
2004-01-29 22:10:33 +00:00
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
MCA_BASE_PARAM_TYPE_INT,
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< The parameter is of type integer. */
|
2004-01-29 22:10:33 +00:00
|
|
|
MCA_BASE_PARAM_TYPE_STRING,
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< The parameter is of type string. */
|
2004-01-29 22:10:33 +00:00
|
|
|
|
|
|
|
MCA_BASE_PARAM_TYPE_MAX
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< Maximum parameter type. */
|
2004-01-29 22:10:33 +00:00
|
|
|
} mca_base_param_type_t;
|
|
|
|
|
2004-06-15 05:37:21 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Entry for holding the information about an MCA parameter and its
|
|
|
|
* default value.
|
|
|
|
*/
|
2004-01-29 22:10:33 +00:00
|
|
|
struct mca_base_param_t {
|
|
|
|
mca_base_param_type_t mbp_type;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< Enum indicating the type of the parameter (integer or string) */
|
2004-01-29 22:10:33 +00:00
|
|
|
char *mbp_type_name;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< String of the type name, or NULL */
|
2004-01-29 22:10:33 +00:00
|
|
|
char *mbp_module_name;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< String of the component name */
|
2004-01-29 22:10:33 +00:00
|
|
|
char *mbp_param_name;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< String of the parameter name */
|
2004-01-29 22:10:33 +00:00
|
|
|
char *mbp_full_name;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< Full parameter name, in case it is not
|
|
|
|
<type>_<component>_<param> */
|
2004-01-29 22:10:33 +00:00
|
|
|
|
|
|
|
int mbp_keyval;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< Keyval value for MPI attribute parameters */
|
2004-01-29 22:10:33 +00:00
|
|
|
char *mbp_env_var_name;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< Environment variable name */
|
2004-01-29 22:10:33 +00:00
|
|
|
|
|
|
|
mca_base_param_storage_t mbp_default_value;
|
2004-06-15 05:37:21 +00:00
|
|
|
/**< Default value of the parameter */
|
2004-01-29 22:10:33 +00:00
|
|
|
};
|
2004-06-15 05:37:21 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Convenience typedef.
|
|
|
|
*/
|
2004-01-29 22:10:33 +00:00
|
|
|
typedef struct mca_base_param_t mca_base_param_t;
|
|
|
|
|
|
|
|
|
2004-01-11 04:41:21 +00:00
|
|
|
/*
|
|
|
|
* Global functions for MCA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#if defined(c_plusplus) || defined(__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2004-04-22 16:59:56 +00:00
|
|
|
/**
|
|
|
|
* Register an integer MCA parameter.
|
|
|
|
*
|
|
|
|
* @param type_name The MCA type (string).
|
|
|
|
* @param module_name The name of the module (string).
|
|
|
|
* @param param_name The name of the parameter being registered (string).
|
|
|
|
* @param mca_param_name If NULL, the user-visible name of the
|
|
|
|
* parameter is {type_name}_{module_name}_{param_name}. If this
|
|
|
|
* parameter is non-NULL, it is used instead of the default name.
|
|
|
|
* @param default_value The value that is used for this parameter if
|
|
|
|
* the user does not supply one.
|
|
|
|
*
|
2004-06-07 15:33:53 +00:00
|
|
|
* @retval OMPI_ERROR Upon failure to register the parameter.
|
2004-04-22 16:59:56 +00:00
|
|
|
* @retval index Index value that can be used with
|
|
|
|
* mca_base_param_lookup_int() to retrieve the value of the parameter.
|
|
|
|
*
|
|
|
|
* This function registers an integer MCA parameter and associates it
|
|
|
|
* with a specific module.
|
|
|
|
*
|
|
|
|
* In most cases, mca_param_name should be NULL. Only in rare cases
|
|
|
|
* is it necessary (or advisable) to override the default name.
|
|
|
|
*/
|
2004-01-15 21:47:30 +00:00
|
|
|
int mca_base_param_register_int(const char *type_name,
|
|
|
|
const char *module_name,
|
|
|
|
const char *param_name,
|
|
|
|
const char *mca_param_name,
|
2004-01-11 04:41:21 +00:00
|
|
|
int default_value);
|
2004-06-15 05:37:21 +00:00
|
|
|
|
2004-04-22 16:59:56 +00:00
|
|
|
/**
|
|
|
|
* Register a string MCA parameter.
|
|
|
|
*
|
|
|
|
* @param type_name The MCA type (string).
|
|
|
|
* @param module_name The name of the module (string).
|
|
|
|
* @param param_name The name of the parameter being registered (string).
|
|
|
|
* @param mca_param_name If NULL, the user-visible name of the
|
|
|
|
* parameter is {type_name}_{module_name}_{param_name}. If this
|
|
|
|
* parameter is non-NULL, it is used instead of the default name.
|
|
|
|
* @param default_value The value that is used for this parameter if
|
|
|
|
* the user does not supply one.
|
|
|
|
*
|
2004-06-07 15:33:53 +00:00
|
|
|
* @retval OMPI_ERROR Upon failure to register the parameter.
|
2004-04-22 16:59:56 +00:00
|
|
|
* @retval index Index value that can be used with
|
|
|
|
* mca_base_param_lookup_string() to retrieve the value of the
|
|
|
|
* parameter.
|
|
|
|
*
|
|
|
|
* This function registers an string MCA parameter and associates it
|
|
|
|
* with a specific module.
|
|
|
|
*
|
|
|
|
* In most cases, mca_param_name should be NULL. Only in rare cases
|
|
|
|
* is it necessary (or advisable) to override the default name.
|
|
|
|
*/
|
2004-01-15 21:47:30 +00:00
|
|
|
int mca_base_param_register_string(const char *type_name,
|
|
|
|
const char *module_name,
|
2004-01-15 17:43:54 +00:00
|
|
|
const char *param_name,
|
|
|
|
const char *mca_param_name,
|
|
|
|
const char *default_value);
|
2004-06-15 05:37:21 +00:00
|
|
|
|
2004-04-22 16:59:56 +00:00
|
|
|
/**
|
|
|
|
* Look up an integer MCA parameter.
|
|
|
|
*
|
|
|
|
* @param index Index previous returned from
|
|
|
|
* mca_base_param_register_int().
|
|
|
|
* @param value Pointer to int where the parameter value will be
|
|
|
|
* stored.
|
|
|
|
*
|
2004-06-07 15:33:53 +00:00
|
|
|
* @retvalue OMPI_ERROR Upon failure. The contents of value are
|
2004-04-22 16:59:56 +00:00
|
|
|
* undefined.
|
2004-06-07 15:33:53 +00:00
|
|
|
* @retvalue OMPI_SUCCESS Upon success. value will be filled with the
|
2004-04-22 16:59:56 +00:00
|
|
|
* parameter's current value.
|
|
|
|
*
|
|
|
|
* The value of a specific MCA parameter can be looked up using the
|
|
|
|
* return value from mca_base_param_register_int().
|
|
|
|
*/
|
2004-01-11 08:16:07 +00:00
|
|
|
int mca_base_param_lookup_int(int index, int *value);
|
2004-06-15 05:37:21 +00:00
|
|
|
|
2004-04-22 16:59:56 +00:00
|
|
|
/**
|
|
|
|
* Look up a string MCA parameter.
|
|
|
|
*
|
|
|
|
* @param index Index previous returned from
|
|
|
|
* mca_base_param_register_string().
|
|
|
|
* @param value Pointer to (char *) where the parameter value will be
|
|
|
|
* stored.
|
|
|
|
*
|
2004-06-07 15:33:53 +00:00
|
|
|
* @retvalue OMPI_ERROR Upon failure. The contents of value are
|
2004-04-22 16:59:56 +00:00
|
|
|
* undefined.
|
2004-06-07 15:33:53 +00:00
|
|
|
* @retvalue OMPI_SUCCESS Upon success. value will be filled with the
|
2004-04-22 16:59:56 +00:00
|
|
|
* parameter's current value.
|
|
|
|
*
|
|
|
|
* The value of a specific MCA parameter can be looked up using the
|
|
|
|
* return value from mca_base_param_register_string().
|
|
|
|
*/
|
2004-01-11 08:16:07 +00:00
|
|
|
int mca_base_param_lookup_string(int index, char **value);
|
2004-06-15 05:37:21 +00:00
|
|
|
|
2004-04-22 16:59:56 +00:00
|
|
|
/**
|
|
|
|
* Find the index for an MCA parameter based on its names.
|
|
|
|
*
|
|
|
|
* @param type_name Name of the type containing the parameter.
|
|
|
|
* @param module_name Name of the module containing the parameter.
|
|
|
|
* @param param_name Name of the parameter.
|
|
|
|
*
|
2004-06-07 15:33:53 +00:00
|
|
|
* @retval OMPI_ERROR If the parameter was not found.
|
2004-04-22 16:59:56 +00:00
|
|
|
* @retval index If the parameter was found.
|
|
|
|
*
|
|
|
|
* It is not always convenient to widely propagate a parameter's index
|
|
|
|
* value, or it may be necessary to look up the parameter from a
|
|
|
|
* different module -- where it is not possible to have the return
|
|
|
|
* value from mca_base_param_register_int() or
|
|
|
|
* mca_base_param_register_string(). This function can be used to
|
|
|
|
* look up the index of any registered parameter. The returned index
|
|
|
|
* can be used with mca_base_param_lookup_int() and
|
|
|
|
* mca_base_param_lookup_string().
|
|
|
|
*/
|
2004-01-15 21:47:30 +00:00
|
|
|
int mca_base_param_find(const char *type, const char *module,
|
|
|
|
const char *param);
|
2004-06-15 05:37:21 +00:00
|
|
|
|
2004-04-22 16:59:56 +00:00
|
|
|
/**
|
|
|
|
* Shut down the MCA parameter system (normally only invoked by the
|
|
|
|
* MCA framework itself).
|
|
|
|
*
|
2004-06-07 15:33:53 +00:00
|
|
|
* @returns OMPI_SUCCESS This function never fails.
|
2004-04-22 16:59:56 +00:00
|
|
|
*
|
|
|
|
* This function shuts down the MCA parameter repository and frees all
|
|
|
|
* associated memory. No other mca_base_param*() functions can be
|
|
|
|
* invoked after this function.
|
|
|
|
*
|
|
|
|
* This function is normally only invoked by the MCA framework itself
|
|
|
|
* when the process is shutting down (e.g., during MPI_FINALIZE). It
|
|
|
|
* is only documented here for completeness.
|
|
|
|
*/
|
2004-01-11 04:41:21 +00:00
|
|
|
int mca_base_param_finalize(void);
|
|
|
|
|
2004-01-13 08:07:10 +00:00
|
|
|
#if 0
|
2004-04-22 16:59:56 +00:00
|
|
|
/* JMS these are currently unimplemented */
|
2004-01-11 04:41:21 +00:00
|
|
|
int mca_base_param_kv_associate(int index, int keyval);
|
|
|
|
int mca_base_param_kv_lookup_int(int index, MPI_Comm comm);
|
|
|
|
char *mca_base_param_kv_lookup_string(int index, MPI_Comm comm);
|
2004-01-13 08:07:10 +00:00
|
|
|
#endif
|
2004-01-11 04:41:21 +00:00
|
|
|
#if defined(c_plusplus) || defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
#endif /* OMPI_MCA_BASE_PARAM_H */
|