📄 rds_base_open.c
字号:
/* * Copyright (c) 2004-2007 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 "orte_config.h"#include "orte/orte_constants.h"#include "opal/mca/mca.h"#include "opal/mca/base/base.h"#include "opal/mca/base/mca_base_param.h"#include "opal/util/output.h"#include "orte/mca/errmgr/errmgr.h"#include "orte/mca/gpr/gpr_types.h"#include "orte/mca/rml/rml.h"#include "orte/mca/rds/base/rds_private.h"#include "orte/mca/rds/base/base.h"/* * The following file was created by configure. It contains extern * statements and the definition of an array of pointers to each * component's public mca_base_component_t struct. */#include "orte/mca/rds/base/static-components.h"/** * Local functions. */static void orte_rds_base_cell_desc_constructor(orte_rds_cell_desc_t *cell){ cell->site = NULL; cell->name = NULL; cell->type = NULL; OBJ_CONSTRUCT(&cell->attributes, opal_list_t);}static void orte_rds_base_cell_desc_destructor(orte_rds_cell_desc_t *cell){ if (NULL != cell->site) free(cell->site); if (NULL != cell->name) free(cell->name); if (NULL != cell->type) free(cell->type); OBJ_DESTRUCT(&cell->attributes);}OBJ_CLASS_INSTANCE( orte_rds_cell_desc_t, opal_list_item_t, orte_rds_base_cell_desc_constructor, orte_rds_base_cell_desc_destructor);static void orte_rds_base_cell_attr_constructor(orte_rds_cell_attr_t *cell){ OBJ_CONSTRUCT(&cell->keyval, orte_gpr_keyval_t);}static void orte_rds_base_cell_attr_destructor(orte_rds_cell_attr_t *cell){ OBJ_DESTRUCT(&cell->keyval);}OBJ_CLASS_INSTANCE( orte_rds_cell_attr_t, opal_list_item_t, orte_rds_base_cell_attr_constructor, orte_rds_base_cell_attr_destructor);/* * Global variables */orte_rds_base_module_t orte_rds = { orte_rds_base_query, orte_rds_base_store_resource};orte_rds_base_module_t orte_rds_no_op = { orte_rds_base_no_op_query, orte_rds_base_no_op_store_resource};orte_rds_base_t orte_rds_base;/** * Function for finding and opening either all MCA components, or the one * that was specifically requested via a MCA parameter. */int orte_rds_base_open(void){ int param, value; char *requested; /* Debugging / verbose output */ param = mca_base_param_reg_int_name("rds", "base_verbose", "Verbosity level for the rds framework", false, false, 0, &value); if (value != 0) { orte_rds_base.rds_output = opal_output_open(NULL); } else { orte_rds_base.rds_output = -1; } /* Some systems do not want any RDS support. In those cases, * memory consumption is also an issue. For those systems, we * avoid opening the RDS components by checking for a directive * to use the "null" component. */ param = mca_base_param_reg_string_name("rds", NULL, NULL, false, false, NULL, &requested); if (NULL != requested && 0 == strcmp(requested, "null")) { /* the user has specifically requested that we use the "null" * component. In this case, that means we do NOT open any * components, and we simply use the default module we have * already defined above */ orte_rds_base.no_op_selected = true; orte_rds = orte_rds_no_op; /* use the no_op module */ return ORTE_SUCCESS; } orte_rds_base.no_op_selected = false; /* Open up all available components */ if (ORTE_SUCCESS != mca_base_components_open("rds", orte_rds_base.rds_output, mca_rds_base_static_components, &orte_rds_base.rds_components, true)) { return ORTE_ERROR; } OBJ_CONSTRUCT(&orte_rds_base.rds_selected, opal_list_t); /* All done */ return ORTE_SUCCESS;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -