/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */ /* * Copyright (c) 2011 Cisco Systems, Inc. All rights reserved. * Copyright (c) 2011-2012 Los Alamos National Security, LLC. All * rights reserved. * $COPYRIGHT$ * * Additional copyrights may follow * * $HEADER$ */ #include "orte_config.h" #include "orte/constants.h" #include #if WANT_CRAY_PMI2_EXT #include #endif #include "opal/mca/mca.h" #include "opal/mca/base/mca_base_param.h" #include "orte/util/proc_info.h" #include "orte/mca/common/pmi/common_pmi.h" #include "grpcomm_pmi.h" static int my_priority=5; /* must be below "bad" module */ /* * Struct of function pointers that need to be initialized */ orte_grpcomm_base_component_t mca_grpcomm_pmi_component = { { ORTE_GRPCOMM_BASE_VERSION_2_0_0, "pmi", /* MCA module name */ ORTE_MAJOR_VERSION, /* MCA module major version */ ORTE_MINOR_VERSION, /* MCA module minor version */ ORTE_RELEASE_VERSION, /* MCA module release version */ orte_grpcomm_pmi_open, /* module open */ orte_grpcomm_pmi_close, /* module close */ orte_grpcomm_pmi_component_query /* module query */ }, { /* The component is checkpoint ready */ MCA_BASE_METADATA_PARAM_CHECKPOINT } }; /* Open the component */ int orte_grpcomm_pmi_open(void) { mca_base_component_t *c = &mca_grpcomm_pmi_component.base_version; /* make the priority adjustable so users can select * pmi for use by apps without affecting daemons */ mca_base_param_reg_int(c, "priority", "Priority of the grpcomm pmi component", false, false, my_priority, &my_priority); return ORTE_SUCCESS; } int orte_grpcomm_pmi_close(void) { mca_common_pmi_finalize (); return ORTE_SUCCESS; } int orte_grpcomm_pmi_component_query(mca_base_module_t **module, int *priority) { /* only use PMI when direct launched */ if (NULL == orte_process_info.my_hnp_uri && ORTE_PROC_IS_MPI && mca_common_pmi_init ()) { /* if PMI is available, make it available for use by MPI procs */ *priority = my_priority; *module = (mca_base_module_t *)&orte_grpcomm_pmi_module; return ORTE_SUCCESS; } /* we can't run */ *priority = -1; *module = NULL; return ORTE_ERROR; }