2011-07-26 08:36:21 +04:00
|
|
|
/*
|
|
|
|
* Copyright (C) Mellanox Technologies Ltd. 2001-2011. ALL RIGHTS RESERVED.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "ompi_config.h"
|
|
|
|
|
2012-06-27 05:28:28 +04:00
|
|
|
#include "orte/util/show_help.h"
|
2011-07-26 08:36:21 +04:00
|
|
|
#include "opal/util/output.h"
|
|
|
|
#include "opal/mca/base/mca_base_param.h"
|
|
|
|
#include "ompi/proc/proc.h"
|
|
|
|
|
|
|
|
#include "mtl_mxm.h"
|
|
|
|
#include "mtl_mxm_types.h"
|
|
|
|
#include "mtl_mxm_request.h"
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
static int ompi_mtl_mxm_component_open(void);
|
|
|
|
static int ompi_mtl_mxm_component_close(void);
|
|
|
|
static int ompi_mtl_mxm_component_register(void);
|
|
|
|
|
|
|
|
int mca_mtl_mxm_output = -1;
|
|
|
|
|
|
|
|
|
|
|
|
static mca_mtl_base_module_t
|
|
|
|
* ompi_mtl_mxm_component_init(bool enable_progress_threads,
|
|
|
|
bool enable_mpi_threads);
|
|
|
|
|
|
|
|
mca_mtl_mxm_component_t mca_mtl_mxm_component = {
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* First, the mca_base_component_t struct containing meta
|
|
|
|
* information about the component itself
|
|
|
|
*/
|
|
|
|
{
|
|
|
|
MCA_MTL_BASE_VERSION_2_0_0,
|
|
|
|
"mxm", /* MCA component name */
|
|
|
|
OMPI_MAJOR_VERSION, /* MCA component major version */
|
|
|
|
OMPI_MINOR_VERSION, /* MCA component minor version */
|
|
|
|
OMPI_RELEASE_VERSION, /* MCA component release version */
|
|
|
|
ompi_mtl_mxm_component_open, /* component open */
|
|
|
|
ompi_mtl_mxm_component_close, /* component close */
|
|
|
|
NULL,
|
|
|
|
ompi_mtl_mxm_component_register
|
|
|
|
},
|
|
|
|
{
|
|
|
|
/* The component is not checkpoint ready */
|
|
|
|
MCA_BASE_METADATA_PARAM_NONE
|
|
|
|
},
|
|
|
|
ompi_mtl_mxm_component_init /* component init */
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
static int ompi_mtl_mxm_component_register(void)
|
|
|
|
{
|
2012-06-02 15:07:20 +04:00
|
|
|
mca_base_component_t*c;
|
2011-07-26 08:36:21 +04:00
|
|
|
|
2012-06-02 15:07:20 +04:00
|
|
|
c = &mca_mtl_mxm_component.super.mtl_version;
|
|
|
|
|
|
|
|
mca_base_param_reg_int(c, "verbose",
|
2011-07-26 08:36:21 +04:00
|
|
|
"Verbose level of the MXM component",
|
|
|
|
false, false,
|
|
|
|
0,
|
|
|
|
&ompi_mtl_mxm.verbose);
|
|
|
|
|
2012-06-02 15:07:20 +04:00
|
|
|
mca_base_param_reg_int(c, "np",
|
2012-06-04 01:48:42 +04:00
|
|
|
"[integer] Minimal number of MPI processes in a single job "
|
|
|
|
"required to activate the MXM transport",
|
2012-06-02 15:07:20 +04:00
|
|
|
false, false,
|
|
|
|
128,
|
|
|
|
&ompi_mtl_mxm.mxm_np);
|
|
|
|
|
2011-07-26 08:36:21 +04:00
|
|
|
return OMPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int ompi_mtl_mxm_component_open(void)
|
|
|
|
{
|
2011-08-07 16:06:49 +04:00
|
|
|
mxm_error_t err;
|
|
|
|
|
|
|
|
mca_mtl_mxm_output = opal_output_open(NULL);
|
|
|
|
opal_output_set_verbosity(mca_mtl_mxm_output, ompi_mtl_mxm.verbose);
|
2012-08-08 19:29:38 +04:00
|
|
|
#if MXM_API < MXM_VERSION(1,5)
|
|
|
|
mxm_fill_context_opts(&ompi_mtl_mxm.mxm_opts);
|
|
|
|
err = mxm_init(&ompi_mtl_mxm.mxm_opts, &ompi_mtl_mxm.mxm_context);
|
|
|
|
MXM_VERBOSE(1, "mxm component open");
|
|
|
|
#else
|
|
|
|
err = mxm_config_read_context_opts(&ompi_mtl_mxm.mxm_opts);
|
|
|
|
if (err != MXM_OK) {
|
|
|
|
MXM_ERROR("Failed to parse MXM configuration");
|
|
|
|
return OPAL_ERR_BAD_PARAM;
|
|
|
|
}
|
|
|
|
|
|
|
|
err = mxm_init(ompi_mtl_mxm.mxm_opts, &ompi_mtl_mxm.mxm_context);
|
|
|
|
MXM_VERBOSE(1, "mxm component open");
|
|
|
|
#endif
|
|
|
|
|
2011-08-07 16:06:49 +04:00
|
|
|
|
|
|
|
if (MXM_OK != err) {
|
2011-08-09 11:09:37 +04:00
|
|
|
if (MXM_ERR_NO_DEVICE == err) {
|
|
|
|
MXM_VERBOSE(1, "No supported device found, disqualifying mxm");
|
|
|
|
} else {
|
2012-06-27 05:28:28 +04:00
|
|
|
orte_show_help("help-mtl-mxm.txt", "mxm init", true,
|
2011-08-09 11:09:37 +04:00
|
|
|
mxm_error_string(err));
|
|
|
|
}
|
2011-07-26 08:36:21 +04:00
|
|
|
return OPAL_ERR_NOT_AVAILABLE;
|
|
|
|
}
|
2012-01-26 22:33:43 +04:00
|
|
|
|
2012-08-06 10:35:57 +04:00
|
|
|
#if MXM_API >= MXM_VERSION(1,5)
|
2012-07-31 11:57:25 +04:00
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
|
2012-07-25 17:26:40 +04:00
|
|
|
OBJ_CONSTRUCT(&mca_mtl_mxm_component.mxm_messages, ompi_free_list_t);
|
|
|
|
rc = ompi_free_list_init_new(&mca_mtl_mxm_component.mxm_messages,
|
|
|
|
sizeof(ompi_mtl_mxm_message_t),
|
|
|
|
opal_cache_line_size,
|
|
|
|
OBJ_CLASS(ompi_mtl_mxm_message_t),
|
|
|
|
0, opal_cache_line_size,
|
|
|
|
32 /* free list num */,
|
|
|
|
-1 /* free list max */,
|
|
|
|
32 /* free list inc */,
|
|
|
|
NULL);
|
|
|
|
if (OMPI_SUCCESS != rc) {
|
|
|
|
orte_show_help("help-mtl-mxm.txt", "mxm init", true,
|
|
|
|
mxm_error_string(err));
|
|
|
|
return OPAL_ERR_NOT_AVAILABLE;
|
|
|
|
}
|
2012-07-31 11:57:25 +04:00
|
|
|
}
|
|
|
|
#endif
|
2012-07-25 17:26:40 +04:00
|
|
|
|
2011-08-07 16:06:49 +04:00
|
|
|
return OMPI_SUCCESS;
|
2011-07-26 08:36:21 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
static int ompi_mtl_mxm_component_close(void)
|
|
|
|
{
|
2011-08-07 16:06:49 +04:00
|
|
|
mxm_cleanup(ompi_mtl_mxm.mxm_context);
|
|
|
|
ompi_mtl_mxm.mxm_context = NULL;
|
2012-07-31 11:57:25 +04:00
|
|
|
|
2012-08-06 10:35:57 +04:00
|
|
|
#if MXM_API >= MXM_VERSION(1,5)
|
2012-07-25 17:26:40 +04:00
|
|
|
OBJ_DESTRUCT(&mca_mtl_mxm_component.mxm_messages);
|
2012-07-31 11:57:25 +04:00
|
|
|
#endif
|
|
|
|
|
2011-07-26 08:36:21 +04:00
|
|
|
return OMPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
static mca_mtl_base_module_t*
|
|
|
|
ompi_mtl_mxm_component_init(bool enable_progress_threads,
|
|
|
|
bool enable_mpi_threads)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
rc = ompi_mtl_mxm_module_init();
|
|
|
|
if (OMPI_SUCCESS != rc) {
|
2011-08-09 11:09:37 +04:00
|
|
|
return NULL;
|
2011-07-26 08:36:21 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Calculate MTL constraints according to MXM types */
|
|
|
|
ompi_mtl_mxm.super.mtl_max_contextid = 1UL << (sizeof(mxm_ctxid_t) * 8);
|
|
|
|
ompi_mtl_mxm.super.mtl_max_tag = 1UL << (sizeof(mxm_tag_t) * 8 - 2);
|
|
|
|
ompi_mtl_mxm.super.mtl_request_size =
|
|
|
|
sizeof(mca_mtl_mxm_request_t) - sizeof(struct mca_mtl_request_t);
|
|
|
|
return &ompi_mtl_mxm.super;
|
|
|
|
}
|
|
|
|
|