e1ba09ad51
ORTED) failure. Note that more work will be necessary to allow the MPI layer to take advantage of this. Per RFC: http://www.open-mpi.org/community/lists/devel/2011/06/9299.php This commit was SVN r24815.
94 строки
2.4 KiB
C
94 строки
2.4 KiB
C
/*
|
|
* Copyright (c) 2004-2006 The Trustees of Indiana University and Indiana
|
|
* University Research and Technology
|
|
* Corporation. All rights reserved.
|
|
* Copyright (c) 2004-2011 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$
|
|
*/
|
|
/** @file:
|
|
*/
|
|
|
|
#ifndef MCA_ODLS_BASE_H
|
|
#define MCA_ODLS_BASE_H
|
|
|
|
/*
|
|
* includes
|
|
*/
|
|
#include "orte_config.h"
|
|
|
|
#include "opal/mca/mca.h"
|
|
#include "opal/class/opal_list.h"
|
|
|
|
#include "orte/mca/odls/odls.h"
|
|
|
|
|
|
BEGIN_C_DECLS
|
|
|
|
/**
|
|
* Open the odls framework
|
|
*/
|
|
ORTE_DECLSPEC int orte_odls_base_open(void);
|
|
|
|
#if !ORTE_DISABLE_FULL_SUPPORT
|
|
|
|
/**
|
|
* Struct to hold globals for the odls framework
|
|
*/
|
|
typedef struct orte_odls_base_t {
|
|
/* components are available */
|
|
bool components_available;
|
|
/* component has been selected */
|
|
bool selected;
|
|
/** List of opened components */
|
|
opal_list_t available_components;
|
|
/** selected component */
|
|
orte_odls_base_component_t selected_component;
|
|
/* warn if binding no-op */
|
|
bool warn_if_not_bound;
|
|
} orte_odls_base_t;
|
|
|
|
/**
|
|
* Global instance of odls-wide framework data
|
|
*/
|
|
ORTE_DECLSPEC extern orte_odls_base_t orte_odls_base;
|
|
|
|
/*
|
|
* Global functions for MCA overall collective open and close
|
|
*/
|
|
|
|
/**
|
|
* Select an odls module
|
|
*/
|
|
ORTE_DECLSPEC int orte_odls_base_select(void);
|
|
|
|
/**
|
|
* Close the odls framework
|
|
*/
|
|
ORTE_DECLSPEC int orte_odls_base_finalize(void);
|
|
ORTE_DECLSPEC int orte_odls_base_close(void);
|
|
|
|
/* proc termination entry points */
|
|
ORTE_DECLSPEC void orte_odls_base_notify_iof_complete(orte_process_name_t *proc);
|
|
ORTE_DECLSPEC void orte_base_default_waitpid_fired(orte_process_name_t *proc, int32_t status);
|
|
|
|
/* setup singleton job data */
|
|
ORTE_DECLSPEC void orte_odls_base_setup_singleton_jobdat(orte_jobid_t jobid);
|
|
|
|
/* Lookup function to see if the child process has already finished. */
|
|
ORTE_DECLSPEC bool orte_odls_base_default_check_finished(orte_process_name_t *proc);
|
|
|
|
#endif /* ORTE_DISABLE_FULL_SUPPORT */
|
|
|
|
END_C_DECLS
|
|
#endif
|