dadca7da88
This merge adds Checkpoint/Restart support to Open MPI. The initial frameworks and components support a LAM/MPI-like implementation. This commit follows the risk assessment presented to the Open MPI core development group on Feb. 22, 2007. This commit closes trac:158 More details to follow. This commit was SVN r14051. The following SVN revisions from the original message are invalid or inconsistent and therefore were not cross-referenced: r13912 The following Trac tickets were found above: Ticket 158 --> https://svn.open-mpi.org/trac/ompi/ticket/158
180 строки
6.4 KiB
C
180 строки
6.4 KiB
C
/*
|
|
* Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana
|
|
* University Research and Technology
|
|
* Corporation. All rights reserved.
|
|
* Copyright (c) 2004-2006 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-2006 The Regents of the University of California.
|
|
* All rights reserved.
|
|
* $COPYRIGHT$
|
|
*
|
|
* Additional copyrights may follow
|
|
*
|
|
* $HEADER$
|
|
*/
|
|
|
|
#include "ompi_config.h"
|
|
#include "opal/sys/cache.h"
|
|
#include "opal/event/event.h"
|
|
#include "mpi.h"
|
|
#include "ompi/mca/pml/pml.h"
|
|
#include "ompi/mca/btl/btl.h"
|
|
#include "ompi/mca/btl/base/base.h"
|
|
#include "opal/mca/base/mca_base_param.h"
|
|
#include "ompi/mca/pml/base/pml_base_bsend.h"
|
|
#include "ompi/mca/pml/crcpw/pml_crcpw.h"
|
|
#include "ompi/mca/bml/base/base.h"
|
|
|
|
|
|
mca_pml_crcpw_component_t mca_pml_crcpw_component = {
|
|
{
|
|
/* First, the mca_base_component_t struct containing meta
|
|
information about the component itself */
|
|
|
|
{
|
|
/* Indicate that we are a pml v1.0.0 component (which also implies
|
|
a specific MCA version) */
|
|
|
|
MCA_PML_BASE_VERSION_1_0_0,
|
|
|
|
"crcpw", /* MCA component name */
|
|
OMPI_MAJOR_VERSION, /* MCA component major version */
|
|
OMPI_MINOR_VERSION, /* MCA component minor version */
|
|
OMPI_RELEASE_VERSION, /* MCA component release version */
|
|
mca_pml_crcpw_component_open, /* component open */
|
|
mca_pml_crcpw_component_close /* component close */
|
|
},
|
|
|
|
/* Next the MCA v1.0.0 component meta data */
|
|
|
|
{
|
|
/* The component is checkpoint ready */
|
|
MCA_BASE_METADATA_PARAM_CHECKPOINT
|
|
},
|
|
|
|
mca_pml_crcpw_component_init, /* component init */
|
|
mca_pml_crcpw_component_finalize /* component finalize */
|
|
},
|
|
/* Verbosity */
|
|
0,
|
|
/* Priority */
|
|
PML_SELECT_WRAPPER_PRIORITY,
|
|
/* Are we being used as a wrapper? */
|
|
false
|
|
};
|
|
|
|
ompi_free_list_t pml_state_list;
|
|
|
|
int mca_pml_crcpw_component_open(void)
|
|
{
|
|
opal_output_verbose( 10, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: component_open: Open");
|
|
|
|
/*
|
|
* Register some MCA parameters
|
|
*/
|
|
mca_base_param_reg_int(&mca_pml_crcpw_component.super.pmlm_version,
|
|
"priority",
|
|
"Priority of the PML crcpw component",
|
|
false, false,
|
|
mca_pml_crcpw_component.priority,
|
|
&mca_pml_crcpw_component.priority);
|
|
|
|
mca_base_param_reg_int(&mca_pml_crcpw_component.super.pmlm_version,
|
|
"verbose",
|
|
"Verbose level for the PML crcpw component",
|
|
false, false,
|
|
mca_pml_crcpw_component.verbose,
|
|
&mca_pml_crcpw_component.verbose);
|
|
|
|
mca_pml_crcpw_component.output_handle = opal_output_open(NULL);
|
|
if ( 0 != mca_pml_crcpw_component.verbose) {
|
|
opal_output_set_verbosity(mca_pml_crcpw_component.output_handle,
|
|
mca_pml_crcpw_component.verbose);
|
|
}
|
|
|
|
/*
|
|
* Debug Output
|
|
*/
|
|
opal_output_verbose(10, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: open()");
|
|
opal_output_verbose(20, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: open: priority = %d",
|
|
mca_pml_crcpw_component.priority);
|
|
opal_output_verbose(20, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: open: verbosity = %d",
|
|
mca_pml_crcpw_component.verbose);
|
|
|
|
return OMPI_SUCCESS;
|
|
}
|
|
|
|
|
|
int mca_pml_crcpw_component_close(void)
|
|
{
|
|
opal_output_verbose( 20, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: component_close: Close");
|
|
|
|
return OMPI_SUCCESS;
|
|
}
|
|
|
|
|
|
mca_pml_base_module_t* mca_pml_crcpw_component_init(int* priority,
|
|
bool enable_progress_threads,
|
|
bool enable_mpi_threads)
|
|
{
|
|
/* We use the PML_SELECT_WRAPPER_PRIORITY to indicate when this
|
|
* component should wrap around what is already selected
|
|
* If it is not set to this seminal value, then we are doing a
|
|
* normal selection operation
|
|
*/
|
|
if(*priority == PML_SELECT_WRAPPER_PRIORITY ) {
|
|
opal_output_verbose( 20, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: component_init: Wrap the selected component %s",
|
|
mca_pml_base_selected_component.pmlm_version.mca_component_name);
|
|
|
|
mca_pml_crcpw_module.wrapped_pml_component = mca_pml_base_selected_component;
|
|
mca_pml_crcpw_module.wrapped_pml_module = mca_pml;
|
|
mca_pml_crcpw_component.pml_crcp_wrapped = true;
|
|
|
|
opal_output_verbose( 20, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: component_init: Initalize Wrapper");
|
|
|
|
OBJ_CONSTRUCT(&pml_state_list, ompi_free_list_t);
|
|
ompi_free_list_init( &pml_state_list,
|
|
sizeof(ompi_crcp_base_pml_state_t),
|
|
OBJ_CLASS(ompi_crcp_base_pml_state_t),
|
|
5, /* Initial number */
|
|
-1, /* Max = Unlimited */
|
|
64, /* Increment by */
|
|
NULL);
|
|
}
|
|
else {
|
|
opal_output_verbose( 20, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: component_init: Priority %d",
|
|
mca_pml_crcpw_component.priority);
|
|
}
|
|
|
|
|
|
*priority = mca_pml_crcpw_component.priority;
|
|
|
|
return &mca_pml_crcpw_module.super;
|
|
}
|
|
|
|
int mca_pml_crcpw_component_finalize(void)
|
|
{
|
|
opal_output_verbose( 20, mca_pml_crcpw_component.output_handle,
|
|
"pml:crcpw: component_finalize: Finalize");
|
|
|
|
OBJ_DESTRUCT(&pml_state_list);
|
|
|
|
if(mca_pml_crcpw_component.pml_crcp_wrapped) {
|
|
return mca_pml_crcpw_module.wrapped_pml_component.pmlm_finalize();
|
|
}
|
|
|
|
return OMPI_SUCCESS;
|
|
}
|
|
|