1
1
openmpi/orte/mca/fddp/base/fddp_base_select.c
Ralph Castain c3c642aa0d Add two new frameworks for sensing and predicting faults. This is just the bare-bones plumbing for now - will instantiate soon.
No ess modules reference these frameworks yet, so they are completely inactive.

This commit was SVN r21847.
2009-08-20 04:27:16 +00:00

79 строки
2.3 KiB
C

/*
* Copyright (c) 2009 Cisco Systems, Inc. All rights reserved.
*
* $COPYRIGHT$
*
* Additional copyrights may follow
*
* $HEADER$
*/
#include "orte_config.h"
#include "orte/constants.h"
#include "opal/mca/mca.h"
#include "opal/mca/base/base.h"
#include "orte/mca/fddp/base/base.h"
/**
* Function for selecting one component from all those that are
* available.
*/
int orte_fddp_base_select(void)
{
int ret, exit_status = ORTE_SUCCESS;
orte_fddp_base_component_t *best_component = NULL;
orte_fddp_base_module_t *best_module = NULL;
char *include_list = NULL;
/*
* Register the framework MCA param and look up include list
*/
mca_base_param_reg_string_name("fddp", NULL,
"Which fddp component to use (empty = none)",
false, false,
NULL, &include_list);
/* If we do not have any components to select this is ok. Just use the default
* "no-op" component and move on.
*/
if( 0 >= opal_list_get_size(&mca_fddp_base_components_available) || NULL == include_list) {
/* Close all components since none will be used */
mca_base_components_close(0, /* Pass 0 to keep this from closing the output handle */
&mca_fddp_base_components_available,
NULL);
goto cleanup;
}
/*
* Select the best component
*/
if( ORTE_SUCCESS != mca_base_select("fddp", orte_fddp_base_output,
&mca_fddp_base_components_available,
(mca_base_module_t **) &best_module,
(mca_base_component_t **) &best_component) ) {
/* It is okay if no component was selected - we just leave
* the orte_fddp module as the default
*/
exit_status = ORTE_SUCCESS;
goto cleanup;
}
if (NULL != orte_fddp.init) {
/* if an init function is provided, use it */
if (ORTE_SUCCESS != (ret = orte_fddp.init()) ) {
exit_status = ret;
goto cleanup;
}
}
/* Save the winner */
orte_fddp = *best_module;
cleanup:
return exit_status;
}