2004-07-13 20:24:26 +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.
|
2004-11-28 20:09:25 +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.
|
2004-11-22 01:38:40 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-07-13 20:24:26 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2004-08-31 09:49:56 +00:00
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
*
|
|
|
|
* This is the private declarations for the MCA parameter system.
|
|
|
|
* This file is internal to the MCA parameter system and should not
|
|
|
|
* need to be used by any other elements in Open MPI except the
|
|
|
|
* special case of the ompi_info command.
|
|
|
|
*
|
|
|
|
* All the rest of the doxygen documentation in this file is marked as
|
|
|
|
* "internal" and won't show up unless you specifically tell doxygen
|
|
|
|
* to generate internal documentation (by default, it is skipped).
|
2004-07-13 20:24:26 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef OMPI_MCA_BASE_PARAM_INTERNAL_H
|
|
|
|
#define OMPI_MCA_BASE_PARAM_INTERNAL_H
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
#include "ompi_config.h"
|
2004-07-13 20:24:26 +00:00
|
|
|
|
2005-07-03 16:06:07 +00:00
|
|
|
#include "opal/class/opal_object.h"
|
2005-07-03 16:22:16 +00:00
|
|
|
#include "opal/class/opal_list.h"
|
2005-07-03 16:52:32 +00:00
|
|
|
#include "class/opal_hash_table.h"
|
2005-02-12 16:23:39 +00:00
|
|
|
#include "mca/base/mca_base_param.h"
|
2004-07-13 20:24:26 +00:00
|
|
|
|
|
|
|
/**
|
2004-08-31 09:49:56 +00:00
|
|
|
* \internal
|
|
|
|
*
|
2004-07-13 20:24:26 +00:00
|
|
|
* Types for MCA parameters.
|
|
|
|
*/
|
|
|
|
typedef union {
|
2004-08-31 09:49:56 +00:00
|
|
|
/** Integer value */
|
|
|
|
int intval;
|
|
|
|
/** String value */
|
|
|
|
char *stringval;
|
2004-07-13 20:24:26 +00:00
|
|
|
} mca_base_param_storage_t;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2004-08-31 09:49:56 +00:00
|
|
|
* \internal
|
|
|
|
*
|
2004-07-13 20:24:26 +00:00
|
|
|
* Entry for holding the information about an MCA parameter and its
|
|
|
|
* default value.
|
|
|
|
*/
|
|
|
|
struct mca_base_param_t {
|
2004-08-31 09:49:56 +00:00
|
|
|
/** Allow this to be an OMPI OBJ */
|
2005-07-03 16:06:07 +00:00
|
|
|
opal_object_t mbp_super;
|
2004-08-31 09:49:56 +00:00
|
|
|
|
|
|
|
/** Enum indicating the type of the parameter (integer or string) */
|
|
|
|
mca_base_param_type_t mbp_type;
|
|
|
|
/** String of the type name, or NULL */
|
|
|
|
char *mbp_type_name;
|
|
|
|
/** String of the component name */
|
|
|
|
char *mbp_component_name;
|
|
|
|
/** String of the parameter name */
|
|
|
|
char *mbp_param_name;
|
|
|
|
/** Full parameter name, in case it is not
|
|
|
|
<type>_<component>_<param> */
|
|
|
|
char *mbp_full_name;
|
2005-02-10 04:37:13 +00:00
|
|
|
|
|
|
|
/** Whether this is internal (not meant to be seen / modified by
|
|
|
|
users) or not */
|
|
|
|
bool mbp_internal;
|
2005-08-01 22:38:17 +00:00
|
|
|
/** Whether this value is changable from the default value that
|
|
|
|
was registered (e.g., when true, useful for reporting values,
|
|
|
|
like the value of the GM library that was linked against) */
|
|
|
|
bool mbp_read_only;
|
|
|
|
/** Help message associated with this parameter */
|
|
|
|
char *mbp_help_msg;
|
2004-08-31 09:49:56 +00:00
|
|
|
|
|
|
|
/** Keyval value for MPI attribute parameters */
|
|
|
|
int mbp_keyval;
|
|
|
|
/** Environment variable name */
|
|
|
|
char *mbp_env_var_name;
|
|
|
|
|
|
|
|
/** Default value of the parameter */
|
|
|
|
mca_base_param_storage_t mbp_default_value;
|
|
|
|
|
|
|
|
/** Whether or not we have a file value */
|
|
|
|
bool mbp_file_value_set;
|
|
|
|
/** Value of the parameter found in a file */
|
|
|
|
mca_base_param_storage_t mbp_file_value;
|
|
|
|
|
|
|
|
/** Whether or not we have an override value */
|
|
|
|
bool mbp_override_value_set;
|
|
|
|
/** Value of the parameter override set via API */
|
|
|
|
mca_base_param_storage_t mbp_override_value;
|
2004-07-13 20:24:26 +00:00
|
|
|
};
|
|
|
|
/**
|
2004-08-31 09:49:56 +00:00
|
|
|
* \internal
|
|
|
|
*
|
2004-07-13 20:24:26 +00:00
|
|
|
* Convenience typedef.
|
|
|
|
*/
|
|
|
|
typedef struct mca_base_param_t mca_base_param_t;
|
|
|
|
|
|
|
|
/**
|
2004-08-31 09:49:56 +00:00
|
|
|
* \internal
|
|
|
|
*
|
2004-07-13 20:24:26 +00:00
|
|
|
* Object delcataion for mca_base_param_t
|
|
|
|
*/
|
|
|
|
OBJ_CLASS_DECLARATION(mca_base_param_t);
|
|
|
|
|
|
|
|
|
2004-08-31 09:49:56 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Structure for holding param names and values read in from files.
|
|
|
|
*/
|
|
|
|
struct mca_base_param_file_value_t {
|
|
|
|
/** Allow this to be an OMPI OBJ */
|
2005-07-03 16:22:16 +00:00
|
|
|
opal_list_item_t super;
|
2004-08-31 09:49:56 +00:00
|
|
|
|
|
|
|
/** Parameter name */
|
|
|
|
char *mbpfv_param;
|
|
|
|
/** Parameter value */
|
|
|
|
char *mbpfv_value;
|
|
|
|
};
|
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Convenience typedef
|
|
|
|
*/
|
|
|
|
typedef struct mca_base_param_file_value_t mca_base_param_file_value_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Object declaration for mca_base_param_file_value_t
|
|
|
|
*/
|
|
|
|
OBJ_CLASS_DECLARATION(mca_base_param_file_value_t);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Global list of params and values read in from MCA parameter files
|
|
|
|
*/
|
2005-07-03 16:22:16 +00:00
|
|
|
OMPI_DECLSPEC extern opal_list_t mca_base_param_file_values;
|
2004-08-31 09:49:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
#if defined(c_plusplus) || defined(__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Parse a parameter file.
|
|
|
|
*/
|
|
|
|
int mca_base_parse_paramfile(const char *paramfile);
|
|
|
|
#if defined(c_plusplus) || defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2004-07-13 20:24:26 +00:00
|
|
|
#endif /* OMPI_MCA_BASE_PARAM_INTERNAL_H */
|