2012-07-18 17:29:37 +00:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
2005-06-30 21:28:35 +00:00
|
|
|
/*
|
2010-03-12 23:57:50 +00:00
|
|
|
* Copyright (c) 2004-2010 The Trustees of Indiana University and Indiana
|
2005-11-05 19:57:48 +00:00
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
2013-07-04 08:34:37 +00:00
|
|
|
* Copyright (c) 2004-2013 The University of Tennessee and The University
|
2005-11-05 19:57:48 +00:00
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2007-09-24 10:11:52 +00:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2005-06-30 21:28:35 +00:00
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2013-02-13 16:31:59 +00:00
|
|
|
* Copyright (c) 2007-2013 Cisco Systems, Inc. All rights reserved.
|
2015-12-30 00:12:19 +06:00
|
|
|
* Copyright (c) 2006-2015 Mellanox Technologies. All rights reserved.
|
2016-02-16 16:42:50 -07:00
|
|
|
* Copyright (c) 2006-2016 Los Alamos National Security, LLC. All rights
|
2007-09-24 10:11:52 +00:00
|
|
|
* reserved.
|
|
|
|
* Copyright (c) 2006-2007 Voltaire All rights reserved.
|
2012-03-01 17:29:40 +00:00
|
|
|
* Copyright (c) 2008-2012 Oracle and/or its affiliates. All rights reserved.
|
2010-02-22 08:14:45 +00:00
|
|
|
* Copyright (c) 2009 IBM Corporation. All rights reserved.
|
2015-09-04 16:54:40 -07:00
|
|
|
* Copyright (c) 2013-2015 Intel, Inc. All rights reserved
|
2015-02-11 15:47:56 -05:00
|
|
|
* Copyright (c) 2013-2015 NVIDIA Corporation. All rights reserved.
|
2014-12-09 18:43:15 +09:00
|
|
|
* Copyright (c) 2014-2015 Research Organization for Information Science
|
2014-06-02 02:23:52 +00:00
|
|
|
* and Technology (RIST). All rights reserved.
|
2014-12-09 18:43:15 +09:00
|
|
|
* Copyright (c) 2014 Bull SAS. All rights reserved
|
2005-06-30 21:28:35 +00:00
|
|
|
* $COPYRIGHT$
|
2007-09-24 10:11:52 +00:00
|
|
|
*
|
2005-06-30 21:28:35 +00:00
|
|
|
* Additional copyrights may follow
|
2007-09-24 10:11:52 +00:00
|
|
|
*
|
2005-06-30 21:28:35 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
#include "opal_config.h"
|
2005-06-30 21:28:35 +00:00
|
|
|
#include <string.h>
|
2014-03-27 17:56:00 +00:00
|
|
|
#include "opal_stdint.h"
|
2009-03-03 22:25:13 +00:00
|
|
|
#include "opal/class/opal_bitmap.h"
|
2009-02-14 02:26:12 +00:00
|
|
|
#include "opal/util/output.h"
|
2008-04-17 20:43:56 +00:00
|
|
|
#include "opal/util/arch.h"
|
2014-10-03 14:19:48 -07:00
|
|
|
#include "opal/util/proc.h"
|
2011-02-23 15:50:37 +00:00
|
|
|
#include "opal/include/opal_stdint.h"
|
2013-02-13 16:31:59 +00:00
|
|
|
#include "opal/util/show_help.h"
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
#include "opal/mca/btl/btl.h"
|
|
|
|
#include "opal/mca/btl/base/btl_base_error.h"
|
2008-04-17 20:43:56 +00:00
|
|
|
|
2010-03-12 23:57:50 +00:00
|
|
|
#if OPAL_ENABLE_FT_CR == 1
|
2014-07-26 21:48:23 +00:00
|
|
|
#include "opal/runtime/opal_cr.h"
|
2008-10-16 15:09:00 +00:00
|
|
|
#endif
|
|
|
|
|
2009-12-15 14:25:07 +00:00
|
|
|
#include "btl_openib_ini.h"
|
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
#include "btl_openib.h"
|
2008-01-21 12:11:18 +00:00
|
|
|
#include "btl_openib_frag.h"
|
2005-06-30 21:28:35 +00:00
|
|
|
#include "btl_openib_proc.h"
|
|
|
|
#include "btl_openib_endpoint.h"
|
2007-11-28 07:18:59 +00:00
|
|
|
#include "btl_openib_xrc.h"
|
2014-01-06 19:51:30 +00:00
|
|
|
#include "btl_openib_async.h"
|
|
|
|
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
#include "opal/datatype/opal_convertor.h"
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
#include "opal/mca/mpool/base/base.h"
|
|
|
|
#include "opal/mca/mpool/mpool.h"
|
2015-11-02 12:07:08 -07:00
|
|
|
#include "opal/mca/rcache/rcache.h"
|
2013-01-27 23:25:10 +00:00
|
|
|
|
2013-11-01 12:19:40 +00:00
|
|
|
#if OPAL_CUDA_SUPPORT
|
2013-01-17 22:34:43 +00:00
|
|
|
#include "opal/datatype/opal_datatype_cuda.h"
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
#include "opal/mca/common/cuda/common_cuda.h"
|
2013-11-01 12:19:40 +00:00
|
|
|
#endif /* OPAL_CUDA_SUPPORT */
|
2013-01-27 23:25:10 +00:00
|
|
|
|
2014-08-05 05:35:57 +00:00
|
|
|
#include "opal/util/sys_limits.h"
|
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
#include <errno.h>
|
2012-07-19 17:52:21 +00:00
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <fcntl.h>
|
2008-01-21 12:11:18 +00:00
|
|
|
#include <string.h>
|
2005-10-02 18:58:57 +00:00
|
|
|
#include <math.h>
|
2007-01-30 21:22:56 +00:00
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
|
|
#include <sys/types.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_TIME_H
|
|
|
|
#include <sys/time.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_RESOURCE_H
|
|
|
|
#include <sys/resource.h>
|
|
|
|
#endif
|
2010-07-12 16:17:56 +00:00
|
|
|
#ifdef HAVE_UNISTD_H
|
2008-02-28 01:57:57 +00:00
|
|
|
#include <unistd.h>
|
2010-07-12 16:17:56 +00:00
|
|
|
#endif
|
2012-07-19 17:52:21 +00:00
|
|
|
#include "opal/mca/hwloc/hwloc.h"
|
|
|
|
|
2011-02-03 23:53:21 +00:00
|
|
|
#ifndef MIN
|
|
|
|
#define MIN(a,b) ((a)<(b)?(a):(b))
|
|
|
|
#endif
|
2007-01-30 21:22:56 +00:00
|
|
|
|
2015-01-06 08:48:33 -07:00
|
|
|
static mca_btl_base_registration_handle_t *mca_btl_openib_register_mem (mca_btl_base_module_t *btl,
|
|
|
|
mca_btl_base_endpoint_t *endpoint,
|
|
|
|
void *base, size_t size, uint32_t flags);
|
|
|
|
static int mca_btl_openib_deregister_mem (mca_btl_base_module_t *btl, mca_btl_base_registration_handle_t *handle);
|
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
mca_btl_openib_module_t mca_btl_openib_module = {
|
2014-04-14 19:29:26 +00:00
|
|
|
.super = {
|
|
|
|
.btl_component = &mca_btl_openib_component.super,
|
|
|
|
.btl_add_procs = mca_btl_openib_add_procs,
|
|
|
|
.btl_del_procs = mca_btl_openib_del_procs,
|
|
|
|
.btl_finalize = mca_btl_openib_finalize,
|
2008-01-21 12:11:18 +00:00
|
|
|
/* we need alloc free, pack */
|
2014-04-14 19:29:26 +00:00
|
|
|
.btl_alloc = mca_btl_openib_alloc,
|
|
|
|
.btl_free = mca_btl_openib_free,
|
|
|
|
.btl_prepare_src = mca_btl_openib_prepare_src,
|
|
|
|
.btl_send = mca_btl_openib_send,
|
|
|
|
.btl_sendi = mca_btl_openib_sendi, /* send immediate */
|
|
|
|
.btl_put = mca_btl_openib_put,
|
|
|
|
.btl_get = mca_btl_openib_get,
|
|
|
|
.btl_dump = mca_btl_base_dump,
|
|
|
|
.btl_register_error = mca_btl_openib_register_error_cb, /* error call back registration */
|
2015-01-06 08:48:33 -07:00
|
|
|
.btl_ft_event = mca_btl_openib_ft_event,
|
|
|
|
.btl_register_mem = mca_btl_openib_register_mem,
|
|
|
|
.btl_deregister_mem = mca_btl_openib_deregister_mem,
|
2015-01-05 14:36:57 -07:00
|
|
|
#if HAVE_DECL_IBV_ATOMIC_HCA
|
|
|
|
.btl_atomic_fop = mca_btl_openib_atomic_fop,
|
|
|
|
.btl_atomic_cswap = mca_btl_openib_atomic_cswap,
|
|
|
|
#endif
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2009-12-15 14:25:07 +00:00
|
|
|
char* const mca_btl_openib_transport_name_strings[MCA_BTL_OPENIB_TRANSPORT_SIZE] = {
|
|
|
|
"MCA_BTL_OPENIB_TRANSPORT_IB",
|
|
|
|
"MCA_BTL_OPENIB_TRANSPORT_IWARP",
|
|
|
|
"MCA_BTL_OPENIB_TRANSPORT_RDMAOE",
|
|
|
|
"MCA_BTL_OPENIB_TRANSPORT_UNKNOWN"
|
|
|
|
};
|
|
|
|
|
2008-11-10 18:35:57 +00:00
|
|
|
static int mca_btl_openib_finalize_resources(struct mca_btl_base_module_t* btl);
|
2008-10-16 15:09:00 +00:00
|
|
|
|
2009-06-18 12:24:39 +00:00
|
|
|
void mca_btl_openib_show_init_error(const char *file, int line,
|
|
|
|
const char *func, const char *dev)
|
2007-01-24 22:25:40 +00:00
|
|
|
{
|
|
|
|
if (ENOMEM == errno) {
|
2007-01-30 21:22:56 +00:00
|
|
|
int ret;
|
|
|
|
struct rlimit limit;
|
|
|
|
char *str_limit = NULL;
|
|
|
|
|
2008-11-25 03:13:09 +00:00
|
|
|
#if HAVE_DECL_RLIMIT_MEMLOCK
|
2007-01-30 21:22:56 +00:00
|
|
|
ret = getrlimit(RLIMIT_MEMLOCK, &limit);
|
2008-11-25 03:13:09 +00:00
|
|
|
#else
|
|
|
|
ret = -1;
|
|
|
|
#endif
|
2007-01-30 21:22:56 +00:00
|
|
|
if (0 != ret) {
|
|
|
|
asprintf(&str_limit, "Unknown");
|
|
|
|
} else if (limit.rlim_cur == RLIM_INFINITY) {
|
|
|
|
asprintf(&str_limit, "unlimited");
|
|
|
|
} else {
|
2007-02-01 19:07:04 +00:00
|
|
|
asprintf(&str_limit, "%ld", (long)limit.rlim_cur);
|
2007-01-30 21:22:56 +00:00
|
|
|
}
|
|
|
|
|
2013-02-12 21:10:11 +00:00
|
|
|
opal_show_help("help-mpi-btl-openib.txt", "init-fail-no-mem",
|
2014-10-03 14:19:48 -07:00
|
|
|
true, opal_process_info.nodename,
|
2007-01-30 21:22:56 +00:00
|
|
|
file, line, func, dev, str_limit);
|
|
|
|
|
|
|
|
if (NULL != str_limit) free(str_limit);
|
2007-01-24 22:25:40 +00:00
|
|
|
} else {
|
2013-02-12 21:10:11 +00:00
|
|
|
opal_show_help("help-mpi-btl-openib.txt", "init-fail-create-q",
|
2014-10-03 14:19:48 -07:00
|
|
|
true, opal_process_info.nodename,
|
2007-01-24 22:25:40 +00:00
|
|
|
file, line, func, strerror(errno), errno, dev);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-06-02 12:54:56 +00:00
|
|
|
static inline struct ibv_cq *create_cq_compat(struct ibv_context *context,
|
2008-01-09 10:05:41 +00:00
|
|
|
int cqe, void *cq_context, struct ibv_comp_channel *channel,
|
|
|
|
int comp_vector)
|
|
|
|
{
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
#if OPAL_IBV_CREATE_CQ_ARGS == 3
|
2008-01-09 10:05:41 +00:00
|
|
|
return ibv_create_cq(context, cqe, channel);
|
|
|
|
#else
|
2008-01-21 12:11:18 +00:00
|
|
|
return ibv_create_cq(context, cqe, cq_context, channel, comp_vector);
|
2008-01-09 10:05:41 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2012-07-10 16:53:27 +00:00
|
|
|
static int adjust_cq(mca_btl_openib_device_t *device, const int cq)
|
2008-01-09 10:05:41 +00:00
|
|
|
{
|
2012-07-10 16:53:27 +00:00
|
|
|
uint32_t cq_size = device->cq_size[cq];
|
2008-01-09 10:05:41 +00:00
|
|
|
|
2012-07-10 16:53:27 +00:00
|
|
|
/* make sure we don't exceed the maximum CQ size and that we
|
|
|
|
* don't size the queue smaller than otherwise requested
|
|
|
|
*/
|
|
|
|
if(cq_size < mca_btl_openib_component.ib_cq_size[cq])
|
|
|
|
cq_size = mca_btl_openib_component.ib_cq_size[cq];
|
2008-01-09 10:05:41 +00:00
|
|
|
|
2012-07-10 16:53:27 +00:00
|
|
|
if(cq_size > (uint32_t)device->ib_dev_attr.max_cqe)
|
|
|
|
cq_size = device->ib_dev_attr.max_cqe;
|
2008-01-09 10:05:41 +00:00
|
|
|
|
2012-07-10 16:53:27 +00:00
|
|
|
if(NULL == device->ib_cq[cq]) {
|
|
|
|
device->ib_cq[cq] = create_cq_compat(device->ib_dev_context, cq_size,
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
#if OPAL_ENABLE_PROGRESS_THREADS == 1
|
2012-07-10 16:53:27 +00:00
|
|
|
device, device->ib_channel,
|
2014-06-25 20:43:28 +00:00
|
|
|
#else
|
|
|
|
NULL, NULL,
|
|
|
|
#endif
|
2012-07-10 16:53:27 +00:00
|
|
|
0);
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2008-07-23 00:28:59 +00:00
|
|
|
if (NULL == device->ib_cq[cq]) {
|
2009-06-18 12:24:39 +00:00
|
|
|
mca_btl_openib_show_init_error(__FILE__, __LINE__, "ibv_create_cq",
|
|
|
|
ibv_get_device_name(device->ib_dev));
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_ERROR;
|
2008-01-09 10:05:41 +00:00
|
|
|
}
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
#if OPAL_ENABLE_PROGRESS_THREADS == 1
|
2008-07-23 00:28:59 +00:00
|
|
|
if(ibv_req_notify_cq(device->ib_cq[cq], 0)) {
|
2009-06-18 12:24:39 +00:00
|
|
|
mca_btl_openib_show_init_error(__FILE__, __LINE__,
|
|
|
|
"ibv_req_notify_cq",
|
|
|
|
ibv_get_device_name(device->ib_dev));
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_ERROR;
|
2008-01-09 10:05:41 +00:00
|
|
|
}
|
|
|
|
|
2008-07-23 00:28:59 +00:00
|
|
|
if (!device->progress) {
|
2008-01-09 10:05:41 +00:00
|
|
|
int rc;
|
2008-07-23 00:28:59 +00:00
|
|
|
device->progress = true;
|
|
|
|
if(OPAL_SUCCESS != (rc = opal_thread_start(&device->thread))) {
|
2008-01-09 10:05:41 +00:00
|
|
|
BTL_ERROR(("Unable to create progress thread, retval=%d", rc));
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
}
|
2014-06-25 20:43:28 +00:00
|
|
|
#endif
|
2008-01-09 10:05:41 +00:00
|
|
|
}
|
2012-07-10 16:53:27 +00:00
|
|
|
#ifdef HAVE_IBV_RESIZE_CQ
|
|
|
|
else if (cq_size > mca_btl_openib_component.ib_cq_size[cq]){
|
|
|
|
int rc;
|
|
|
|
rc = ibv_resize_cq(device->ib_cq[cq], cq_size);
|
|
|
|
/* For ConnectX the resize CQ is not implemented and verbs returns -ENOSYS
|
|
|
|
* but should return ENOSYS. So it is reason for abs */
|
|
|
|
if(rc && ENOSYS != abs(rc)) {
|
|
|
|
BTL_ERROR(("cannot resize completion queue, error: %d", rc));
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_ERROR;
|
2012-07-10 16:53:27 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
2008-01-09 10:05:41 +00:00
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2008-01-09 10:05:41 +00:00
|
|
|
}
|
2010-01-07 17:39:18 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* In this function we check if the device supports srq limit
|
|
|
|
event. We create the temporary srq, post some receive buffers - in
|
|
|
|
order to prevent srq limit event immediately and call the
|
|
|
|
"ibv_modify_srq" function. If a return value of the function not
|
|
|
|
success => our decision that the device doesn't support this
|
|
|
|
capability. */
|
2009-12-16 14:05:35 +00:00
|
|
|
static int check_if_device_support_modify_srq(mca_btl_openib_module_t *openib_btl)
|
|
|
|
{
|
|
|
|
char buff;
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
int rc = OPAL_SUCCESS;
|
2009-12-16 14:05:35 +00:00
|
|
|
|
|
|
|
struct ibv_srq* dummy_srq = NULL;
|
|
|
|
struct ibv_srq_attr modify_attr;
|
|
|
|
|
|
|
|
struct ibv_sge sge_elem;
|
2010-01-07 17:39:18 +00:00
|
|
|
struct ibv_recv_wr wr1, wr2, *bad_wr;
|
2009-12-16 14:05:35 +00:00
|
|
|
|
|
|
|
struct ibv_srq_init_attr init_attr;
|
|
|
|
memset(&init_attr, 0, sizeof(struct ibv_srq_init_attr));
|
|
|
|
|
|
|
|
init_attr.attr.max_wr = 3;
|
|
|
|
init_attr.attr.max_sge = 1;
|
|
|
|
|
|
|
|
dummy_srq = ibv_create_srq(openib_btl->device->ib_pd, &init_attr);
|
|
|
|
if(NULL == dummy_srq) {
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
rc = OPAL_ERROR;
|
2010-04-12 11:28:44 +00:00
|
|
|
return rc;
|
2009-12-16 14:05:35 +00:00
|
|
|
}
|
|
|
|
|
2014-01-20 15:44:45 +00:00
|
|
|
sge_elem.addr = (uint64_t)((uintptr_t) &buff);
|
2009-12-16 14:05:35 +00:00
|
|
|
sge_elem.length = sizeof(buff);
|
|
|
|
|
|
|
|
wr1.num_sge = wr2.num_sge = 1;
|
|
|
|
wr1.sg_list = wr2.sg_list = &sge_elem;
|
|
|
|
|
|
|
|
wr1.next = &wr2;
|
|
|
|
wr2.next = NULL;
|
|
|
|
|
|
|
|
if(ibv_post_srq_recv(dummy_srq, &wr1, &bad_wr)) {
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
rc = OPAL_ERROR;
|
2009-12-16 14:05:35 +00:00
|
|
|
goto destroy_dummy_srq;
|
|
|
|
}
|
|
|
|
|
|
|
|
modify_attr.max_wr = 2;
|
|
|
|
modify_attr.max_sge = 1;
|
|
|
|
modify_attr.srq_limit = 1;
|
|
|
|
|
|
|
|
if(ibv_modify_srq(dummy_srq, &modify_attr, IBV_SRQ_LIMIT)) {
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
rc = OPAL_ERR_NOT_SUPPORTED;
|
2009-12-16 14:05:35 +00:00
|
|
|
goto destroy_dummy_srq;
|
|
|
|
}
|
|
|
|
|
|
|
|
destroy_dummy_srq:
|
|
|
|
if(ibv_destroy_srq(dummy_srq)) {
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
rc = OPAL_ERROR;
|
2009-12-16 14:05:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
2008-01-09 10:05:41 +00:00
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
/*
|
|
|
|
* create both the high and low priority completion queues
|
2008-01-09 10:05:41 +00:00
|
|
|
* and the shared receive queue (if requested)
|
2008-01-21 12:11:18 +00:00
|
|
|
*/
|
2008-01-09 10:05:41 +00:00
|
|
|
static int create_srq(mca_btl_openib_module_t *openib_btl)
|
|
|
|
{
|
2009-12-16 14:05:35 +00:00
|
|
|
int qp, rc = 0;
|
|
|
|
int32_t rd_num, rd_curr_num;
|
|
|
|
|
|
|
|
bool device_support_modify_srq = true;
|
|
|
|
|
|
|
|
/* Check if our device supports modify srq ability */
|
|
|
|
rc = check_if_device_support_modify_srq(openib_btl);
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if(OPAL_ERR_NOT_SUPPORTED == rc) {
|
2009-12-16 14:05:35 +00:00
|
|
|
device_support_modify_srq = false;
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
} else if(OPAL_SUCCESS != rc) {
|
2009-12-16 14:05:35 +00:00
|
|
|
mca_btl_openib_show_init_error(__FILE__, __LINE__,
|
|
|
|
"ibv_create_srq",
|
|
|
|
ibv_get_device_name(openib_btl->device->ib_dev));
|
2010-01-14 16:09:10 +00:00
|
|
|
return rc;
|
2009-12-16 14:05:35 +00:00
|
|
|
}
|
2008-01-09 10:05:41 +00:00
|
|
|
|
|
|
|
/* create the SRQ's */
|
2008-01-21 12:11:18 +00:00
|
|
|
for(qp = 0; qp < mca_btl_openib_component.num_qps; qp++) {
|
|
|
|
struct ibv_srq_init_attr attr;
|
2009-12-16 14:05:35 +00:00
|
|
|
memset(&attr, 0, sizeof(struct ibv_srq_init_attr));
|
2008-01-09 10:05:41 +00:00
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
if(!BTL_OPENIB_QP_TYPE_PP(qp)) {
|
|
|
|
attr.attr.max_wr = mca_btl_openib_component.qp_infos[qp].rd_num +
|
2008-01-09 10:05:41 +00:00
|
|
|
mca_btl_openib_component.qp_infos[qp].u.srq_qp.sd_max;
|
2008-06-11 16:31:39 +00:00
|
|
|
attr.attr.max_sge = 1;
|
2008-01-09 10:05:41 +00:00
|
|
|
openib_btl->qps[qp].u.srq_qp.rd_posted = 0;
|
|
|
|
#if HAVE_XRC
|
|
|
|
if(BTL_OPENIB_QP_TYPE_XRC(qp)) {
|
2015-01-07 13:27:25 +09:00
|
|
|
#if OPAL_HAVE_CONNECTX_XRC_DOMAINS
|
2014-12-09 18:43:15 +09:00
|
|
|
struct ibv_srq_init_attr_ex attr_ex;
|
|
|
|
memset(&attr_ex, 0, sizeof(struct ibv_srq_init_attr_ex));
|
|
|
|
attr_ex.attr.max_wr = attr.attr.max_wr;
|
|
|
|
attr_ex.attr.max_sge = attr.attr.max_sge;
|
|
|
|
attr_ex.comp_mask = IBV_SRQ_INIT_ATTR_TYPE | IBV_SRQ_INIT_ATTR_XRCD |
|
|
|
|
IBV_SRQ_INIT_ATTR_CQ | IBV_SRQ_INIT_ATTR_PD;
|
|
|
|
attr_ex.srq_type = IBV_SRQT_XRC;
|
|
|
|
attr_ex.xrcd = openib_btl->device->xrcd;
|
|
|
|
attr_ex.cq = openib_btl->device->ib_cq[qp_cq_prio(qp)];
|
|
|
|
attr_ex.pd = openib_btl->device->ib_pd;
|
|
|
|
|
|
|
|
openib_btl->qps[qp].u.srq_qp.srq =
|
|
|
|
ibv_create_srq_ex(openib_btl->device->ib_dev_context, &attr_ex);
|
|
|
|
#else
|
2008-01-09 10:05:41 +00:00
|
|
|
openib_btl->qps[qp].u.srq_qp.srq =
|
2008-07-23 00:28:59 +00:00
|
|
|
ibv_create_xrc_srq(openib_btl->device->ib_pd,
|
|
|
|
openib_btl->device->xrc_domain,
|
|
|
|
openib_btl->device->ib_cq[qp_cq_prio(qp)], &attr);
|
2014-12-09 18:43:15 +09:00
|
|
|
#endif
|
2008-01-09 10:05:41 +00:00
|
|
|
} else
|
|
|
|
#endif
|
|
|
|
{
|
2015-12-23 22:53:01 +06:00
|
|
|
opal_mutex_lock(&openib_btl->device->device_lock);
|
2008-01-09 10:05:41 +00:00
|
|
|
openib_btl->qps[qp].u.srq_qp.srq =
|
2008-07-23 00:28:59 +00:00
|
|
|
ibv_create_srq(openib_btl->device->ib_pd, &attr);
|
2015-12-23 22:53:01 +06:00
|
|
|
opal_mutex_unlock(&openib_btl->device->device_lock);
|
2008-01-09 10:05:41 +00:00
|
|
|
}
|
2008-01-21 12:11:18 +00:00
|
|
|
if (NULL == openib_btl->qps[qp].u.srq_qp.srq) {
|
2009-06-18 12:24:39 +00:00
|
|
|
mca_btl_openib_show_init_error(__FILE__, __LINE__,
|
|
|
|
"ibv_create_srq",
|
|
|
|
ibv_get_device_name(openib_btl->device->ib_dev));
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_ERROR;
|
2008-01-09 10:05:41 +00:00
|
|
|
}
|
2009-12-15 15:52:10 +00:00
|
|
|
|
2010-02-18 09:48:16 +00:00
|
|
|
{
|
|
|
|
opal_mutex_t *lock = &mca_btl_openib_component.srq_manager.lock;
|
|
|
|
opal_hash_table_t *srq_addr_table = &mca_btl_openib_component.srq_manager.srq_addr_table;
|
|
|
|
|
|
|
|
opal_mutex_lock(lock);
|
|
|
|
if (OPAL_SUCCESS != opal_hash_table_set_value_ptr(
|
|
|
|
srq_addr_table, &openib_btl->qps[qp].u.srq_qp.srq,
|
|
|
|
sizeof(struct ibv_srq*), (void*) openib_btl)) {
|
|
|
|
BTL_ERROR(("SRQ Internal error."
|
|
|
|
" Failed to add element to mca_btl_openib_component.srq_manager.srq_addr_table\n"));
|
|
|
|
|
|
|
|
opal_mutex_unlock(lock);
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_ERROR;
|
2010-02-18 09:48:16 +00:00
|
|
|
}
|
|
|
|
opal_mutex_unlock(lock);
|
|
|
|
}
|
2009-12-15 15:52:10 +00:00
|
|
|
rd_num = mca_btl_openib_component.qp_infos[qp].rd_num;
|
|
|
|
rd_curr_num = openib_btl->qps[qp].u.srq_qp.rd_curr_num = mca_btl_openib_component.qp_infos[qp].u.srq_qp.rd_init;
|
|
|
|
|
2009-12-16 14:05:35 +00:00
|
|
|
if(true == mca_btl_openib_component.enable_srq_resize &&
|
|
|
|
true == device_support_modify_srq) {
|
2009-12-15 15:52:10 +00:00
|
|
|
if(0 == rd_curr_num) {
|
|
|
|
openib_btl->qps[qp].u.srq_qp.rd_curr_num = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
openib_btl->qps[qp].u.srq_qp.rd_low_local = rd_curr_num - (rd_curr_num >> 2);
|
|
|
|
openib_btl->qps[qp].u.srq_qp.srq_limit_event_flag = true;
|
|
|
|
} else {
|
|
|
|
openib_btl->qps[qp].u.srq_qp.rd_curr_num = rd_num;
|
|
|
|
openib_btl->qps[qp].u.srq_qp.rd_low_local = mca_btl_openib_component.qp_infos[qp].rd_low;
|
|
|
|
/* Not used in this case, but we don't need a garbage */
|
|
|
|
mca_btl_openib_component.qp_infos[qp].u.srq_qp.srq_limit = 0;
|
|
|
|
openib_btl->qps[qp].u.srq_qp.srq_limit_event_flag = false;
|
|
|
|
}
|
2008-01-09 10:05:41 +00:00
|
|
|
}
|
|
|
|
}
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2016-02-16 16:42:50 -07:00
|
|
|
openib_btl->srqs_created = true;
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2008-01-09 10:05:41 +00:00
|
|
|
}
|
|
|
|
|
2015-12-23 22:53:01 +06:00
|
|
|
static int openib_btl_prepare(struct mca_btl_openib_module_t* openib_btl)
|
|
|
|
{
|
|
|
|
int rc = OPAL_SUCCESS;
|
|
|
|
opal_mutex_lock(&openib_btl->ib_lock);
|
2016-02-16 16:42:50 -07:00
|
|
|
if (!openib_btl->srqs_created &&
|
2015-12-23 22:53:01 +06:00
|
|
|
(mca_btl_openib_component.num_srq_qps > 0 ||
|
|
|
|
mca_btl_openib_component.num_xrc_qps > 0)) {
|
|
|
|
rc = create_srq(openib_btl);
|
|
|
|
}
|
|
|
|
opal_mutex_unlock(&openib_btl->ib_lock);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-02-16 16:42:50 -07:00
|
|
|
static int openib_btl_size_queues(struct mca_btl_openib_module_t* openib_btl)
|
2008-01-09 10:05:41 +00:00
|
|
|
{
|
|
|
|
uint32_t send_cqes, recv_cqes;
|
2016-06-07 16:05:56 -06:00
|
|
|
int rc = OPAL_SUCCESS;
|
2008-07-23 00:28:59 +00:00
|
|
|
mca_btl_openib_device_t *device = openib_btl->device;
|
2016-06-07 16:05:56 -06:00
|
|
|
uint32_t requested[BTL_OPENIB_MAX_CQ];
|
2008-01-09 10:05:41 +00:00
|
|
|
|
2015-12-23 22:53:01 +06:00
|
|
|
opal_mutex_lock(&openib_btl->ib_lock);
|
2016-06-07 16:05:56 -06:00
|
|
|
|
|
|
|
for (int cq = 0 ; cq < BTL_OPENIB_MAX_CQ ; ++cq) {
|
|
|
|
requested[cq] = 0;
|
|
|
|
}
|
|
|
|
|
2012-07-10 16:53:27 +00:00
|
|
|
/* figure out reasonable sizes for completion queues */
|
2016-06-07 16:05:56 -06:00
|
|
|
for (int qp = 0 ; qp < mca_btl_openib_component.num_qps ; qp++) {
|
|
|
|
if (BTL_OPENIB_QP_TYPE_SRQ(qp)) {
|
2012-07-10 16:53:27 +00:00
|
|
|
send_cqes = mca_btl_openib_component.qp_infos[qp].u.srq_qp.sd_max;
|
|
|
|
recv_cqes = mca_btl_openib_component.qp_infos[qp].rd_num;
|
|
|
|
} else {
|
|
|
|
send_cqes = (mca_btl_openib_component.qp_infos[qp].rd_num +
|
2016-02-16 16:42:50 -07:00
|
|
|
mca_btl_openib_component.qp_infos[qp].u.pp_qp.rd_rsv) * openib_btl->num_peers;
|
2012-07-10 16:53:27 +00:00
|
|
|
recv_cqes = send_cqes;
|
|
|
|
}
|
2015-12-23 22:53:01 +06:00
|
|
|
|
2016-06-07 16:05:56 -06:00
|
|
|
requested[qp_cq_prio(qp)] += recv_cqes;
|
|
|
|
requested[BTL_OPENIB_LP_CQ] += send_cqes;
|
2012-07-10 16:53:27 +00:00
|
|
|
}
|
|
|
|
|
2016-06-07 16:05:56 -06:00
|
|
|
opal_mutex_lock (&openib_btl->device->device_lock);
|
|
|
|
for (int cq = 0 ; cq < BTL_OPENIB_MAX_CQ ; ++cq) {
|
|
|
|
if (requested[cq] < mca_btl_openib_component.ib_cq_size[cq]) {
|
|
|
|
requested[cq] = mca_btl_openib_component.ib_cq_size[cq];
|
2016-06-18 07:15:11 -07:00
|
|
|
} else if (requested[cq] > (uint32_t) openib_btl->device->ib_dev_attr.max_cqe) {
|
2016-06-07 16:05:56 -06:00
|
|
|
requested[cq] = openib_btl->device->ib_dev_attr.max_cqe;
|
|
|
|
}
|
2008-01-09 10:05:41 +00:00
|
|
|
|
2016-06-07 16:05:56 -06:00
|
|
|
if (openib_btl->device->cq_size[cq] < requested[cq]) {
|
|
|
|
openib_btl->device->cq_size[cq] = requested[cq];
|
2008-01-09 10:05:41 +00:00
|
|
|
|
2016-06-07 16:05:56 -06:00
|
|
|
rc = adjust_cq (device, cq);
|
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
opal_mutex_unlock (&openib_btl->device->device_lock);
|
2015-12-23 22:53:01 +06:00
|
|
|
opal_mutex_unlock(&openib_btl->ib_lock);
|
2016-06-07 16:05:56 -06:00
|
|
|
|
2008-01-09 10:05:41 +00:00
|
|
|
return rc;
|
|
|
|
}
|
2007-01-24 22:25:40 +00:00
|
|
|
|
2009-12-15 14:25:07 +00:00
|
|
|
mca_btl_openib_transport_type_t mca_btl_openib_get_transport_type(mca_btl_openib_module_t* openib_btl)
|
|
|
|
{
|
2011-07-04 14:00:41 +00:00
|
|
|
/* If we have a driver with RDMAoE supporting as the device struct contains the same type (IB) for
|
2009-12-15 14:25:07 +00:00
|
|
|
IBV_LINK_LAYER_INFINIBAND and IBV_LINK_LAYER_ETHERNET link layers and the single way
|
|
|
|
to detect this fact is to check their link_layer fields in a port_attr struct.
|
|
|
|
If our driver doesn't support this feature => the checking of transport type in device struct will be enough.
|
|
|
|
If the driver doesn't support completely transport types =>
|
|
|
|
our assumption that it is very old driver - that supports IB devices only */
|
|
|
|
|
|
|
|
#ifdef HAVE_STRUCT_IBV_DEVICE_TRANSPORT_TYPE
|
|
|
|
switch(openib_btl->device->ib_dev->transport_type) {
|
|
|
|
case IBV_TRANSPORT_IB:
|
2013-08-22 17:44:20 +00:00
|
|
|
#if HAVE_DECL_IBV_LINK_LAYER_ETHERNET
|
2009-12-15 14:25:07 +00:00
|
|
|
switch(openib_btl->ib_port_attr.link_layer) {
|
|
|
|
case IBV_LINK_LAYER_ETHERNET:
|
|
|
|
return MCA_BTL_OPENIB_TRANSPORT_RDMAOE;
|
|
|
|
|
|
|
|
case IBV_LINK_LAYER_INFINIBAND:
|
|
|
|
return MCA_BTL_OPENIB_TRANSPORT_IB;
|
|
|
|
/* It is not possible that a device struct contains
|
|
|
|
IB transport and port was configured to IBV_LINK_LAYER_UNSPECIFIED */
|
|
|
|
case IBV_LINK_LAYER_UNSPECIFIED:
|
|
|
|
default:
|
|
|
|
return MCA_BTL_OPENIB_TRANSPORT_UNKNOWN;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
return MCA_BTL_OPENIB_TRANSPORT_IB;
|
|
|
|
|
|
|
|
case IBV_TRANSPORT_IWARP:
|
|
|
|
return MCA_BTL_OPENIB_TRANSPORT_IWARP;
|
|
|
|
|
2011-07-04 14:00:41 +00:00
|
|
|
case IBV_TRANSPORT_UNKNOWN:
|
2009-12-15 14:25:07 +00:00
|
|
|
default:
|
|
|
|
return MCA_BTL_OPENIB_TRANSPORT_UNKNOWN;
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
return MCA_BTL_OPENIB_TRANSPORT_IB;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2011-07-04 14:00:41 +00:00
|
|
|
static int mca_btl_openib_tune_endpoint(mca_btl_openib_module_t* openib_btl,
|
2009-12-15 14:25:07 +00:00
|
|
|
mca_btl_base_endpoint_t* endpoint)
|
|
|
|
{
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
opal_btl_openib_ini_values_t values;
|
2009-12-15 14:25:07 +00:00
|
|
|
char* recv_qps = NULL;
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
int ret;
|
2009-12-15 14:25:07 +00:00
|
|
|
|
|
|
|
if(mca_btl_openib_get_transport_type(openib_btl) != endpoint->rem_info.rem_transport_type) {
|
2013-02-12 21:10:11 +00:00
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
As per the email discussion, revise the sparse handling of hostnames so that we avoid potential infinite loops while allowing large-scale users to improve their startup time:
* add a new MCA param orte_hostname_cutoff to specify the number of nodes at which we stop including hostnames. This defaults to INT_MAX => always include hostnames. If a value is given, then we will include hostnames for any allocation smaller than the given limit.
* remove ompi_proc_get_hostname. Replace all occurrences with a direct link to ompi_proc_t's proc_hostname, protected by appropriate "if NULL"
* modify the OMPI-ORTE integration component so that any call to modex_recv automatically loads the ompi_proc_t->proc_hostname field as well as returning the requested info. Thus, any process whose modex info you retrieve will automatically receive the hostname. Note that on-demand retrieval is still enabled - i.e., if we are running under direct launch with PMI, the hostname will be fetched upon first call to modex_recv, and then the ompi_proc_t->proc_hostname field will be loaded
* removed a stale MCA param "mpi_keep_peer_hostnames" that was no longer used anywhere in the code base
* added an envar lookup in ess/pmi for the number of nodes in the allocation. Sadly, PMI itself doesn't provide that info, so we have to get it a different way. Currently, we support PBS-based systems and SLURM - for any other, rank0 will emit a warning and we assume max number of daemons so we will always retain hostnames
This commit was SVN r29052.
2013-08-20 18:59:36 +00:00
|
|
|
"conflicting transport types", true,
|
2014-10-03 14:19:48 -07:00
|
|
|
opal_process_info.nodename,
|
As per the email discussion, revise the sparse handling of hostnames so that we avoid potential infinite loops while allowing large-scale users to improve their startup time:
* add a new MCA param orte_hostname_cutoff to specify the number of nodes at which we stop including hostnames. This defaults to INT_MAX => always include hostnames. If a value is given, then we will include hostnames for any allocation smaller than the given limit.
* remove ompi_proc_get_hostname. Replace all occurrences with a direct link to ompi_proc_t's proc_hostname, protected by appropriate "if NULL"
* modify the OMPI-ORTE integration component so that any call to modex_recv automatically loads the ompi_proc_t->proc_hostname field as well as returning the requested info. Thus, any process whose modex info you retrieve will automatically receive the hostname. Note that on-demand retrieval is still enabled - i.e., if we are running under direct launch with PMI, the hostname will be fetched upon first call to modex_recv, and then the ompi_proc_t->proc_hostname field will be loaded
* removed a stale MCA param "mpi_keep_peer_hostnames" that was no longer used anywhere in the code base
* added an envar lookup in ess/pmi for the number of nodes in the allocation. Sadly, PMI itself doesn't provide that info, so we have to get it a different way. Currently, we support PBS-based systems and SLURM - for any other, rank0 will emit a warning and we assume max number of daemons so we will always retain hostnames
This commit was SVN r29052.
2013-08-20 18:59:36 +00:00
|
|
|
ibv_get_device_name(openib_btl->device->ib_dev),
|
|
|
|
(openib_btl->device->ib_dev_attr).vendor_id,
|
|
|
|
(openib_btl->device->ib_dev_attr).vendor_part_id,
|
|
|
|
mca_btl_openib_transport_name_strings[mca_btl_openib_get_transport_type(openib_btl)],
|
2014-10-03 14:19:48 -07:00
|
|
|
opal_get_proc_hostname(endpoint->endpoint_proc->proc_opal),
|
As per the email discussion, revise the sparse handling of hostnames so that we avoid potential infinite loops while allowing large-scale users to improve their startup time:
* add a new MCA param orte_hostname_cutoff to specify the number of nodes at which we stop including hostnames. This defaults to INT_MAX => always include hostnames. If a value is given, then we will include hostnames for any allocation smaller than the given limit.
* remove ompi_proc_get_hostname. Replace all occurrences with a direct link to ompi_proc_t's proc_hostname, protected by appropriate "if NULL"
* modify the OMPI-ORTE integration component so that any call to modex_recv automatically loads the ompi_proc_t->proc_hostname field as well as returning the requested info. Thus, any process whose modex info you retrieve will automatically receive the hostname. Note that on-demand retrieval is still enabled - i.e., if we are running under direct launch with PMI, the hostname will be fetched upon first call to modex_recv, and then the ompi_proc_t->proc_hostname field will be loaded
* removed a stale MCA param "mpi_keep_peer_hostnames" that was no longer used anywhere in the code base
* added an envar lookup in ess/pmi for the number of nodes in the allocation. Sadly, PMI itself doesn't provide that info, so we have to get it a different way. Currently, we support PBS-based systems and SLURM - for any other, rank0 will emit a warning and we assume max number of daemons so we will always retain hostnames
This commit was SVN r29052.
2013-08-20 18:59:36 +00:00
|
|
|
endpoint->rem_info.rem_vendor_id,
|
|
|
|
endpoint->rem_info.rem_vendor_part_id,
|
|
|
|
mca_btl_openib_transport_name_strings[endpoint->rem_info.rem_transport_type]);
|
2011-07-04 14:00:41 +00:00
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_ERROR;
|
2009-12-15 14:25:07 +00:00
|
|
|
}
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
memset(&values, 0, sizeof(opal_btl_openib_ini_values_t));
|
|
|
|
ret = opal_btl_openib_ini_query(endpoint->rem_info.rem_vendor_id,
|
2009-12-15 14:25:07 +00:00
|
|
|
endpoint->rem_info.rem_vendor_part_id, &values);
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if (OPAL_SUCCESS != ret &&
|
|
|
|
OPAL_ERR_NOT_FOUND != ret) {
|
2013-02-12 21:10:11 +00:00
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
2009-12-15 14:25:07 +00:00
|
|
|
"error in device init", true,
|
2014-10-03 14:19:48 -07:00
|
|
|
opal_process_info.nodename,
|
2009-12-15 14:25:07 +00:00
|
|
|
ibv_get_device_name(openib_btl->device->ib_dev));
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(openib_btl->device->mtu < endpoint->rem_info.rem_mtu) {
|
2011-07-04 14:00:41 +00:00
|
|
|
endpoint->rem_info.rem_mtu = openib_btl->device->mtu;
|
2009-12-15 14:25:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
endpoint->use_eager_rdma = openib_btl->device->use_eager_rdma &
|
|
|
|
endpoint->use_eager_rdma;
|
|
|
|
|
|
|
|
/* Receive queues checking */
|
|
|
|
|
|
|
|
/* In this check we assume that the command line or INI file parameters are the same
|
|
|
|
for all processes on all machines. The assumption is correct for 99.9999% of users,
|
|
|
|
if a user distributes different INI files or parameters for different node/procs,
|
|
|
|
it is on his own responsibility */
|
|
|
|
switch(mca_btl_openib_component.receive_queues_source) {
|
2014-11-04 14:25:02 -07:00
|
|
|
case MCA_BASE_VAR_SOURCE_COMMAND_LINE:
|
|
|
|
case MCA_BASE_VAR_SOURCE_ENV:
|
|
|
|
case MCA_BASE_VAR_SOURCE_FILE:
|
|
|
|
case MCA_BASE_VAR_SOURCE_SET:
|
|
|
|
case MCA_BASE_VAR_SOURCE_OVERRIDE:
|
|
|
|
break;
|
2009-12-15 14:25:07 +00:00
|
|
|
|
2011-07-04 14:00:41 +00:00
|
|
|
/* If the queues configuration was set from command line
|
2009-12-15 14:25:07 +00:00
|
|
|
(with --mca btl_openib_receive_queues parameter) => both sides have a same configuration */
|
|
|
|
|
|
|
|
/* In this case the local queues configuration was gotten from INI file =>
|
2011-07-04 14:00:41 +00:00
|
|
|
not possible that remote side got its queues configuration from command line =>
|
2009-12-15 14:25:07 +00:00
|
|
|
(by prio) the configuration was set from INI file or (if not configure)
|
|
|
|
by default queues configuration */
|
2014-11-04 14:25:02 -07:00
|
|
|
case BTL_OPENIB_RQ_SOURCE_DEVICE_INI:
|
|
|
|
if(NULL != values.receive_queues) {
|
|
|
|
recv_qps = values.receive_queues;
|
|
|
|
} else {
|
|
|
|
recv_qps = mca_btl_openib_component.default_recv_qps;
|
|
|
|
}
|
2009-12-15 14:25:07 +00:00
|
|
|
|
2014-11-04 14:25:02 -07:00
|
|
|
if(0 != strcmp(mca_btl_openib_component.receive_queues,
|
|
|
|
recv_qps)) {
|
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
|
|
|
"unsupported queues configuration", true,
|
|
|
|
opal_process_info.nodename,
|
|
|
|
ibv_get_device_name(openib_btl->device->ib_dev),
|
|
|
|
(openib_btl->device->ib_dev_attr).vendor_id,
|
|
|
|
(openib_btl->device->ib_dev_attr).vendor_part_id,
|
|
|
|
mca_btl_openib_component.receive_queues,
|
|
|
|
opal_get_proc_hostname(endpoint->endpoint_proc->proc_opal),
|
|
|
|
endpoint->rem_info.rem_vendor_id,
|
|
|
|
endpoint->rem_info.rem_vendor_part_id,
|
|
|
|
recv_qps);
|
2009-12-15 14:25:07 +00:00
|
|
|
|
2014-11-04 14:25:02 -07:00
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
break;
|
2009-12-15 14:25:07 +00:00
|
|
|
|
2011-07-04 14:00:41 +00:00
|
|
|
/* If the local queues configuration was set
|
2009-12-15 14:25:07 +00:00
|
|
|
by default queues => check all possible cases for remote side and compare */
|
2014-11-04 14:25:02 -07:00
|
|
|
case MCA_BASE_VAR_SOURCE_DEFAULT:
|
|
|
|
if(NULL != values.receive_queues) {
|
|
|
|
if(0 != strcmp(mca_btl_openib_component.receive_queues,
|
|
|
|
values.receive_queues)) {
|
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
2009-12-15 14:25:07 +00:00
|
|
|
"unsupported queues configuration", true,
|
2014-10-03 14:19:48 -07:00
|
|
|
opal_process_info.nodename,
|
2009-12-15 14:25:07 +00:00
|
|
|
ibv_get_device_name(openib_btl->device->ib_dev),
|
|
|
|
(openib_btl->device->ib_dev_attr).vendor_id,
|
|
|
|
(openib_btl->device->ib_dev_attr).vendor_part_id,
|
|
|
|
mca_btl_openib_component.receive_queues,
|
2014-10-03 14:19:48 -07:00
|
|
|
opal_get_proc_hostname(endpoint->endpoint_proc->proc_opal),
|
2009-12-15 14:25:07 +00:00
|
|
|
endpoint->rem_info.rem_vendor_id,
|
|
|
|
endpoint->rem_info.rem_vendor_part_id,
|
|
|
|
values.receive_queues);
|
|
|
|
|
2014-11-04 14:25:02 -07:00
|
|
|
return OPAL_ERROR;
|
2009-12-15 14:25:07 +00:00
|
|
|
}
|
2014-11-04 14:25:02 -07:00
|
|
|
}
|
|
|
|
break;
|
2009-12-15 14:25:07 +00:00
|
|
|
}
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2009-12-15 14:25:07 +00:00
|
|
|
}
|
|
|
|
|
2015-12-23 22:53:01 +06:00
|
|
|
static int prepare_device_for_use (mca_btl_openib_device_t *device)
|
2014-01-06 19:51:30 +00:00
|
|
|
{
|
|
|
|
mca_btl_openib_frag_init_data_t *init_data;
|
2015-12-23 22:53:01 +06:00
|
|
|
int rc = OPAL_SUCCESS, length;
|
|
|
|
|
|
|
|
opal_mutex_lock(&device->device_lock);
|
2014-01-06 19:51:30 +00:00
|
|
|
|
|
|
|
if (device->ready_for_use) {
|
2015-12-23 22:53:01 +06:00
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* For each btl module that we made - find every
|
|
|
|
base device that doesn't have device->qps setup on it yet (remember
|
|
|
|
that some modules may share the same device, so when going through
|
|
|
|
to loop, we may hit a device that was already setup earlier in
|
|
|
|
the loop).
|
|
|
|
|
|
|
|
We may to call for prepare_device_for_use() only after adding the btl
|
|
|
|
to mca_btl_openib_component.openib_btls, since the prepare_device_for_use
|
|
|
|
adds device to async thread that require access to
|
|
|
|
mca_btl_openib_component.openib_btls.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Setup the device qps info */
|
|
|
|
device->qps = (mca_btl_openib_device_qp_t*)
|
|
|
|
calloc(mca_btl_openib_component.num_qps,
|
|
|
|
sizeof(mca_btl_openib_device_qp_t));
|
|
|
|
if (NULL == device->qps) {
|
|
|
|
BTL_ERROR(("Failed malloc: %s:%d", __FILE__, __LINE__));
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = OPAL_ERR_OUT_OF_RESOURCE;
|
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for (int qp_index = 0 ; qp_index < mca_btl_openib_component.num_qps ; qp_index++) {
|
2015-02-19 13:41:41 -07:00
|
|
|
OBJ_CONSTRUCT(&device->qps[qp_index].send_free, opal_free_list_t);
|
|
|
|
OBJ_CONSTRUCT(&device->qps[qp_index].recv_free, opal_free_list_t);
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
|
2015-10-06 12:47:09 -06:00
|
|
|
device->got_fatal_event = false;
|
|
|
|
device->got_port_event = false;
|
|
|
|
mca_btl_openib_async_add_device (device);
|
2014-01-06 19:51:30 +00:00
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
#if OPAL_ENABLE_PROGRESS_THREADS == 1
|
2014-01-06 19:51:30 +00:00
|
|
|
/* Prepare data for thread, but not starting it */
|
|
|
|
OBJ_CONSTRUCT(&device->thread, opal_thread_t);
|
|
|
|
device->thread.t_run = mca_btl_openib_progress_thread;
|
|
|
|
device->thread.t_arg = device;
|
|
|
|
device->progress = false;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if HAVE_XRC
|
|
|
|
/* if user configured to run with XRC qp and the device doesn't
|
|
|
|
* support it - we should ignore this device. Maybe we have another
|
|
|
|
* one that has XRC support
|
|
|
|
*/
|
|
|
|
if (!(device->ib_dev_attr.device_cap_flags & IBV_DEVICE_XRC) &&
|
|
|
|
MCA_BTL_XRC_ENABLED) {
|
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
|
|
|
"XRC on device without XRC support", true,
|
|
|
|
mca_btl_openib_component.num_xrc_qps,
|
|
|
|
ibv_get_device_name(device->ib_dev),
|
2014-07-26 21:48:23 +00:00
|
|
|
opal_process_info.nodename);
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = OPAL_ERROR;
|
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (MCA_BTL_XRC_ENABLED) {
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if (OPAL_SUCCESS != mca_btl_openib_open_xrc_domain(device)) {
|
2014-01-06 19:51:30 +00:00
|
|
|
BTL_ERROR(("XRC Internal error. Failed to open xrc domain"));
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = OPAL_ERROR;
|
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
device->endpoints = OBJ_NEW(opal_pointer_array_t);
|
|
|
|
opal_pointer_array_init(device->endpoints, 10, INT_MAX, 10);
|
|
|
|
opal_pointer_array_add(&mca_btl_openib_component.devices, device);
|
|
|
|
if (mca_btl_openib_component.max_eager_rdma > 0 &&
|
|
|
|
device->use_eager_rdma) {
|
|
|
|
device->eager_rdma_buffers =
|
2015-05-27 12:17:59 -06:00
|
|
|
(mca_btl_base_endpoint_t **) calloc((size_t) mca_btl_openib_component.max_eager_rdma * device->btls,
|
2014-01-06 19:51:30 +00:00
|
|
|
sizeof(mca_btl_openib_endpoint_t*));
|
|
|
|
if(NULL == device->eager_rdma_buffers) {
|
|
|
|
BTL_ERROR(("Memory allocation fails"));
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = OPAL_ERR_OUT_OF_RESOURCE;
|
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
init_data = (mca_btl_openib_frag_init_data_t *) malloc(sizeof(mca_btl_openib_frag_init_data_t));
|
|
|
|
if (NULL == init_data) {
|
|
|
|
if (mca_btl_openib_component.max_eager_rdma > 0 &&
|
|
|
|
device->use_eager_rdma) {
|
|
|
|
/* cleanup */
|
|
|
|
free (device->eager_rdma_buffers);
|
|
|
|
device->eager_rdma_buffers = NULL;
|
|
|
|
}
|
|
|
|
BTL_ERROR(("Memory allocation fails"));
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = OPAL_ERR_OUT_OF_RESOURCE;
|
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
length = sizeof(mca_btl_openib_header_t) +
|
|
|
|
sizeof(mca_btl_openib_footer_t) +
|
|
|
|
sizeof(mca_btl_openib_eager_rdma_header_t);
|
|
|
|
|
|
|
|
init_data->order = MCA_BTL_NO_ORDER;
|
|
|
|
init_data->list = &device->send_free_control;
|
|
|
|
|
2015-02-19 13:41:41 -07:00
|
|
|
rc = opal_free_list_init(&device->send_free_control,
|
2014-01-06 19:51:30 +00:00
|
|
|
sizeof(mca_btl_openib_send_control_frag_t), opal_cache_line_size,
|
|
|
|
OBJ_CLASS(mca_btl_openib_send_control_frag_t), length,
|
|
|
|
mca_btl_openib_component.buffer_alignment,
|
|
|
|
mca_btl_openib_component.ib_free_list_num, -1,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
2015-11-02 12:07:08 -07:00
|
|
|
device->mpool, 0, device->rcache, mca_btl_openib_frag_init,
|
2014-01-06 19:51:30 +00:00
|
|
|
init_data);
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if (OPAL_SUCCESS != rc) {
|
2014-01-06 19:51:30 +00:00
|
|
|
/* If we're "out of memory", this usually means that we ran
|
|
|
|
out of registered memory, so show that error message */
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if (OPAL_ERR_OUT_OF_RESOURCE == rc ||
|
|
|
|
OPAL_ERR_TEMP_OUT_OF_RESOURCE == rc) {
|
2014-01-06 19:51:30 +00:00
|
|
|
errno = ENOMEM;
|
|
|
|
mca_btl_openib_show_init_error(__FILE__, __LINE__,
|
2015-02-19 13:41:41 -07:00
|
|
|
"opal_free_list_init",
|
2014-01-06 19:51:30 +00:00
|
|
|
ibv_get_device_name(device->ib_dev));
|
|
|
|
}
|
2015-12-23 22:53:01 +06:00
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* setup all the qps */
|
|
|
|
for (int qp = 0 ; qp < mca_btl_openib_component.num_qps ; qp++) {
|
|
|
|
init_data = (mca_btl_openib_frag_init_data_t *) malloc(sizeof(mca_btl_openib_frag_init_data_t));
|
|
|
|
if (NULL == init_data) {
|
|
|
|
BTL_ERROR(("Memory allocation fails"));
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = OPAL_ERR_OUT_OF_RESOURCE;
|
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Initialize pool of send fragments */
|
|
|
|
length = sizeof(mca_btl_openib_header_t) +
|
|
|
|
sizeof(mca_btl_openib_header_coalesced_t) +
|
|
|
|
sizeof(mca_btl_openib_control_header_t) +
|
|
|
|
sizeof(mca_btl_openib_footer_t) +
|
|
|
|
mca_btl_openib_component.qp_infos[qp].size;
|
|
|
|
|
|
|
|
init_data->order = qp;
|
|
|
|
init_data->list = &device->qps[qp].send_free;
|
|
|
|
|
2015-02-19 13:41:41 -07:00
|
|
|
rc = opal_free_list_init (init_data->list,
|
2014-01-06 19:51:30 +00:00
|
|
|
sizeof(mca_btl_openib_send_frag_t), opal_cache_line_size,
|
|
|
|
OBJ_CLASS(mca_btl_openib_send_frag_t), length,
|
|
|
|
mca_btl_openib_component.buffer_alignment,
|
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
mca_btl_openib_component.ib_free_list_max,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
2015-11-02 12:07:08 -07:00
|
|
|
device->mpool, 0, device->rcache, mca_btl_openib_frag_init,
|
2015-02-19 13:41:41 -07:00
|
|
|
init_data);
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if (OPAL_SUCCESS != rc) {
|
2014-01-06 19:51:30 +00:00
|
|
|
/* If we're "out of memory", this usually means that we
|
|
|
|
ran out of registered memory, so show that error
|
|
|
|
message */
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if (OPAL_ERR_OUT_OF_RESOURCE == rc ||
|
|
|
|
OPAL_ERR_TEMP_OUT_OF_RESOURCE == rc) {
|
2014-01-06 19:51:30 +00:00
|
|
|
errno = ENOMEM;
|
|
|
|
mca_btl_openib_show_init_error(__FILE__, __LINE__,
|
2015-02-19 13:41:41 -07:00
|
|
|
"opal_free_list_init",
|
2014-01-06 19:51:30 +00:00
|
|
|
ibv_get_device_name(device->ib_dev));
|
|
|
|
}
|
2015-12-23 22:53:01 +06:00
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
init_data = (mca_btl_openib_frag_init_data_t *) malloc(sizeof(mca_btl_openib_frag_init_data_t));
|
|
|
|
length = sizeof(mca_btl_openib_header_t) +
|
|
|
|
sizeof(mca_btl_openib_header_coalesced_t) +
|
|
|
|
sizeof(mca_btl_openib_control_header_t) +
|
|
|
|
sizeof(mca_btl_openib_footer_t) +
|
|
|
|
mca_btl_openib_component.qp_infos[qp].size;
|
|
|
|
|
|
|
|
init_data->order = qp;
|
|
|
|
init_data->list = &device->qps[qp].recv_free;
|
|
|
|
|
2015-02-19 13:41:41 -07:00
|
|
|
if(OPAL_SUCCESS != opal_free_list_init (init_data->list,
|
2014-01-06 19:51:30 +00:00
|
|
|
sizeof(mca_btl_openib_recv_frag_t), opal_cache_line_size,
|
|
|
|
OBJ_CLASS(mca_btl_openib_recv_frag_t),
|
|
|
|
length, mca_btl_openib_component.buffer_alignment,
|
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
mca_btl_openib_component.ib_free_list_max,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
2015-11-02 12:07:08 -07:00
|
|
|
device->mpool, 0, device->rcache, mca_btl_openib_frag_init,
|
2014-01-06 19:51:30 +00:00
|
|
|
init_data)) {
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = OPAL_ERROR;
|
|
|
|
goto exit;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
device->ready_for_use = true;
|
|
|
|
|
2015-12-23 22:53:01 +06:00
|
|
|
exit:
|
|
|
|
opal_mutex_unlock(&device->device_lock);
|
|
|
|
return rc;
|
2014-01-06 19:51:30 +00:00
|
|
|
}
|
2012-07-19 17:52:21 +00:00
|
|
|
|
2015-12-21 09:34:11 +06:00
|
|
|
static int init_ib_proc_nolock(mca_btl_openib_module_t* openib_btl, mca_btl_openib_proc_t* ib_proc,
|
2015-12-23 22:16:06 +06:00
|
|
|
volatile mca_btl_base_endpoint_t **endpoint_ptr,
|
2015-12-21 16:47:50 +06:00
|
|
|
int local_port_cnt, int btl_rank)
|
2015-12-21 09:01:48 +06:00
|
|
|
{
|
2015-12-21 09:34:11 +06:00
|
|
|
int rem_port_cnt, matching_port = -1, j, rc;
|
2015-12-21 09:01:48 +06:00
|
|
|
mca_btl_base_endpoint_t *endpoint;
|
|
|
|
opal_btl_openib_connect_base_module_t *local_cpc;
|
|
|
|
opal_btl_openib_connect_base_module_data_t *remote_cpc_data;
|
|
|
|
|
|
|
|
*endpoint_ptr = NULL;
|
|
|
|
|
|
|
|
/* check if the remote proc has any ports that:
|
|
|
|
- on the same subnet as the local proc, and
|
|
|
|
- on that subnet, has a CPC in common with the local proc
|
|
|
|
*/
|
|
|
|
|
|
|
|
rem_port_cnt = 0;
|
|
|
|
BTL_VERBOSE(("got %d port_infos ", ib_proc->proc_port_count));
|
|
|
|
for (j = 0; j < (int) ib_proc->proc_port_count; j++){
|
|
|
|
BTL_VERBOSE(("got a subnet %016" PRIx64,
|
|
|
|
ib_proc->proc_ports[j].pm_port_info.subnet_id));
|
|
|
|
if (ib_proc->proc_ports[j].pm_port_info.subnet_id ==
|
|
|
|
openib_btl->port_info.subnet_id) {
|
|
|
|
BTL_VERBOSE(("Got a matching subnet!"));
|
|
|
|
if (rem_port_cnt == btl_rank) {
|
|
|
|
matching_port = j;
|
|
|
|
}
|
|
|
|
rem_port_cnt++;
|
2016-03-16 10:52:06 +02:00
|
|
|
} else {
|
|
|
|
if (mca_btl_openib_component.allow_different_subnets) {
|
|
|
|
BTL_VERBOSE(("Using different subnets!"));
|
|
|
|
if (rem_port_cnt == btl_rank) {
|
|
|
|
matching_port = j;
|
|
|
|
}
|
|
|
|
rem_port_cnt++;
|
|
|
|
}
|
2015-12-21 09:01:48 +06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (0 == rem_port_cnt) {
|
|
|
|
/* no use trying to communicate with this endpoint */
|
|
|
|
BTL_VERBOSE(("No matching subnet id/CPC was found, moving on.. "));
|
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* If this process has multiple ports on a single subnet ID,
|
|
|
|
and the report proc also has multiple ports on this same
|
|
|
|
subnet ID, the default connection pattern is:
|
|
|
|
|
|
|
|
LOCAL REMOTE PEER
|
|
|
|
1st port on subnet X <--> 1st port on subnet X
|
|
|
|
2nd port on subnet X <--> 2nd port on subnet X
|
|
|
|
3nd port on subnet X <--> 3nd port on subnet X
|
|
|
|
...etc.
|
|
|
|
|
|
|
|
Note that the port numbers may not be contiguous, and they
|
|
|
|
may not be the same on either side. Hence the "1st", "2nd",
|
|
|
|
"3rd, etc. notation, above.
|
|
|
|
|
|
|
|
Hence, if the local "rank" of this module's port on the
|
|
|
|
subnet ID is greater than the total number of ports on the
|
|
|
|
peer on this same subnet, then we have no match. So skip
|
|
|
|
this connection. */
|
|
|
|
if (rem_port_cnt < local_port_cnt && btl_rank >= rem_port_cnt) {
|
|
|
|
BTL_VERBOSE(("Not enough remote ports on this subnet id, moving on.. "));
|
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Now that we have verified that we're on the same subnet and
|
|
|
|
the remote peer has enough ports, see if that specific port
|
|
|
|
on the peer has a matching CPC. */
|
|
|
|
assert(btl_rank <= ib_proc->proc_port_count);
|
|
|
|
assert(matching_port != -1);
|
|
|
|
if (OPAL_SUCCESS !=
|
|
|
|
opal_btl_openib_connect_base_find_match(openib_btl,
|
|
|
|
&(ib_proc->proc_ports[matching_port]),
|
|
|
|
&local_cpc,
|
|
|
|
&remote_cpc_data)) {
|
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* The btl_proc datastructure is shared by all IB BTL
|
|
|
|
* instances that are trying to reach this destination.
|
|
|
|
* Cache the peer instance on the btl_proc.
|
|
|
|
*/
|
|
|
|
endpoint = OBJ_NEW(mca_btl_openib_endpoint_t);
|
|
|
|
assert(((opal_object_t*)endpoint)->obj_reference_count == 1);
|
|
|
|
if(NULL == endpoint) {
|
|
|
|
return OPAL_ERR_OUT_OF_RESOURCE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_XRC
|
|
|
|
if (MCA_BTL_XRC_ENABLED) {
|
|
|
|
int rem_port_cnt = 0;
|
|
|
|
for(j = 0; j < (int) ib_proc->proc_port_count; j++) {
|
|
|
|
if(ib_proc->proc_ports[j].pm_port_info.subnet_id ==
|
|
|
|
openib_btl->port_info.subnet_id) {
|
|
|
|
if (rem_port_cnt == btl_rank)
|
|
|
|
break;
|
|
|
|
else
|
|
|
|
rem_port_cnt ++;
|
2016-03-16 10:52:06 +02:00
|
|
|
} else {
|
|
|
|
if (mca_btl_openib_component.allow_different_subnets) {
|
|
|
|
if (rem_port_cnt == btl_rank)
|
|
|
|
break;
|
|
|
|
else
|
|
|
|
rem_port_cnt ++;
|
|
|
|
}
|
2015-12-21 09:01:48 +06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
assert(rem_port_cnt == btl_rank);
|
|
|
|
/* Push the subnet/lid/jobid to xrc hash */
|
|
|
|
rc = mca_btl_openib_ib_address_add_new(
|
|
|
|
ib_proc->proc_ports[j].pm_port_info.lid,
|
|
|
|
ib_proc->proc_ports[j].pm_port_info.subnet_id,
|
|
|
|
ib_proc->proc_opal->proc_name.jobid, endpoint);
|
|
|
|
if (OPAL_SUCCESS != rc ) {
|
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
mca_btl_openib_endpoint_init(openib_btl, endpoint,
|
|
|
|
local_cpc,
|
|
|
|
&(ib_proc->proc_ports[matching_port]),
|
|
|
|
remote_cpc_data);
|
|
|
|
|
|
|
|
rc = mca_btl_openib_proc_insert(ib_proc, endpoint);
|
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
OBJ_RELEASE(endpoint);
|
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(OPAL_SUCCESS != mca_btl_openib_tune_endpoint(openib_btl, endpoint)) {
|
|
|
|
OBJ_RELEASE(endpoint);
|
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
|
2015-12-22 17:21:42 +06:00
|
|
|
/* protect device because several endpoints for different ib_proc's
|
|
|
|
* may be simultaneously initialized */
|
|
|
|
opal_mutex_lock(&openib_btl->device->device_lock);
|
2015-12-21 09:01:48 +06:00
|
|
|
endpoint->index = opal_pointer_array_add(openib_btl->device->endpoints, (void*)endpoint);
|
2015-12-22 17:21:42 +06:00
|
|
|
opal_mutex_unlock(&openib_btl->device->device_lock);
|
|
|
|
|
2015-12-21 09:01:48 +06:00
|
|
|
if( 0 > endpoint->index ) {
|
|
|
|
OBJ_RELEASE(endpoint);
|
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Tell the selected CPC that it won. NOTE: This call is
|
|
|
|
outside of / separate from mca_btl_openib_endpoint_init()
|
|
|
|
because this function likely needs the endpoint->index. */
|
|
|
|
if (NULL != local_cpc->cbm_endpoint_init) {
|
|
|
|
rc = local_cpc->cbm_endpoint_init(endpoint);
|
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
OBJ_RELEASE(endpoint);
|
|
|
|
return OPAL_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
*endpoint_ptr = endpoint;
|
|
|
|
return OPAL_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2015-12-23 22:16:06 +06:00
|
|
|
static int get_openib_btl_params(mca_btl_openib_module_t* openib_btl, int *port_cnt_ptr)
|
|
|
|
{
|
|
|
|
int port_cnt = 0, rank = -1, j;
|
|
|
|
for(j=0; j < mca_btl_openib_component.ib_num_btls; j++){
|
|
|
|
if(mca_btl_openib_component.openib_btls[j]->port_info.subnet_id
|
|
|
|
== openib_btl->port_info.subnet_id) {
|
|
|
|
if(openib_btl == mca_btl_openib_component.openib_btls[j]) {
|
|
|
|
rank = port_cnt;
|
|
|
|
}
|
|
|
|
port_cnt++;
|
2016-03-16 10:52:06 +02:00
|
|
|
} else {
|
|
|
|
if (mca_btl_openib_component.allow_different_subnets) {
|
|
|
|
if (openib_btl == mca_btl_openib_component.openib_btls[j]) {
|
|
|
|
rank = port_cnt;
|
|
|
|
}
|
|
|
|
port_cnt++;
|
|
|
|
}
|
2015-12-23 22:16:06 +06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
*port_cnt_ptr = port_cnt;
|
|
|
|
return rank;
|
|
|
|
}
|
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
/*
|
|
|
|
* add a proc to this btl module
|
2005-07-20 15:17:18 +00:00
|
|
|
* creates an endpoint that is setup on the
|
|
|
|
* first send to the endpoint
|
2008-01-21 12:11:18 +00:00
|
|
|
*/
|
2005-06-30 21:28:35 +00:00
|
|
|
int mca_btl_openib_add_procs(
|
2008-01-21 12:11:18 +00:00
|
|
|
struct mca_btl_base_module_t* btl,
|
|
|
|
size_t nprocs,
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
struct opal_proc_t **procs,
|
2008-01-21 12:11:18 +00:00
|
|
|
struct mca_btl_base_endpoint_t** peers,
|
2009-03-03 22:25:13 +00:00
|
|
|
opal_bitmap_t* reachable)
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
2005-07-12 13:38:54 +00:00
|
|
|
mca_btl_openib_module_t* openib_btl = (mca_btl_openib_module_t*)btl;
|
2015-12-24 17:22:55 +06:00
|
|
|
size_t nprocs_new_loc = 0, nprocs_new = 0;
|
|
|
|
int i,j, rc;
|
2007-01-12 22:42:20 +00:00
|
|
|
int lcl_subnet_id_port_cnt = 0;
|
2007-01-08 17:20:09 +00:00
|
|
|
int btl_rank = 0;
|
2015-12-23 22:16:06 +06:00
|
|
|
volatile mca_btl_base_endpoint_t* endpoint;
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2015-12-23 22:16:06 +06:00
|
|
|
btl_rank = get_openib_btl_params(openib_btl, &lcl_subnet_id_port_cnt);
|
|
|
|
if( 0 > btl_rank ){
|
|
|
|
return OPAL_ERR_NOT_FOUND;
|
2007-01-12 22:42:20 +00:00
|
|
|
}
|
2007-06-14 10:27:11 +00:00
|
|
|
|
2007-11-28 07:18:59 +00:00
|
|
|
#if HAVE_XRC
|
|
|
|
if(MCA_BTL_XRC_ENABLED &&
|
|
|
|
NULL == mca_btl_openib_component.ib_addr_table.ht_table) {
|
|
|
|
if(OPAL_SUCCESS != opal_hash_table_init(
|
|
|
|
&mca_btl_openib_component.ib_addr_table, nprocs)) {
|
2008-05-02 11:52:33 +00:00
|
|
|
BTL_ERROR(("XRC internal error. Failed to allocate ib_table"));
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_ERROR;
|
2007-11-28 07:18:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = prepare_device_for_use (openib_btl->device);
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if (OPAL_SUCCESS != rc) {
|
2014-01-06 19:51:30 +00:00
|
|
|
BTL_ERROR(("could not prepare openib device for use"));
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2016-02-16 16:42:50 -07:00
|
|
|
if (0 == openib_btl->num_peers) {
|
|
|
|
/* ensure completion queues are created before attempting to
|
|
|
|
* make a loop-back queue pair */
|
|
|
|
rc = openib_btl_size_queues(openib_btl);
|
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
BTL_ERROR(("error creating cqs"));
|
|
|
|
return rc;
|
|
|
|
}
|
2015-12-23 22:53:01 +06:00
|
|
|
}
|
|
|
|
|
2015-12-24 17:22:55 +06:00
|
|
|
/* prepare all proc's and account them properly */
|
|
|
|
for (i = 0, nprocs_new_loc = 0 ; i < (int) nprocs; i++) {
|
|
|
|
struct opal_proc_t* proc = procs[i];
|
|
|
|
mca_btl_openib_proc_t* ib_proc;
|
|
|
|
|
|
|
|
#if defined(HAVE_STRUCT_IBV_DEVICE_TRANSPORT_TYPE)
|
|
|
|
/* Most current iWARP adapters (June 2008) cannot handle
|
|
|
|
talking to other processes on the same host (!) -- so mark
|
|
|
|
them as unreachable (need to use sm). So for the moment,
|
|
|
|
we'll just mark any local peer on an iWARP NIC as
|
|
|
|
unreachable. See trac ticket #1352. */
|
|
|
|
if (IBV_TRANSPORT_IWARP == openib_btl->device->ib_dev->transport_type &&
|
|
|
|
OPAL_PROC_ON_LOCAL_NODE(proc->proc_flags)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if(NULL == (ib_proc = mca_btl_openib_proc_get_locked(proc)) ) {
|
|
|
|
/* if we don't have connection info for this process, it's
|
|
|
|
* okay because some other method might be able to reach it,
|
|
|
|
* so just mark it as unreachable by us */
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* account this openib_btl in this proc */
|
|
|
|
rc = mca_btl_openib_proc_reg_btl(ib_proc, openib_btl);
|
|
|
|
|
|
|
|
opal_mutex_unlock( &ib_proc->proc_lock );
|
|
|
|
|
|
|
|
switch( rc ){
|
|
|
|
case OPAL_SUCCESS:
|
|
|
|
/* this is a new process to this openib btl */
|
|
|
|
nprocs_new++;
|
|
|
|
if (OPAL_PROC_ON_LOCAL_NODE(proc->proc_flags)) {
|
|
|
|
nprocs_new_loc ++;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case OPAL_ERR_RESOURCE_BUSY:
|
|
|
|
/* process was accounted earlier in this openib btl */
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
/* unexpected error, e.g. out of mem */
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-02-16 16:42:50 -07:00
|
|
|
if (nprocs_new) {
|
2016-06-07 16:05:56 -06:00
|
|
|
opal_atomic_add_32 (&openib_btl->num_peers, nprocs_new);
|
2016-02-16 16:42:50 -07:00
|
|
|
|
|
|
|
/* adjust cq sizes given the new procs */
|
|
|
|
rc = openib_btl_size_queues (openib_btl);
|
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
BTL_ERROR(("error creating cqs"));
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
rc = openib_btl_prepare (openib_btl);
|
2015-01-05 14:36:57 -07:00
|
|
|
if (OPAL_SUCCESS != rc) {
|
2016-02-16 16:42:50 -07:00
|
|
|
BTL_ERROR(("could not prepare openib btl module for use"));
|
2015-01-05 14:36:57 -07:00
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2015-12-24 17:22:55 +06:00
|
|
|
opal_mutex_lock(&openib_btl->device->device_lock);
|
|
|
|
openib_btl->local_procs += nprocs_new_loc;
|
|
|
|
if( 0 < nprocs_new_loc ){
|
|
|
|
openib_btl->device->mem_reg_max = openib_btl->device->mem_reg_max_total / openib_btl->local_procs;
|
|
|
|
}
|
|
|
|
opal_mutex_unlock(&openib_btl->device->device_lock);
|
|
|
|
|
|
|
|
/* prepare endpoints */
|
|
|
|
for (i = 0, nprocs_new_loc = 0 ; i < (int) nprocs; i++) {
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
struct opal_proc_t* proc = procs[i];
|
2005-06-30 21:28:35 +00:00
|
|
|
mca_btl_openib_proc_t* ib_proc;
|
2015-05-07 12:47:07 -06:00
|
|
|
bool found_existing = false;
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2008-06-09 14:53:58 +00:00
|
|
|
opal_output(-1, "add procs: adding proc %d", i);
|
2008-06-20 22:08:00 +00:00
|
|
|
|
2008-06-25 14:50:59 +00:00
|
|
|
#if defined(HAVE_STRUCT_IBV_DEVICE_TRANSPORT_TYPE)
|
2008-06-20 22:08:00 +00:00
|
|
|
/* Most current iWARP adapters (June 2008) cannot handle
|
|
|
|
talking to other processes on the same host (!) -- so mark
|
|
|
|
them as unreachable (need to use sm). So for the moment,
|
|
|
|
we'll just mark any local peer on an iWARP NIC as
|
|
|
|
unreachable. See trac ticket #1352. */
|
2008-07-23 00:28:59 +00:00
|
|
|
if (IBV_TRANSPORT_IWARP == openib_btl->device->ib_dev->transport_type &&
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
OPAL_PROC_ON_LOCAL_NODE(proc->proc_flags)) {
|
2008-06-20 22:08:00 +00:00
|
|
|
continue;
|
|
|
|
}
|
2008-06-25 14:50:59 +00:00
|
|
|
#endif
|
2008-06-20 22:08:00 +00:00
|
|
|
|
2015-12-24 17:22:55 +06:00
|
|
|
if(NULL == (ib_proc = mca_btl_openib_proc_get_locked(proc)) ) {
|
2014-09-10 17:02:16 +00:00
|
|
|
/* if we don't have connection info for this process, it's
|
|
|
|
* okay because some other method might be able to reach it,
|
|
|
|
* so just mark it as unreachable by us */
|
|
|
|
continue;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
|
2015-12-21 16:47:50 +06:00
|
|
|
found_existing = false;
|
|
|
|
|
2015-12-24 17:22:55 +06:00
|
|
|
for (j = 0 ; j < (int) ib_proc->proc_endpoint_count ; ++j) {
|
|
|
|
endpoint = ib_proc->proc_endpoints[j];
|
|
|
|
if (endpoint->endpoint_btl == openib_btl) {
|
|
|
|
found_existing = true;
|
|
|
|
break;
|
2015-12-21 16:47:50 +06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( !found_existing ) {
|
|
|
|
rc = init_ib_proc_nolock(openib_btl, ib_proc, &endpoint,
|
|
|
|
lcl_subnet_id_port_cnt, btl_rank);
|
|
|
|
if( OPAL_SUCCESS == rc ){
|
2015-05-07 12:47:07 -06:00
|
|
|
found_existing = true;
|
|
|
|
}
|
|
|
|
}
|
2015-12-21 18:23:40 +06:00
|
|
|
opal_mutex_unlock( &ib_proc->proc_lock );
|
2015-05-07 12:47:07 -06:00
|
|
|
|
|
|
|
if (found_existing) {
|
|
|
|
if (reachable) {
|
|
|
|
opal_bitmap_set_bit(reachable, i);
|
|
|
|
}
|
2015-12-23 22:16:06 +06:00
|
|
|
peers[i] = (mca_btl_base_endpoint_t*)endpoint;
|
2015-05-07 12:47:07 -06:00
|
|
|
}
|
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
2007-01-03 22:35:41 +00:00
|
|
|
|
2015-01-05 14:36:57 -07:00
|
|
|
return OPAL_SUCCESS;
|
2006-07-31 17:24:39 +00:00
|
|
|
}
|
2006-07-30 00:58:40 +00:00
|
|
|
|
2015-05-07 12:47:07 -06:00
|
|
|
struct mca_btl_base_endpoint_t *mca_btl_openib_get_ep (struct mca_btl_base_module_t *btl, struct opal_proc_t *proc)
|
|
|
|
{
|
|
|
|
mca_btl_openib_module_t *openib_btl = (mca_btl_openib_module_t *) btl;
|
2015-12-23 22:16:06 +06:00
|
|
|
volatile mca_btl_base_endpoint_t *endpoint = NULL;
|
2016-02-16 16:42:50 -07:00
|
|
|
int local_port_cnt = 0, btl_rank, rc;
|
2015-05-07 12:47:07 -06:00
|
|
|
mca_btl_openib_proc_t *ib_proc;
|
|
|
|
|
2015-12-23 22:53:01 +06:00
|
|
|
rc = prepare_device_for_use (openib_btl->device);
|
2015-12-21 09:53:26 +06:00
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
BTL_ERROR(("could not prepare openib device for use"));
|
2015-12-21 16:47:50 +06:00
|
|
|
return NULL;
|
2015-12-21 09:53:26 +06:00
|
|
|
}
|
|
|
|
|
2015-12-24 17:22:55 +06:00
|
|
|
if (NULL == (ib_proc = mca_btl_openib_proc_get_locked(proc))) {
|
2015-05-07 12:47:07 -06:00
|
|
|
/* if we don't have connection info for this process, it's
|
|
|
|
* okay because some other method might be able to reach it,
|
|
|
|
* so just mark it as unreachable by us */
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2015-12-24 17:22:55 +06:00
|
|
|
rc = mca_btl_openib_proc_reg_btl(ib_proc, openib_btl);
|
|
|
|
|
|
|
|
switch( rc ){
|
|
|
|
case OPAL_SUCCESS:
|
|
|
|
/* unlock first to avoid possible deadlocks */
|
|
|
|
opal_mutex_unlock(&ib_proc->proc_lock);
|
|
|
|
|
|
|
|
/* this is a new process to this openib btl
|
|
|
|
* account this procs if need */
|
2016-06-07 16:05:56 -06:00
|
|
|
opal_atomic_add_32 (&openib_btl->num_peers, 1);
|
2016-02-16 16:42:50 -07:00
|
|
|
rc = openib_btl_size_queues(openib_btl);
|
2015-12-24 17:22:55 +06:00
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
BTL_ERROR(("error creating cqs"));
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( OPAL_PROC_ON_LOCAL_NODE(proc->proc_flags) ) {
|
|
|
|
opal_mutex_lock(&openib_btl->ib_lock);
|
|
|
|
openib_btl->local_procs += 1;
|
|
|
|
openib_btl->device->mem_reg_max = openib_btl->device->mem_reg_max_total / openib_btl->local_procs;
|
|
|
|
opal_mutex_unlock(&openib_btl->ib_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* lock process back */
|
|
|
|
opal_mutex_lock(&ib_proc->proc_lock);
|
|
|
|
break;
|
|
|
|
case OPAL_ERR_RESOURCE_BUSY:
|
|
|
|
/* process was accounted earlier in this openib btl */
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
/* unexpected error, e.g. out of mem */
|
|
|
|
BTL_ERROR(("Unexpected OPAL error %d", rc));
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2016-02-16 16:42:50 -07:00
|
|
|
rc = openib_btl_prepare(openib_btl);
|
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
BTL_ERROR(("could not prepare openib btl structure for use"));
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
|
2015-12-24 17:22:55 +06:00
|
|
|
for (size_t j = 0 ; j < ib_proc->proc_endpoint_count ; ++j) {
|
|
|
|
endpoint = ib_proc->proc_endpoints[j];
|
|
|
|
if (endpoint->endpoint_btl == openib_btl) {
|
|
|
|
goto exit;
|
2015-05-07 12:47:07 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-12-21 16:47:50 +06:00
|
|
|
endpoint = NULL;
|
2015-12-23 22:16:06 +06:00
|
|
|
|
|
|
|
btl_rank = get_openib_btl_params(openib_btl, &local_port_cnt);
|
|
|
|
if( 0 > btl_rank ){
|
|
|
|
goto exit;
|
2015-12-21 09:34:11 +06:00
|
|
|
}
|
2015-05-07 12:47:07 -06:00
|
|
|
|
2015-12-21 09:34:11 +06:00
|
|
|
(void)init_ib_proc_nolock(openib_btl, ib_proc, &endpoint,
|
2015-12-21 16:47:50 +06:00
|
|
|
local_port_cnt, btl_rank);
|
2015-12-22 22:33:54 +06:00
|
|
|
|
2015-12-21 16:47:50 +06:00
|
|
|
exit:
|
2015-12-21 18:23:40 +06:00
|
|
|
opal_mutex_unlock(&ib_proc->proc_lock);
|
2015-12-22 22:33:54 +06:00
|
|
|
|
2015-12-23 22:16:06 +06:00
|
|
|
return (struct mca_btl_base_endpoint_t *)endpoint;
|
2015-05-07 12:47:07 -06:00
|
|
|
}
|
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
/*
|
|
|
|
* delete the proc as reachable from this btl module
|
2005-07-20 15:17:18 +00:00
|
|
|
*/
|
2008-01-21 12:11:18 +00:00
|
|
|
int mca_btl_openib_del_procs(struct mca_btl_base_module_t* btl,
|
|
|
|
size_t nprocs,
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
struct opal_proc_t **procs,
|
2005-06-30 21:28:35 +00:00
|
|
|
struct mca_btl_base_endpoint_t ** peers)
|
|
|
|
{
|
2014-06-02 02:23:52 +00:00
|
|
|
int i, ep_index;
|
2007-05-08 21:47:21 +00:00
|
|
|
mca_btl_openib_module_t* openib_btl = (mca_btl_openib_module_t*) btl;
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
mca_btl_openib_endpoint_t* endpoint;
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2007-05-08 21:47:21 +00:00
|
|
|
for (i=0 ; i < (int) nprocs ; i++) {
|
|
|
|
mca_btl_base_endpoint_t* del_endpoint = peers[i];
|
|
|
|
for(ep_index=0;
|
2008-07-23 00:28:59 +00:00
|
|
|
ep_index < opal_pointer_array_get_size(openib_btl->device->endpoints);
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
ep_index++) {
|
2010-07-12 16:17:56 +00:00
|
|
|
endpoint = (mca_btl_openib_endpoint_t *)
|
2008-07-23 00:28:59 +00:00
|
|
|
opal_pointer_array_get_item(openib_btl->device->endpoints,
|
2007-08-20 12:28:25 +00:00
|
|
|
ep_index);
|
|
|
|
if(!endpoint || endpoint->endpoint_btl != openib_btl) {
|
2007-05-08 21:47:21 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (endpoint == del_endpoint) {
|
2014-06-02 02:23:52 +00:00
|
|
|
int j;
|
2008-05-02 11:52:33 +00:00
|
|
|
BTL_VERBOSE(("in del_procs %d, setting another endpoint to null",
|
2007-10-15 17:53:02 +00:00
|
|
|
ep_index));
|
2014-06-02 02:23:52 +00:00
|
|
|
/* remove the endpoint from eager_rdma_buffers */
|
|
|
|
for (j=0; j<openib_btl->device->eager_rdma_buffers_count; j++) {
|
|
|
|
if (openib_btl->device->eager_rdma_buffers[j] == endpoint) {
|
|
|
|
/* should it be obj_reference_count == 2 ? */
|
|
|
|
assert(((opal_object_t*)endpoint)->obj_reference_count > 1);
|
|
|
|
OBJ_RELEASE(endpoint);
|
|
|
|
openib_btl->device->eager_rdma_buffers[j] = NULL;
|
|
|
|
/* can we simply break and leave the for loop ? */
|
|
|
|
}
|
|
|
|
}
|
2008-07-23 00:28:59 +00:00
|
|
|
opal_pointer_array_set_item(openib_btl->device->endpoints,
|
2007-08-20 12:28:25 +00:00
|
|
|
ep_index, NULL);
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
assert(((opal_object_t*)endpoint)->obj_reference_count == 1);
|
2008-05-02 11:52:33 +00:00
|
|
|
mca_btl_openib_proc_remove(procs[i], endpoint);
|
2007-05-08 21:47:21 +00:00
|
|
|
OBJ_RELEASE(endpoint);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
/*
|
2006-08-16 20:21:38 +00:00
|
|
|
*Register callback function for error handling..
|
2008-01-21 12:11:18 +00:00
|
|
|
*/
|
2006-08-16 20:21:38 +00:00
|
|
|
int mca_btl_openib_register_error_cb(
|
2008-01-21 12:11:18 +00:00
|
|
|
struct mca_btl_base_module_t* btl,
|
2006-08-16 20:21:38 +00:00
|
|
|
mca_btl_base_module_error_cb_fn_t cbfunc)
|
|
|
|
{
|
2008-01-21 12:11:18 +00:00
|
|
|
|
|
|
|
mca_btl_openib_module_t* openib_btl = (mca_btl_openib_module_t*) btl;
|
2006-08-16 20:21:38 +00:00
|
|
|
openib_btl->error_cb = cbfunc; /* stash for later */
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2006-08-16 20:21:38 +00:00
|
|
|
}
|
|
|
|
|
2007-12-09 14:02:32 +00:00
|
|
|
static inline mca_btl_base_descriptor_t *
|
2007-12-09 14:08:55 +00:00
|
|
|
ib_frag_alloc(mca_btl_openib_module_t *btl, size_t size, uint8_t order,
|
|
|
|
uint32_t flags)
|
2007-12-09 14:02:32 +00:00
|
|
|
{
|
2013-07-04 08:34:37 +00:00
|
|
|
int qp;
|
2015-02-19 13:41:41 -07:00
|
|
|
opal_free_list_item_t* item = NULL;
|
2007-12-09 14:02:32 +00:00
|
|
|
|
|
|
|
for(qp = 0; qp < mca_btl_openib_component.num_qps; qp++) {
|
|
|
|
if(mca_btl_openib_component.qp_infos[qp].size >= size) {
|
2015-02-19 13:41:41 -07:00
|
|
|
item = opal_free_list_get (&btl->device->qps[qp].send_free);
|
2007-12-09 14:02:32 +00:00
|
|
|
if(item)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(NULL == item)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
/* not all upper layer users set this */
|
2015-03-10 14:21:42 -06:00
|
|
|
to_base_frag(item)->segment.seg_len = size;
|
2007-12-09 14:02:32 +00:00
|
|
|
to_base_frag(item)->base.order = order;
|
2007-12-09 14:08:55 +00:00
|
|
|
to_base_frag(item)->base.des_flags = flags;
|
2007-12-09 14:02:32 +00:00
|
|
|
|
|
|
|
assert(to_send_frag(item)->qp_idx <= order);
|
|
|
|
return &to_base_frag(item)->base;
|
|
|
|
}
|
|
|
|
|
2007-12-09 14:05:13 +00:00
|
|
|
/* check if pending fragment has enough space for coalescing */
|
|
|
|
static mca_btl_openib_send_frag_t *check_coalescing(opal_list_t *frag_list,
|
2014-11-04 14:26:17 -07:00
|
|
|
opal_mutex_t *lock, struct mca_btl_base_endpoint_t *ep, size_t size,
|
|
|
|
mca_btl_openib_coalesced_frag_t **cfrag)
|
2007-12-09 14:05:13 +00:00
|
|
|
{
|
|
|
|
mca_btl_openib_send_frag_t *frag = NULL;
|
|
|
|
|
2014-11-04 14:26:17 -07:00
|
|
|
if (opal_list_is_empty(frag_list))
|
2007-12-09 14:05:13 +00:00
|
|
|
return NULL;
|
|
|
|
|
|
|
|
OPAL_THREAD_LOCK(lock);
|
2014-11-04 14:26:17 -07:00
|
|
|
if (!opal_list_is_empty(frag_list)) {
|
2007-12-09 14:05:13 +00:00
|
|
|
int qp;
|
|
|
|
size_t total_length;
|
|
|
|
opal_list_item_t *i = opal_list_get_first(frag_list);
|
|
|
|
frag = to_send_frag(i);
|
|
|
|
if(to_com_frag(frag)->endpoint != ep ||
|
|
|
|
MCA_BTL_OPENIB_FRAG_CONTROL == openib_frag_type(frag)) {
|
|
|
|
OPAL_THREAD_UNLOCK(lock);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
total_length = size + frag->coalesced_length +
|
2015-03-10 14:21:42 -06:00
|
|
|
to_base_frag(frag)->segment.seg_len +
|
2007-12-09 14:05:13 +00:00
|
|
|
sizeof(mca_btl_openib_header_coalesced_t);
|
|
|
|
|
|
|
|
qp = to_base_frag(frag)->base.order;
|
|
|
|
|
2014-11-04 14:26:17 -07:00
|
|
|
if(total_length <= mca_btl_openib_component.qp_infos[qp].size) {
|
|
|
|
/* make sure we can allocate a coalescing frag before returning success */
|
|
|
|
*cfrag = alloc_coalesced_frag();
|
|
|
|
if (OPAL_LIKELY(NULL != cfrag)) {
|
|
|
|
(*cfrag)->send_frag = frag;
|
|
|
|
(*cfrag)->sent = false;
|
|
|
|
|
|
|
|
opal_list_remove_first(frag_list);
|
|
|
|
} else {
|
|
|
|
frag = NULL;
|
|
|
|
}
|
|
|
|
} else {
|
2007-12-09 14:05:13 +00:00
|
|
|
frag = NULL;
|
2014-11-04 14:26:17 -07:00
|
|
|
}
|
2007-12-09 14:05:13 +00:00
|
|
|
}
|
|
|
|
OPAL_THREAD_UNLOCK(lock);
|
|
|
|
|
|
|
|
return frag;
|
|
|
|
}
|
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/**
|
|
|
|
* Allocate a segment.
|
|
|
|
*
|
|
|
|
* @param btl (IN) BTL module
|
|
|
|
* @param size (IN) Request segment size.
|
2008-01-21 12:11:18 +00:00
|
|
|
* @param size (IN) Size of segment to allocate
|
|
|
|
*
|
|
|
|
* When allocating a segment we pull a pre-alllocated segment
|
2005-07-20 15:17:18 +00:00
|
|
|
* from one of two free lists, an eager list and a max list
|
2005-06-30 21:28:35 +00:00
|
|
|
*/
|
|
|
|
mca_btl_base_descriptor_t* mca_btl_openib_alloc(
|
|
|
|
struct mca_btl_base_module_t* btl,
|
2007-12-09 14:05:13 +00:00
|
|
|
struct mca_btl_base_endpoint_t* ep,
|
2007-05-24 19:51:26 +00:00
|
|
|
uint8_t order,
|
2007-12-09 14:08:01 +00:00
|
|
|
size_t size,
|
|
|
|
uint32_t flags)
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
2007-12-09 14:05:13 +00:00
|
|
|
mca_btl_openib_module_t *obtl = (mca_btl_openib_module_t*)btl;
|
|
|
|
int qp = frag_size_to_order(obtl, size);
|
|
|
|
mca_btl_openib_send_frag_t *sfrag = NULL;
|
2014-11-04 14:26:17 -07:00
|
|
|
mca_btl_openib_coalesced_frag_t *cfrag = NULL;
|
2007-12-09 14:05:13 +00:00
|
|
|
|
|
|
|
assert(qp != MCA_BTL_NO_ORDER);
|
|
|
|
|
2008-02-18 17:39:30 +00:00
|
|
|
if(mca_btl_openib_component.use_message_coalescing &&
|
2009-08-05 22:23:26 +00:00
|
|
|
(flags & MCA_BTL_DES_FLAGS_BTL_OWNERSHIP)) {
|
2007-12-09 14:08:55 +00:00
|
|
|
int prio = !(flags & MCA_BTL_DES_FLAGS_PRIORITY);
|
2012-03-01 17:29:40 +00:00
|
|
|
|
2009-01-07 14:10:58 +00:00
|
|
|
sfrag = check_coalescing(&ep->qps[qp].no_wqe_pending_frags[prio],
|
2014-11-04 14:26:17 -07:00
|
|
|
&ep->endpoint_lock, ep, size, &cfrag);
|
2007-12-09 14:05:13 +00:00
|
|
|
|
2014-11-04 14:26:17 -07:00
|
|
|
if (NULL == sfrag) {
|
2007-12-09 14:05:13 +00:00
|
|
|
if(BTL_OPENIB_QP_TYPE_PP(qp)) {
|
2009-01-07 14:41:20 +00:00
|
|
|
sfrag = check_coalescing(&ep->qps[qp].no_credits_pending_frags[prio],
|
2014-11-04 14:26:17 -07:00
|
|
|
&ep->endpoint_lock, ep, size, &cfrag);
|
2007-12-09 14:05:13 +00:00
|
|
|
} else {
|
|
|
|
sfrag = check_coalescing(
|
2007-12-09 14:08:55 +00:00
|
|
|
&obtl->qps[qp].u.srq_qp.pending_frags[prio],
|
2014-11-04 14:26:17 -07:00
|
|
|
&obtl->ib_lock, ep, size, &cfrag);
|
2007-12-09 14:05:13 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-11-04 14:26:17 -07:00
|
|
|
if (NULL == sfrag) {
|
2007-12-09 14:08:55 +00:00
|
|
|
return ib_frag_alloc((mca_btl_openib_module_t*)btl, size, order, flags);
|
2014-11-04 14:26:17 -07:00
|
|
|
}
|
2007-12-09 14:05:13 +00:00
|
|
|
|
|
|
|
/* begin coalescing message */
|
|
|
|
|
|
|
|
/* fix up new coalescing header if this is the first coalesced frag */
|
|
|
|
if(sfrag->hdr != sfrag->chdr) {
|
|
|
|
mca_btl_openib_control_header_t *ctrl_hdr;
|
|
|
|
mca_btl_openib_header_coalesced_t *clsc_hdr;
|
|
|
|
uint8_t org_tag;
|
|
|
|
|
|
|
|
org_tag = sfrag->hdr->tag;
|
|
|
|
sfrag->hdr = sfrag->chdr;
|
|
|
|
ctrl_hdr = (mca_btl_openib_control_header_t*)(sfrag->hdr + 1);
|
|
|
|
clsc_hdr = (mca_btl_openib_header_coalesced_t*)(ctrl_hdr + 1);
|
2013-08-30 14:53:59 +00:00
|
|
|
sfrag->hdr->tag = MCA_BTL_TAG_IB;
|
2007-12-09 14:05:13 +00:00
|
|
|
ctrl_hdr->type = MCA_BTL_OPENIB_CONTROL_COALESCED;
|
|
|
|
clsc_hdr->tag = org_tag;
|
2015-03-10 14:21:42 -06:00
|
|
|
clsc_hdr->size = to_base_frag(sfrag)->segment.seg_len;
|
|
|
|
clsc_hdr->alloc_size = to_base_frag(sfrag)->segment.seg_len;
|
2007-12-09 14:10:25 +00:00
|
|
|
if(ep->nbo)
|
|
|
|
BTL_OPENIB_HEADER_COALESCED_HTON(*clsc_hdr);
|
2007-12-09 14:05:13 +00:00
|
|
|
sfrag->coalesced_length = sizeof(mca_btl_openib_control_header_t) +
|
|
|
|
sizeof(mca_btl_openib_header_coalesced_t);
|
2008-01-21 12:11:18 +00:00
|
|
|
to_com_frag(sfrag)->sg_entry.addr = (uint64_t)(uintptr_t)sfrag->hdr;
|
2007-12-09 14:05:13 +00:00
|
|
|
}
|
|
|
|
|
2015-06-23 20:59:57 -07:00
|
|
|
cfrag->hdr = (mca_btl_openib_header_coalesced_t*)((unsigned char*)(sfrag->hdr + 1) +
|
2012-03-01 17:29:40 +00:00
|
|
|
sfrag->coalesced_length +
|
2015-03-10 14:21:42 -06:00
|
|
|
to_base_frag(sfrag)->segment.seg_len);
|
2012-03-01 17:29:40 +00:00
|
|
|
cfrag->hdr = (mca_btl_openib_header_coalesced_t*)BTL_OPENIB_ALIGN_COALESCE_HDR(cfrag->hdr);
|
2007-12-09 14:05:13 +00:00
|
|
|
cfrag->hdr->alloc_size = size;
|
|
|
|
|
|
|
|
/* point coalesced frag pointer into a data buffer */
|
2015-03-10 14:21:42 -06:00
|
|
|
to_base_frag(cfrag)->segment.seg_addr.pval = cfrag->hdr + 1;
|
|
|
|
to_base_frag(cfrag)->segment.seg_len = size;
|
2007-12-09 14:05:13 +00:00
|
|
|
|
2014-11-04 14:26:17 -07:00
|
|
|
/* NTH: there is no reason to append the coalesced fragment here. No more
|
|
|
|
* fragments will be added until either send or free has been called on
|
|
|
|
* the coalesced frag. */
|
2007-12-09 14:05:13 +00:00
|
|
|
|
2008-02-19 12:26:45 +00:00
|
|
|
to_base_frag(cfrag)->base.des_flags = flags;
|
|
|
|
|
2007-12-09 14:05:13 +00:00
|
|
|
return &to_base_frag(cfrag)->base;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
/**
|
|
|
|
* Return a segment
|
|
|
|
*
|
|
|
|
* Return the segment to the appropriate
|
|
|
|
* preallocated segment list
|
|
|
|
*/
|
2005-06-30 21:28:35 +00:00
|
|
|
int mca_btl_openib_free(
|
2008-01-21 12:11:18 +00:00
|
|
|
struct mca_btl_base_module_t* btl,
|
|
|
|
mca_btl_base_descriptor_t* des)
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
2007-11-28 07:11:14 +00:00
|
|
|
/* reset those field on free so we will not have to do it on alloc */
|
|
|
|
to_base_frag(des)->base.des_flags = 0;
|
2007-12-09 14:05:13 +00:00
|
|
|
switch(openib_frag_type(des)) {
|
|
|
|
case MCA_BTL_OPENIB_FRAG_SEND:
|
|
|
|
to_send_frag(des)->hdr = (mca_btl_openib_header_t*)
|
|
|
|
(((unsigned char*)to_send_frag(des)->chdr) +
|
|
|
|
sizeof(mca_btl_openib_header_coalesced_t) +
|
|
|
|
sizeof(mca_btl_openib_control_header_t));
|
2007-12-09 14:15:35 +00:00
|
|
|
to_com_frag(des)->sg_entry.addr =
|
|
|
|
(uint64_t)(uintptr_t)to_send_frag(des)->hdr;
|
2007-12-09 14:05:13 +00:00
|
|
|
to_send_frag(des)->coalesced_length = 0;
|
2015-03-10 14:21:42 -06:00
|
|
|
to_base_frag(des)->segment.seg_addr.pval =
|
2012-07-18 17:29:37 +00:00
|
|
|
to_send_frag(des)->hdr + 1;
|
2007-12-09 14:05:13 +00:00
|
|
|
assert(!opal_list_get_size(&to_send_frag(des)->coalesced_frags));
|
2014-07-10 16:31:15 +00:00
|
|
|
/* fall through */
|
2007-12-09 14:05:13 +00:00
|
|
|
default:
|
|
|
|
break;
|
2007-11-28 07:11:14 +00:00
|
|
|
}
|
2014-11-04 14:26:17 -07:00
|
|
|
|
|
|
|
if (openib_frag_type(des) == MCA_BTL_OPENIB_FRAG_COALESCED && !to_coalesced_frag(des)->sent) {
|
|
|
|
mca_btl_openib_send_frag_t *sfrag = to_coalesced_frag(des)->send_frag;
|
|
|
|
|
|
|
|
/* the coalesced fragment would have sent the original fragment but that
|
|
|
|
* will not happen so send the fragment now */
|
|
|
|
mca_btl_openib_endpoint_send(to_com_frag(sfrag)->endpoint, sfrag);
|
|
|
|
}
|
|
|
|
|
2007-11-28 07:11:14 +00:00
|
|
|
MCA_BTL_IB_FRAG_RETURN(des);
|
2008-01-21 12:11:18 +00:00
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-01-21 12:11:18 +00:00
|
|
|
* register user buffer or pack
|
|
|
|
* data into pre-registered buffer and return a
|
2005-07-20 15:17:18 +00:00
|
|
|
* descriptor that can be
|
2005-06-30 21:28:35 +00:00
|
|
|
* used for send/put.
|
|
|
|
*
|
|
|
|
* @param btl (IN) BTL module
|
|
|
|
* @param peer (IN) BTL peer addressing
|
2008-01-21 12:11:18 +00:00
|
|
|
*
|
|
|
|
* prepare source's behavior depends on the following:
|
|
|
|
* Has a valid memory registration been passed to prepare_src?
|
|
|
|
* if so we attempt to use the pre-registered user-buffer, if the memory registration
|
|
|
|
* is too small (only a portion of the user buffer) then we must reregister the user buffer
|
|
|
|
* Has the user requested the memory to be left pinned?
|
|
|
|
* if so we insert the memory registration into a memory tree for later lookup, we
|
|
|
|
* may also remove a previous registration if a MRU (most recently used) list of
|
2007-04-26 21:03:38 +00:00
|
|
|
* registrations is full, this prevents resources from being exhausted.
|
2008-01-21 12:11:18 +00:00
|
|
|
* Is the requested size larger than the btl's max send size?
|
|
|
|
* if so and we aren't asked to leave the registration pinned, then we register the memory if
|
|
|
|
* the users buffer is contiguous
|
|
|
|
* Otherwise we choose from two free lists of pre-registered memory in which to pack the data into.
|
|
|
|
*
|
2005-06-30 21:28:35 +00:00
|
|
|
*/
|
|
|
|
mca_btl_base_descriptor_t* mca_btl_openib_prepare_src(
|
|
|
|
struct mca_btl_base_module_t* btl,
|
|
|
|
struct mca_btl_base_endpoint_t* endpoint,
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
struct opal_convertor_t* convertor,
|
2007-05-24 19:51:26 +00:00
|
|
|
uint8_t order,
|
2005-06-30 21:28:35 +00:00
|
|
|
size_t reserve,
|
2007-12-09 14:08:01 +00:00
|
|
|
size_t* size,
|
|
|
|
uint32_t flags)
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
2007-11-28 07:11:14 +00:00
|
|
|
mca_btl_openib_com_frag_t *frag = NULL;
|
2006-12-17 12:26:41 +00:00
|
|
|
struct iovec iov;
|
|
|
|
uint32_t iov_count = 1;
|
|
|
|
size_t max_data = *size;
|
2012-07-13 21:19:16 +00:00
|
|
|
void *ptr;
|
2014-11-19 23:16:16 -07:00
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
assert(MCA_BTL_NO_ORDER == order);
|
|
|
|
|
2015-01-06 08:48:33 -07:00
|
|
|
if (max_data + reserve > btl->btl_max_send_size) {
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
max_data = btl->btl_max_send_size - reserve;
|
2006-12-17 12:26:41 +00:00
|
|
|
}
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2015-01-06 08:48:33 -07:00
|
|
|
frag = (mca_btl_openib_com_frag_t *) mca_btl_openib_alloc (btl, endpoint, order,
|
2012-07-18 17:29:37 +00:00
|
|
|
max_data + reserve, flags);
|
2015-01-06 08:48:33 -07:00
|
|
|
if (NULL == frag) {
|
|
|
|
return NULL;
|
2014-11-19 23:22:43 -07:00
|
|
|
}
|
2014-10-30 16:43:41 -06:00
|
|
|
|
2015-03-10 14:21:42 -06:00
|
|
|
ptr = to_base_frag(frag)->segment.seg_addr.pval;
|
2015-01-06 08:48:33 -07:00
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
iov.iov_len = max_data;
|
2012-07-13 21:19:16 +00:00
|
|
|
iov.iov_base = (IOVBASE_TYPE *) ( (unsigned char*) ptr + reserve );
|
2015-06-17 08:56:56 -07:00
|
|
|
(void) opal_convertor_pack(convertor, &iov, &iov_count, &max_data);
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2013-11-01 12:19:40 +00:00
|
|
|
#if OPAL_CUDA_SUPPORT /* CUDA_ASYNC_SEND */
|
2013-01-17 22:34:43 +00:00
|
|
|
/* If the convertor is copying the data asynchronously, then record an event
|
2013-12-03 20:25:58 +00:00
|
|
|
* that will trigger the callback when it completes. Mark descriptor as async.
|
|
|
|
* No need for this in the case we are not sending any GPU data. */
|
|
|
|
if ((convertor->flags & CONVERTOR_CUDA_ASYNC) && (0 != max_data)) {
|
2013-01-17 22:34:43 +00:00
|
|
|
mca_common_cuda_record_dtoh_event("btl_openib", (mca_btl_base_descriptor_t *)frag);
|
|
|
|
to_base_frag(frag)->base.des_flags = flags | MCA_BTL_DES_FLAGS_CUDA_COPY_ASYNC;
|
|
|
|
}
|
2013-11-01 12:19:40 +00:00
|
|
|
#endif /* OPAL_CUDA_SUPPORT */
|
2013-01-17 22:34:43 +00:00
|
|
|
|
2007-11-28 07:11:14 +00:00
|
|
|
*size = max_data;
|
|
|
|
|
2007-12-11 13:10:52 +00:00
|
|
|
/* not all upper layer users set this */
|
2015-03-10 14:21:42 -06:00
|
|
|
to_base_frag(frag)->segment.seg_len = max_data + reserve;
|
2007-12-11 13:10:52 +00:00
|
|
|
|
2007-11-28 07:11:14 +00:00
|
|
|
return &to_base_frag(frag)->base;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
|
2008-11-10 18:35:57 +00:00
|
|
|
static int mca_btl_openib_finalize_resources(struct mca_btl_base_module_t* btl) {
|
2008-01-21 12:11:18 +00:00
|
|
|
mca_btl_openib_module_t* openib_btl;
|
2007-05-08 21:47:21 +00:00
|
|
|
mca_btl_openib_endpoint_t* endpoint;
|
2007-12-23 12:29:34 +00:00
|
|
|
int ep_index, i;
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
int qp, rc = OPAL_SUCCESS;
|
2008-01-21 12:11:18 +00:00
|
|
|
|
|
|
|
openib_btl = (mca_btl_openib_module_t*) btl;
|
2005-07-20 15:17:18 +00:00
|
|
|
|
2008-10-16 15:09:00 +00:00
|
|
|
/* Sanity check */
|
|
|
|
if( mca_btl_openib_component.ib_num_btls <= 0 ) {
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2008-10-16 15:09:00 +00:00
|
|
|
}
|
|
|
|
|
2007-05-08 21:47:21 +00:00
|
|
|
/* Release all QPs */
|
2013-04-09 21:55:31 +00:00
|
|
|
if (NULL != openib_btl->device->endpoints) {
|
|
|
|
for (ep_index=0;
|
|
|
|
ep_index < opal_pointer_array_get_size(openib_btl->device->endpoints);
|
|
|
|
ep_index++) {
|
|
|
|
endpoint=(mca_btl_openib_endpoint_t *)opal_pointer_array_get_item(openib_btl->device->endpoints,
|
|
|
|
ep_index);
|
|
|
|
if(!endpoint) {
|
|
|
|
BTL_VERBOSE(("In finalize, got another null endpoint"));
|
|
|
|
continue;
|
2007-12-23 13:58:31 +00:00
|
|
|
}
|
2013-04-09 21:55:31 +00:00
|
|
|
if(endpoint->endpoint_btl != openib_btl) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
for(i = 0; i < openib_btl->device->eager_rdma_buffers_count; i++) {
|
|
|
|
if(openib_btl->device->eager_rdma_buffers[i] == endpoint) {
|
|
|
|
openib_btl->device->eager_rdma_buffers[i] = NULL;
|
|
|
|
OBJ_RELEASE(endpoint);
|
|
|
|
}
|
|
|
|
}
|
2013-10-30 11:47:49 +00:00
|
|
|
opal_pointer_array_set_item(openib_btl->device->endpoints,
|
|
|
|
ep_index, NULL);
|
|
|
|
assert(((opal_object_t*)endpoint)->obj_reference_count == 1);
|
2013-04-09 21:55:31 +00:00
|
|
|
OBJ_RELEASE(endpoint);
|
2007-12-23 13:58:31 +00:00
|
|
|
}
|
2007-05-08 21:47:21 +00:00
|
|
|
}
|
2008-05-02 11:52:33 +00:00
|
|
|
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
/* Release SRQ resources */
|
2008-01-21 12:11:18 +00:00
|
|
|
for(qp = 0; qp < mca_btl_openib_component.num_qps; qp++) {
|
2007-11-28 07:20:26 +00:00
|
|
|
if(!BTL_OPENIB_QP_TYPE_PP(qp)) {
|
2010-02-18 09:48:16 +00:00
|
|
|
MCA_BTL_OPENIB_CLEAN_PENDING_FRAGS(
|
|
|
|
&openib_btl->qps[qp].u.srq_qp.pending_frags[0]);
|
|
|
|
MCA_BTL_OPENIB_CLEAN_PENDING_FRAGS(
|
|
|
|
&openib_btl->qps[qp].u.srq_qp.pending_frags[1]);
|
|
|
|
if (NULL != openib_btl->qps[qp].u.srq_qp.srq) {
|
|
|
|
opal_mutex_t *lock =
|
|
|
|
&mca_btl_openib_component.srq_manager.lock;
|
|
|
|
|
|
|
|
opal_hash_table_t *srq_addr_table =
|
|
|
|
&mca_btl_openib_component.srq_manager.srq_addr_table;
|
|
|
|
|
2011-07-04 14:00:41 +00:00
|
|
|
opal_mutex_lock(lock);
|
2010-02-18 09:48:16 +00:00
|
|
|
if (OPAL_SUCCESS !=
|
|
|
|
opal_hash_table_remove_value_ptr(srq_addr_table,
|
|
|
|
&openib_btl->qps[qp].u.srq_qp.srq,
|
|
|
|
sizeof(struct ibv_srq *))) {
|
|
|
|
BTL_VERBOSE(("Failed to remove SRQ %d entry from hash table.", qp));
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
rc = OPAL_ERROR;
|
2010-02-18 09:48:16 +00:00
|
|
|
}
|
|
|
|
opal_mutex_unlock(lock);
|
|
|
|
if (0 != ibv_destroy_srq(openib_btl->qps[qp].u.srq_qp.srq)) {
|
2007-11-28 07:18:59 +00:00
|
|
|
BTL_VERBOSE(("Failed to close SRQ %d", qp));
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
rc = OPAL_ERROR;
|
2007-11-28 07:18:59 +00:00
|
|
|
}
|
2010-02-18 09:48:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_DESTRUCT(&openib_btl->qps[qp].u.srq_qp.pending_frags[0]);
|
|
|
|
OBJ_DESTRUCT(&openib_btl->qps[qp].u.srq_qp.pending_frags[1]);
|
2007-05-08 21:47:21 +00:00
|
|
|
}
|
|
|
|
}
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
|
2008-10-06 00:46:02 +00:00
|
|
|
/* Finalize the CPC modules on this openib module */
|
|
|
|
for (i = 0; i < openib_btl->num_cpcs; ++i) {
|
|
|
|
if (NULL != openib_btl->cpcs[i]->cbm_finalize) {
|
|
|
|
openib_btl->cpcs[i]->cbm_finalize(openib_btl, openib_btl->cpcs[i]);
|
|
|
|
}
|
|
|
|
free(openib_btl->cpcs[i]);
|
|
|
|
}
|
|
|
|
free(openib_btl->cpcs);
|
|
|
|
|
2008-07-23 00:28:59 +00:00
|
|
|
/* Release device if there are no more users */
|
2008-11-10 18:35:57 +00:00
|
|
|
if(!(--openib_btl->device->btls)) {
|
2008-07-23 00:28:59 +00:00
|
|
|
OBJ_RELEASE(openib_btl->device);
|
2007-05-08 21:47:21 +00:00
|
|
|
}
|
2007-11-28 07:14:34 +00:00
|
|
|
|
2010-02-18 09:48:16 +00:00
|
|
|
if (NULL != openib_btl->qps) {
|
2011-07-04 14:00:41 +00:00
|
|
|
free(openib_btl->qps);
|
2010-02-18 09:48:16 +00:00
|
|
|
}
|
|
|
|
|
2008-11-10 18:35:57 +00:00
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int mca_btl_openib_finalize(struct mca_btl_base_module_t* btl)
|
|
|
|
{
|
|
|
|
mca_btl_openib_module_t* openib_btl;
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
int i, rc = OPAL_SUCCESS;
|
2008-11-10 18:35:57 +00:00
|
|
|
|
|
|
|
openib_btl = (mca_btl_openib_module_t*) btl;
|
|
|
|
|
|
|
|
/* Sanity check */
|
|
|
|
if( mca_btl_openib_component.ib_num_btls <= 0 ) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2008-10-06 00:46:02 +00:00
|
|
|
/* Remove the btl from component list */
|
2013-10-30 11:47:49 +00:00
|
|
|
if ( mca_btl_openib_component.ib_num_btls > 0 ) {
|
2008-10-06 00:46:02 +00:00
|
|
|
for(i = 0; i < mca_btl_openib_component.ib_num_btls; i++){
|
|
|
|
if (mca_btl_openib_component.openib_btls[i] == openib_btl){
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
if( OPAL_SUCCESS != (rc = mca_btl_openib_finalize_resources(btl) ) ) {
|
2013-10-30 11:47:49 +00:00
|
|
|
BTL_VERBOSE(("Failed to finalize resources"));
|
|
|
|
}
|
2008-10-06 00:46:02 +00:00
|
|
|
mca_btl_openib_component.openib_btls[i] =
|
|
|
|
mca_btl_openib_component.openib_btls[mca_btl_openib_component.ib_num_btls-1];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
mca_btl_openib_component.ib_num_btls--;
|
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
OBJ_DESTRUCT(&openib_btl->ib_lock);
|
2007-05-08 21:47:21 +00:00
|
|
|
free(openib_btl);
|
|
|
|
|
This commit brings in two major things:
1. Galen's fine-grain control of queue pair resources in the openib
BTL.
1. Pasha's new implementation of asychronous HCA event handling.
Pasha's new implementation doesn't take much explanation, but the new
"multifrag" stuff does.
Note that "svn merge" was not used to bring this new code from the
/tmp/ib_multifrag branch -- something Bad happened in the periodic
trunk pulls on that branch making an actual merge back to the trunk
effectively impossible (i.e., lots and lots of arbitrary conflicts and
artifical changes). :-(
== Fine-grain control of queue pair resources ==
Galen's fine-grain control of queue pair resources to the OpenIB BTL
(thanks to Gleb for fixing broken code and providing additional
functionality, Pasha for finding broken code, and Jeff for doing all
the svn work and regression testing).
Prior to this commit, the OpenIB BTL created two queue pairs: one for
eager size fragments and one for max send size fragments. When the
use of the shared receive queue (SRQ) was specified (via "-mca
btl_openib_use_srq 1"), these QPs would use a shared receive queue for
receive buffers instead of the default per-peer (PP) receive queues
and buffers. One consequence of this design is that receive buffer
utilization (the size of the data received as a percentage of the
receive buffer used for the data) was quite poor for a number of
applications.
The new design allows multiple QPs to be specified at runtime. Each
QP can be setup to use PP or SRQ receive buffers as well as giving
fine-grained control over receive buffer size, number of receive
buffers to post, when to replenish the receive queue (low water mark)
and for SRQ QPs, the number of outstanding sends can also be
specified. The following is an example of the syntax to describe QPs
to the OpenIB BTL using the new MCA parameter btl_openib_receive_queues:
{{{
-mca btl_openib_receive_queues \
"P,128,16,4;S,1024,256,128,32;S,4096,256,128,32;S,65536,256,128,32"
}}}
Each QP description is delimited by ";" (semicolon) with individual
fields of the QP description delimited by "," (comma). The above
example therefore describes 4 QPs.
The first QP is:
P,128,16,4
Meaning: per-peer receive buffer QPs are indicated by a starting field
of "P"; the first QP (shown above) is therefore a per-peer based QP.
The second field indicates the size of the receive buffer in bytes
(128 bytes). The third field indicates the number of receive buffers
to allocate to the QP (16). The fourth field indicates the low
watermark for receive buffers at which time the BTL will repost
receive buffers to the QP (4).
The second QP is:
S,1024,256,128,32
Shared receive queue based QPs are indicated by a starting field of
"S"; the second QP (shown above) is therefore a shared receive queue
based QP. The second, third and fourth fields are the same as in the
per-peer based QP. The fifth field is the number of outstanding sends
that are allowed at a given time on the QP (32). This provides a
"good enough" mechanism of flow control for some regular communication
patterns.
QPs MUST be specified in ascending receive buffer size order. This
requirement may be removed prior to 1.3 release.
This commit was SVN r15474.
2007-07-18 01:15:59 +00:00
|
|
|
BTL_VERBOSE(("Success in closing BTL resources"));
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2007-11-28 07:14:34 +00:00
|
|
|
return rc;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
|
2009-03-25 16:53:26 +00:00
|
|
|
/*
|
|
|
|
* Send immediate - Minimum function calls minimum checks, send the data ASAP.
|
2011-07-04 14:00:41 +00:00
|
|
|
* If BTL can't to send the messages imidiate, it creates messages descriptor
|
2009-03-25 16:53:26 +00:00
|
|
|
* returns it to PML.
|
|
|
|
*/
|
|
|
|
int mca_btl_openib_sendi( struct mca_btl_base_module_t* btl,
|
|
|
|
struct mca_btl_base_endpoint_t* ep,
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
struct opal_convertor_t* convertor,
|
2009-03-25 16:53:26 +00:00
|
|
|
void* header,
|
|
|
|
size_t header_size,
|
|
|
|
size_t payload_size,
|
|
|
|
uint8_t order,
|
|
|
|
uint32_t flags,
|
|
|
|
mca_btl_base_tag_t tag,
|
2011-07-04 14:00:41 +00:00
|
|
|
mca_btl_base_descriptor_t** descriptor)
|
2009-03-25 16:53:26 +00:00
|
|
|
{
|
|
|
|
mca_btl_openib_module_t *obtl = (mca_btl_openib_module_t*)btl;
|
|
|
|
size_t size = payload_size + header_size;
|
2013-07-04 08:34:37 +00:00
|
|
|
int qp = frag_size_to_order(obtl, size),
|
2015-02-11 15:47:56 -05:00
|
|
|
prio = flags & MCA_BTL_DES_FLAGS_PRIORITY,
|
2009-03-25 16:53:26 +00:00
|
|
|
ib_rc;
|
|
|
|
bool do_rdma = false;
|
2015-02-19 13:41:41 -07:00
|
|
|
opal_free_list_item_t* item = NULL;
|
2009-03-25 16:53:26 +00:00
|
|
|
mca_btl_openib_frag_t *frag;
|
|
|
|
mca_btl_openib_header_t *hdr;
|
2012-12-26 10:19:12 +00:00
|
|
|
int send_signaled;
|
2015-01-06 08:47:07 -07:00
|
|
|
int rc;
|
2009-03-25 16:53:26 +00:00
|
|
|
|
|
|
|
OPAL_THREAD_LOCK(&ep->endpoint_lock);
|
|
|
|
|
|
|
|
if (OPAL_UNLIKELY(MCA_BTL_IB_CONNECTED != ep->endpoint_state)) {
|
|
|
|
goto cant_send;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* If it is pending messages on the qp - we can not send */
|
|
|
|
if(OPAL_UNLIKELY(!opal_list_is_empty(&ep->qps[qp].no_wqe_pending_frags[prio]))) {
|
|
|
|
goto cant_send;
|
|
|
|
}
|
|
|
|
|
2014-10-24 13:35:01 -07:00
|
|
|
#if OPAL_CUDA_GDR_SUPPORT
|
|
|
|
/* We do not want to use this path when we have GDR support */
|
|
|
|
if (convertor->flags & CONVERTOR_CUDA) {
|
|
|
|
goto cant_send;
|
|
|
|
}
|
|
|
|
#endif /* OPAL_CUDA_GDR_SUPPORT */
|
|
|
|
|
2009-03-25 16:53:26 +00:00
|
|
|
/* Allocate WQE */
|
|
|
|
if(OPAL_UNLIKELY(qp_get_wqe(ep, qp) < 0)) {
|
2015-01-06 08:47:07 -07:00
|
|
|
goto cant_send_wqe;
|
2009-03-25 16:53:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Allocate fragment */
|
2015-02-19 13:41:41 -07:00
|
|
|
item = opal_free_list_get (&obtl->device->qps[qp].send_free);
|
2009-03-25 16:53:26 +00:00
|
|
|
if(OPAL_UNLIKELY(NULL == item)) {
|
|
|
|
/* we don't return NULL because maybe later we will try to coalesce */
|
2015-01-06 08:47:07 -07:00
|
|
|
goto cant_send_wqe;
|
2009-03-25 16:53:26 +00:00
|
|
|
}
|
|
|
|
frag = to_base_frag(item);
|
|
|
|
hdr = to_send_frag(item)->hdr;
|
2015-01-06 08:47:07 -07:00
|
|
|
|
|
|
|
/* eager rdma or send ? Check eager rdma credits */
|
|
|
|
/* Note: Maybe we want to implement isend only for eager rdma ?*/
|
|
|
|
rc = mca_btl_openib_endpoint_credit_acquire (ep, qp, prio, size, &do_rdma,
|
|
|
|
to_send_frag(frag), false);
|
|
|
|
if (OPAL_UNLIKELY(OPAL_SUCCESS != rc)) {
|
|
|
|
goto cant_send_frag;
|
|
|
|
}
|
|
|
|
|
2015-03-10 14:21:42 -06:00
|
|
|
frag->segment.seg_len = size;
|
2009-03-25 16:53:26 +00:00
|
|
|
frag->base.order = qp;
|
|
|
|
frag->base.des_flags = flags;
|
|
|
|
hdr->tag = tag;
|
|
|
|
to_com_frag(item)->endpoint = ep;
|
|
|
|
|
|
|
|
/* put match header */
|
2015-03-10 14:21:42 -06:00
|
|
|
memcpy(frag->segment.seg_addr.pval, header, header_size);
|
2009-03-25 16:53:26 +00:00
|
|
|
|
|
|
|
/* Pack data */
|
|
|
|
if(payload_size) {
|
|
|
|
size_t max_data;
|
|
|
|
struct iovec iov;
|
|
|
|
uint32_t iov_count;
|
|
|
|
/* pack the data into the supplied buffer */
|
2015-03-10 14:21:42 -06:00
|
|
|
iov.iov_base = (IOVBASE_TYPE*)((unsigned char*)frag->segment.seg_addr.pval + header_size);
|
2009-03-25 16:53:26 +00:00
|
|
|
iov.iov_len = max_data = payload_size;
|
|
|
|
iov_count = 1;
|
|
|
|
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
(void)opal_convertor_pack( convertor, &iov, &iov_count, &max_data);
|
2009-03-25 16:53:26 +00:00
|
|
|
|
|
|
|
assert(max_data == payload_size);
|
|
|
|
}
|
|
|
|
|
2012-12-26 10:19:12 +00:00
|
|
|
#if BTL_OPENIB_FAILOVER_ENABLED
|
2013-01-13 10:11:03 +00:00
|
|
|
send_signaled = 1;
|
2012-12-26 10:19:12 +00:00
|
|
|
#else
|
|
|
|
send_signaled = qp_need_signal(ep, qp, payload_size + header_size, do_rdma);
|
|
|
|
#endif
|
|
|
|
ib_rc = post_send(ep, to_send_frag(item), do_rdma, send_signaled);
|
2009-03-25 16:53:26 +00:00
|
|
|
|
2015-01-06 08:47:07 -07:00
|
|
|
if (!ib_rc) {
|
2012-12-26 10:19:12 +00:00
|
|
|
if (0 == send_signaled) {
|
|
|
|
MCA_BTL_IB_FRAG_RETURN(frag);
|
|
|
|
}
|
2011-01-19 20:58:22 +00:00
|
|
|
#if BTL_OPENIB_FAILOVER_ENABLED
|
2012-12-26 10:19:12 +00:00
|
|
|
else {
|
|
|
|
/* Return up in case needed for failover */
|
|
|
|
*descriptor = (struct mca_btl_base_descriptor_t *) frag;
|
|
|
|
}
|
2010-07-14 10:08:19 +00:00
|
|
|
#endif
|
2009-03-25 16:53:26 +00:00
|
|
|
OPAL_THREAD_UNLOCK(&ep->endpoint_lock);
|
2015-01-06 08:47:07 -07:00
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2009-03-25 16:53:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Failed to send, do clean up all allocated resources */
|
2015-01-06 08:47:07 -07:00
|
|
|
if (ep->nbo) {
|
2009-03-25 16:53:26 +00:00
|
|
|
BTL_OPENIB_HEADER_NTOH(*hdr);
|
|
|
|
}
|
2015-01-06 08:47:07 -07:00
|
|
|
|
|
|
|
mca_btl_openib_endpoint_credit_release (ep, qp, do_rdma, to_send_frag(frag));
|
|
|
|
|
|
|
|
cant_send_frag:
|
|
|
|
MCA_BTL_IB_FRAG_RETURN(frag);
|
|
|
|
cant_send_wqe:
|
|
|
|
qp_put_wqe (ep, qp);
|
2009-03-25 16:53:26 +00:00
|
|
|
cant_send:
|
|
|
|
OPAL_THREAD_UNLOCK(&ep->endpoint_lock);
|
|
|
|
/* We can not send the data directly, so we just return descriptor */
|
2015-01-05 14:41:21 -07:00
|
|
|
if (NULL != descriptor) {
|
|
|
|
*descriptor = mca_btl_openib_alloc(btl, ep, order, size, flags);
|
|
|
|
}
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_ERR_RESOURCE_BUSY;
|
2009-03-25 16:53:26 +00:00
|
|
|
}
|
2005-06-30 21:28:35 +00:00
|
|
|
/*
|
2008-01-21 12:11:18 +00:00
|
|
|
* Initiate a send.
|
2005-06-30 21:28:35 +00:00
|
|
|
*/
|
|
|
|
|
2008-01-21 12:11:18 +00:00
|
|
|
int mca_btl_openib_send(
|
2005-06-30 21:28:35 +00:00
|
|
|
struct mca_btl_base_module_t* btl,
|
2007-12-09 14:05:13 +00:00
|
|
|
struct mca_btl_base_endpoint_t* ep,
|
|
|
|
struct mca_btl_base_descriptor_t* des,
|
2005-06-30 21:28:35 +00:00
|
|
|
mca_btl_base_tag_t tag)
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
2007-12-09 14:05:13 +00:00
|
|
|
mca_btl_openib_send_frag_t *frag;
|
|
|
|
|
|
|
|
assert(openib_frag_type(des) == MCA_BTL_OPENIB_FRAG_SEND ||
|
|
|
|
openib_frag_type(des) == MCA_BTL_OPENIB_FRAG_COALESCED);
|
2008-01-21 12:11:18 +00:00
|
|
|
|
2007-12-09 14:05:13 +00:00
|
|
|
if(openib_frag_type(des) == MCA_BTL_OPENIB_FRAG_COALESCED) {
|
2014-11-04 14:26:17 -07:00
|
|
|
frag = to_coalesced_frag(des)->send_frag;
|
|
|
|
|
|
|
|
/* save coalesced fragment on a main fragment; we will need it after send
|
|
|
|
* completion to free it and to call upper layer callback */
|
|
|
|
opal_list_append(&frag->coalesced_frags, (opal_list_item_t*) des);
|
|
|
|
frag->coalesced_length += to_coalesced_frag(des)->hdr->alloc_size +
|
|
|
|
sizeof(mca_btl_openib_header_coalesced_t);
|
|
|
|
|
|
|
|
to_coalesced_frag(des)->sent = true;
|
2007-12-09 14:05:13 +00:00
|
|
|
to_coalesced_frag(des)->hdr->tag = tag;
|
2015-01-06 08:48:33 -07:00
|
|
|
to_coalesced_frag(des)->hdr->size = des->des_segments->seg_len;
|
2007-12-09 14:10:25 +00:00
|
|
|
if(ep->nbo)
|
|
|
|
BTL_OPENIB_HEADER_COALESCED_HTON(*to_coalesced_frag(des)->hdr);
|
2007-12-09 14:05:13 +00:00
|
|
|
} else {
|
|
|
|
frag = to_send_frag(des);
|
2008-01-21 12:11:18 +00:00
|
|
|
to_com_frag(des)->endpoint = ep;
|
2007-12-09 14:05:13 +00:00
|
|
|
frag->hdr->tag = tag;
|
|
|
|
}
|
2007-11-28 07:11:14 +00:00
|
|
|
|
2009-03-25 16:53:26 +00:00
|
|
|
des->des_flags |= MCA_BTL_DES_SEND_ALWAYS_CALLBACK;
|
|
|
|
|
2007-12-09 14:05:13 +00:00
|
|
|
return mca_btl_openib_endpoint_send(ep, frag);
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
|
2015-01-06 08:48:33 -07:00
|
|
|
static mca_btl_base_registration_handle_t *mca_btl_openib_register_mem (mca_btl_base_module_t *btl,
|
|
|
|
mca_btl_base_endpoint_t *endpoint,
|
|
|
|
void *base, size_t size, uint32_t flags)
|
2014-10-30 16:43:41 -06:00
|
|
|
{
|
2015-11-02 12:07:08 -07:00
|
|
|
mca_btl_openib_module_t *openib_module = (mca_btl_openib_module_t *) btl;
|
2015-01-06 08:48:33 -07:00
|
|
|
mca_btl_openib_reg_t *reg;
|
|
|
|
uint32_t mflags = 0;
|
2015-09-29 15:28:00 -06:00
|
|
|
int access_flags = flags & MCA_BTL_REG_FLAG_ACCESS_ANY;
|
2015-01-06 08:48:33 -07:00
|
|
|
int rc;
|
2014-11-19 23:22:43 -07:00
|
|
|
|
2015-01-06 08:48:33 -07:00
|
|
|
#if OPAL_CUDA_GDR_SUPPORT
|
|
|
|
if (flags & MCA_BTL_REG_FLAG_CUDA_GPU_MEM) {
|
2015-11-02 12:07:08 -07:00
|
|
|
mflags |= MCA_RCACHE_FLAGS_CUDA_GPU_MEM;
|
2014-10-30 16:43:41 -06:00
|
|
|
}
|
2015-01-06 08:48:33 -07:00
|
|
|
#endif /* OPAL_CUDA_GDR_SUPPORT */
|
2014-10-30 16:43:41 -06:00
|
|
|
|
2015-11-02 12:07:08 -07:00
|
|
|
rc = openib_module->device->rcache->rcache_register (openib_module->device->rcache, base, size, mflags,
|
|
|
|
access_flags, (mca_rcache_base_registration_t **) ®);
|
2015-01-06 08:48:33 -07:00
|
|
|
if (OPAL_UNLIKELY(OPAL_SUCCESS != rc || NULL == reg)) {
|
|
|
|
return NULL;
|
2014-11-19 23:22:43 -07:00
|
|
|
}
|
2014-10-30 16:43:41 -06:00
|
|
|
|
2015-01-06 08:48:33 -07:00
|
|
|
return ®->btl_handle;
|
2014-10-30 16:43:41 -06:00
|
|
|
}
|
|
|
|
|
2015-01-06 08:48:33 -07:00
|
|
|
static int mca_btl_openib_deregister_mem (mca_btl_base_module_t *btl, mca_btl_base_registration_handle_t *handle)
|
2014-10-30 16:43:41 -06:00
|
|
|
{
|
2015-11-02 12:07:08 -07:00
|
|
|
mca_btl_openib_module_t *openib_module = (mca_btl_openib_module_t *) btl;
|
2015-01-06 08:48:33 -07:00
|
|
|
mca_btl_openib_reg_t *reg = (mca_btl_openib_reg_t *)((intptr_t) handle - offsetof (mca_btl_openib_reg_t, btl_handle));
|
2014-10-30 16:43:41 -06:00
|
|
|
|
2015-11-02 12:07:08 -07:00
|
|
|
openib_module->device->rcache->rcache_deregister (openib_module->device->rcache, (mca_rcache_base_registration_t *) reg);
|
2014-10-30 16:43:41 -06:00
|
|
|
|
|
|
|
return OPAL_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2010-03-12 23:57:50 +00:00
|
|
|
#if OPAL_ENABLE_FT_CR == 0
|
2007-03-16 23:11:45 +00:00
|
|
|
int mca_btl_openib_ft_event(int state) {
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2008-10-16 15:09:00 +00:00
|
|
|
}
|
|
|
|
#else
|
|
|
|
int mca_btl_openib_ft_event(int state) {
|
|
|
|
int i;
|
|
|
|
|
2007-03-16 23:11:45 +00:00
|
|
|
if(OPAL_CRS_CHECKPOINT == state) {
|
2008-10-16 15:09:00 +00:00
|
|
|
/* Continue must reconstruct the routes (including modex), since we
|
|
|
|
* have to tear down the devices completely. */
|
2014-12-22 21:36:51 +01:00
|
|
|
opal_cr_continue_like_restart = true;
|
2008-10-16 15:09:00 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* To keep the node from crashing we need to call ibv_close_device
|
|
|
|
* before the checkpoint is taken. To do this we need to tear
|
|
|
|
* everything down, and rebuild it all on continue/restart. :(
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Shutdown all modules
|
|
|
|
* - Do this backwards since the openib_finalize function also loops
|
|
|
|
* over this variable.
|
|
|
|
*/
|
|
|
|
for (i = 0; i < mca_btl_openib_component.ib_num_btls; ++i ) {
|
2008-11-10 18:35:57 +00:00
|
|
|
mca_btl_openib_finalize_resources( &(mca_btl_openib_component.openib_btls[i])->super);
|
2008-10-16 15:09:00 +00:00
|
|
|
}
|
2008-11-10 18:35:57 +00:00
|
|
|
|
|
|
|
mca_btl_openib_component.devices_count = 0;
|
|
|
|
mca_btl_openib_component.ib_num_btls = 0;
|
|
|
|
OBJ_DESTRUCT(&mca_btl_openib_component.ib_procs);
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
opal_btl_openib_connect_base_finalize();
|
2007-03-16 23:11:45 +00:00
|
|
|
}
|
|
|
|
else if(OPAL_CRS_CONTINUE == state) {
|
2008-10-16 15:09:00 +00:00
|
|
|
; /* Cleared by forcing the modex, no work needed */
|
2007-03-16 23:11:45 +00:00
|
|
|
}
|
|
|
|
else if(OPAL_CRS_RESTART == state) {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
else if(OPAL_CRS_TERM == state ) {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
return OPAL_SUCCESS;
|
2007-03-16 23:11:45 +00:00
|
|
|
}
|
2008-10-16 15:09:00 +00:00
|
|
|
|
2010-03-12 23:57:50 +00:00
|
|
|
#endif /* OPAL_ENABLE_FT_CR */
|