2011-06-21 15:41:57 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004-2005 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-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2007-2010 Cisco Systems, Inc. All rights reserved.
|
|
|
|
* Copyright (c) 2010-2011 Los Alamos National Security, LLC.
|
|
|
|
* All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef OPAL_SHMEM_BASE_H
|
|
|
|
#define OPAL_SHMEM_BASE_H
|
|
|
|
|
|
|
|
#include "opal_config.h"
|
|
|
|
|
|
|
|
#include "opal/mca/shmem/shmem.h"
|
|
|
|
|
|
|
|
BEGIN_C_DECLS
|
|
|
|
|
|
|
|
/* ////////////////////////////////////////////////////////////////////////// */
|
|
|
|
/* Public API for the shmem framework */
|
|
|
|
/* ////////////////////////////////////////////////////////////////////////// */
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_segment_create(opal_shmem_ds_t *ds_buf,
|
|
|
|
const char *file_name,
|
|
|
|
size_t size);
|
|
|
|
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_ds_copy(const opal_shmem_ds_t *from,
|
|
|
|
opal_shmem_ds_t *to);
|
|
|
|
|
|
|
|
OPAL_DECLSPEC void *
|
|
|
|
opal_shmem_segment_attach(opal_shmem_ds_t *ds_buf);
|
|
|
|
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_segment_detach(opal_shmem_ds_t *ds_buf);
|
|
|
|
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_unlink(opal_shmem_ds_t *ds_buf);
|
|
|
|
/* ////////////////////////////////////////////////////////////////////////// */
|
|
|
|
/* End Public API for the shmem framework */
|
|
|
|
/* ////////////////////////////////////////////////////////////////////////// */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Global functions for MCA overall shmem open and close
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Register MCA params for the shmem base.
|
|
|
|
*
|
|
|
|
* @retval OPAL_SUCCESS Upon success
|
|
|
|
*
|
|
|
|
* This function is invoked by opal_shmem_base_register_params(). It registers
|
|
|
|
* some shmem-wide MCA parameters.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_base_register_params(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Performs a run-time query across all available shmem components. Similar to
|
|
|
|
* mca_base_select, but take into consideration environment hints provided by
|
|
|
|
* orte.
|
|
|
|
*
|
|
|
|
* see: orte/mca/odls/base/odls_base_default_fns.c
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_base_runtime_query(mca_base_module_t **best_module,
|
|
|
|
mca_base_component_t **best_component);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* returns the name of the best, runnable shmem component. the caller is
|
|
|
|
* responsible for freeing returned resources.
|
|
|
|
*
|
|
|
|
* @retval name of best component. NULL if no component is found.
|
|
|
|
*
|
|
|
|
* see: orte/mca/odls/base/odls_base_default_fns.c
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC char *
|
|
|
|
opal_shmem_base_best_runnable_component_name(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize the shmem MCA framework
|
|
|
|
*
|
|
|
|
* @retval OPAL_SUCCESS Upon success
|
|
|
|
* @retval OPAL_ERROR Upon failure
|
|
|
|
*
|
|
|
|
* This must be the first function invoked in the shmem MCA
|
|
|
|
* framework. It initializes the shmem MCA framework, finds
|
|
|
|
* and opens shmem components, etc.
|
|
|
|
*
|
|
|
|
* This function is invoked during opal_init().
|
|
|
|
*
|
|
|
|
* This function fills in the internal global variable
|
|
|
|
* opal_shmem_base_components_opened, which is a list of all
|
|
|
|
* shmem components that were successfully opened. This
|
|
|
|
* variable should \em only be used by other shmem base
|
|
|
|
* functions -- it is not considered a public interface member --
|
|
|
|
* and is only mentioned here for completeness.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_base_open(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Select an available component.
|
|
|
|
*
|
|
|
|
* @return OPAL_SUCCESS Upon success.
|
|
|
|
* @return OPAL_NOT_FOUND If no component can be selected.
|
|
|
|
* @return OPAL_ERROR Upon other failure.
|
|
|
|
*
|
|
|
|
* This function invokes the selection process for shmem components,
|
|
|
|
* which works as follows:
|
|
|
|
*
|
|
|
|
* - If the \em shmem MCA parameter is not specified, the
|
|
|
|
* selection set is all available shmem components.
|
|
|
|
* - If the \em shmem MCA parameter is specified, the
|
|
|
|
* selection set is just that component.
|
|
|
|
* - All components in the selection set are queried to see if
|
|
|
|
* they want to run. All components that want to run are ranked
|
|
|
|
* by their priority and the highest priority component is
|
|
|
|
* selected. All non-selected components have their "close"
|
|
|
|
* function invoked to let them know that they were not selected.
|
|
|
|
* - The selected component will have its "init" function invoked to
|
|
|
|
* let it know that it was selected.
|
|
|
|
*
|
|
|
|
* If we fall through this entire process and no component is
|
|
|
|
* selected, then return OPAL_NOT_FOUND (this is not a fatal
|
|
|
|
* error).
|
|
|
|
*
|
|
|
|
* At the end of this process, we'll either have a single
|
|
|
|
* component that is selected and initialized, or no component was
|
|
|
|
* selected. If no component was selected, subsequent invocation
|
|
|
|
* of the shmem wrapper functions will return an error.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_base_select(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Shut down the shmem MCA framework.
|
|
|
|
*
|
|
|
|
* @retval OPAL_SUCCESS Always
|
|
|
|
*
|
|
|
|
* This function shuts down everything in the shmem MCA
|
|
|
|
* framework, and is called during opal_finalize().
|
|
|
|
*
|
|
|
|
* It must be the last function invoked on the shmem MCA
|
|
|
|
* framework.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC int
|
|
|
|
opal_shmem_base_close(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Indication of whether a component was successfully selected or
|
|
|
|
* not
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC extern bool opal_shmem_base_selected;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Global component struct for the selected component
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC extern const opal_shmem_base_component_2_0_0_t
|
|
|
|
*opal_shmem_base_component;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Global module struct for the selected module
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC extern const opal_shmem_base_module_2_0_0_t
|
|
|
|
*opal_shmem_base_module;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Indicator as to whether the list of opened shmem components
|
|
|
|
* is valid or not.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC extern bool opal_shmem_base_components_opened_valid;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* List of all opened components; created when the shmem
|
|
|
|
* framework is initialized and destroyed when we reduce the list
|
|
|
|
* to all available shmem components.
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC extern opal_list_t opal_shmem_base_components_opened;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Debugging output stream
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC extern int opal_shmem_base_output;
|
|
|
|
|
2011-12-14 22:25:32 +00:00
|
|
|
OPAL_DECLSPEC extern bool opal_mmap_on_nfs_warning;
|
|
|
|
|
2011-06-21 15:41:57 +00:00
|
|
|
END_C_DECLS
|
|
|
|
|
|
|
|
#endif /* OPAL_BASE_SHMEM_H */
|