1
1
openmpi/opal/mca/sysinfo/base/sysinfo_base_close.c
Ralph Castain a0d5c80ce0 Add a new framework for discovering local resource information such as cpu type/model, #cpus, available physical memory, etc. Two initial components (darwin and linux) are provided. This is needed to support bootstrap operations where daemons are started at node boot, and applications where initial knowledge of cpu identification is needed to guide framework component selection.
Add orte configuration option to control the use of the framework in the system. Although the code will build, it will not be active unless configured with --enable-bootstrap.

If bootstrap is enabled and the new opal_sysinfo framework can successfully determine the cpu model, pass that info to the application as an MCA param to support some work at Sun.

Also, have daemons report back the resources they find to guide process mapping in bootstrap operations (i.e., where the daemon starts at node boot as opposed to being launched at application start).

Adjust some platform files to enable these capabilities.

This commit was SVN r22244.
2009-11-30 23:11:25 +00:00

44 строки
1.1 KiB
C

/*
* Copyright (c) 2009 Cisco Systems, Inc. All rights reserved.
*
* $COPYRIGHT$
*
* Additional copyrights may follow
*
* $HEADER$
*/
#include "opal_config.h"
#include "opal/constants.h"
#include "opal/mca/mca.h"
#include "opal/mca/base/base.h"
#include "opal/mca/sysinfo/sysinfo.h"
#include "opal/mca/sysinfo/base/base.h"
int opal_sysinfo_base_close(void)
{
opal_list_item_t *item;
opal_sysinfo_module_t *mod;
/* call the finalize of all available modules */
while (NULL != (item = opal_list_remove_first(&opal_sysinfo_avail_modules))) {
mod = (opal_sysinfo_module_t*)item;
if (NULL != mod->module->finalize) {
mod->module->finalize();
}
}
OBJ_DESTRUCT(&opal_sysinfo_avail_modules);
/* Close all components that are still open (this should only
happen during ompi_info). */
mca_base_components_close(opal_sysinfo_base_output,
&opal_sysinfo_base_components_opened, NULL);
OBJ_DESTRUCT(&opal_sysinfo_base_components_opened);
/* All done */
return OPAL_SUCCESS;
}