2011-11-02 15:07:57 +00:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
2011-10-20 21:39:44 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2009 The University of Tennessee and The University
|
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2006-2007 Voltaire. All rights reserved.
|
|
|
|
* Copyright (c) 2009-2010 Cisco Systems, Inc. All rights reserved.
|
2014-01-29 18:35:47 +00:00
|
|
|
* Copyright (c) 2010-2014 Los Alamos National Security, LLC.
|
2011-10-20 21:39:44 +00:00
|
|
|
* All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
*/
|
|
|
|
#ifndef MCA_BTL_VADER_H
|
|
|
|
#define MCA_BTL_VADER_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_config.h"
|
2011-10-20 21:39:44 +00:00
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#ifdef HAVE_STDINT_H
|
|
|
|
# include <stdint.h>
|
|
|
|
#endif /* HAVE_STDINT_H */
|
|
|
|
#ifdef HAVE_SCHED_H
|
|
|
|
# include <sched.h>
|
|
|
|
#endif /* HAVE_SCHED_H */
|
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
# include <unistd.h>
|
|
|
|
#endif /* HAVE_UNISTD_H */
|
|
|
|
|
2014-01-06 19:51:44 +00:00
|
|
|
#include "opal/mca/shmem/base/base.h"
|
2011-10-20 21:39:44 +00:00
|
|
|
|
|
|
|
#include "opal/class/opal_free_list.h"
|
|
|
|
#include "opal/sys/atomic.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/mpool/mpool.h"
|
|
|
|
#include "opal/mca/mpool/base/base.h"
|
|
|
|
#include "opal/mca/btl/base/base.h"
|
|
|
|
#include "opal/mca/rcache/rcache.h"
|
|
|
|
#include "opal/mca/rcache/base/base.h"
|
2014-09-23 18:11:22 +00:00
|
|
|
#include "opal/mca/btl/base/btl_base_error.h"
|
2014-07-26 22:21:08 +00:00
|
|
|
#include "opal/util/proc.h"
|
2013-03-27 22:10:02 +00:00
|
|
|
#include "btl_vader_endpoint.h"
|
2011-10-20 21:39:44 +00:00
|
|
|
|
2014-09-23 18:11:22 +00:00
|
|
|
#include "opal/mca/pmix/pmix.h"
|
|
|
|
|
2014-10-17 17:06:33 -06:00
|
|
|
#include "btl_vader_xpmem.h"
|
|
|
|
#include "btl_vader_knem.h"
|
|
|
|
|
2011-10-20 21:39:44 +00:00
|
|
|
BEGIN_C_DECLS
|
|
|
|
|
|
|
|
#define min(a,b) ((a) < (b) ? (a) : (b))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Shared Memory resource managment
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct vader_fifo_t;
|
|
|
|
|
2013-03-27 22:10:02 +00:00
|
|
|
/*
|
|
|
|
* Modex data
|
|
|
|
*/
|
2014-10-17 17:06:33 -06:00
|
|
|
union vader_modex_t {
|
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_BTL_VADER_HAVE_XPMEM
|
2014-10-17 17:06:33 -06:00
|
|
|
struct vader_modex_xpmem_t {
|
|
|
|
xpmem_segid_t seg_id;
|
|
|
|
void *segment_base;
|
|
|
|
} xpmem;
|
2014-01-06 19:51:44 +00:00
|
|
|
#endif
|
2014-10-17 17:06:33 -06:00
|
|
|
opal_shmem_ds_t seg_ds;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Single copy mechanisms
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
MCA_BTL_VADER_XPMEM = 0,
|
|
|
|
MCA_BTL_VADER_CMA = 1,
|
|
|
|
MCA_BTL_VADER_KNEM = 2,
|
|
|
|
MCA_BTL_VADER_NONE = 3,
|
2013-03-27 22:10:02 +00:00
|
|
|
};
|
|
|
|
|
2011-10-20 21:39:44 +00:00
|
|
|
/**
|
|
|
|
* Shared Memory (VADER) BTL module.
|
|
|
|
*/
|
|
|
|
struct mca_btl_vader_component_t {
|
|
|
|
mca_btl_base_component_2_0_0_t super; /**< base BTL component */
|
|
|
|
int vader_free_list_num; /**< initial size of free lists */
|
|
|
|
int vader_free_list_max; /**< maximum size of free lists */
|
2014-09-23 18:11:22 +00:00
|
|
|
int vader_free_list_inc; /**< number of elements to alloc when growing free lists */
|
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_BTL_VADER_HAVE_XPMEM
|
2014-09-23 18:11:22 +00:00
|
|
|
xpmem_segid_t my_seg_id; /**< this rank's xpmem segment id */
|
2014-01-06 19:51:44 +00:00
|
|
|
#endif
|
2014-10-17 17:06:33 -06:00
|
|
|
opal_shmem_ds_t seg_ds; /**< this rank's shared memory segment (when not using xpmem) */
|
2014-01-06 19:51:44 +00:00
|
|
|
|
2014-09-23 18:11:22 +00:00
|
|
|
opal_mutex_t lock; /**< lock to protect concurrent updates to this structure's members */
|
|
|
|
char *my_segment; /**< this rank's base pointer */
|
|
|
|
size_t segment_size; /**< size of my_segment */
|
|
|
|
size_t segment_offset; /**< start of unused portion of my_segment */
|
2011-10-20 21:39:44 +00:00
|
|
|
int32_t num_smp_procs; /**< current number of smp procs on this host */
|
|
|
|
ompi_free_list_t vader_frags_eager; /**< free list of vader send frags */
|
2014-09-23 18:11:22 +00:00
|
|
|
ompi_free_list_t vader_frags_max_send; /**< free list of vader max send frags (large fragments) */
|
2014-10-17 17:06:33 -06:00
|
|
|
ompi_free_list_t vader_frags_user; /**< free list of small inline frags */
|
2014-11-19 23:22:43 -07:00
|
|
|
ompi_free_list_t vader_frags_rdma; /**< free list of vader put/get frags (single-copy) */
|
2011-10-20 21:39:44 +00:00
|
|
|
|
2014-09-23 18:11:22 +00:00
|
|
|
unsigned int fbox_threshold; /**< number of sends required before we setup a send fast box for a peer */
|
|
|
|
unsigned int fbox_max; /**< maximum number of send fast boxes to allocate */
|
|
|
|
unsigned int fbox_size; /**< size of each peer fast box allocation */
|
|
|
|
unsigned int fbox_count; /**< number of send fast boxes allocated */
|
|
|
|
|
2014-10-17 17:06:33 -06:00
|
|
|
int single_copy_mechanism; /**< single copy mechanism to use */
|
|
|
|
|
2014-09-23 18:11:22 +00:00
|
|
|
int memcpy_limit; /**< Limit where we switch from memmove to memcpy */
|
|
|
|
int log_attach_align; /**< Log of the alignment for xpmem segments */
|
|
|
|
unsigned int max_inline_send; /**< Limit for copy-in-copy-out fragments */
|
|
|
|
|
|
|
|
mca_btl_base_endpoint_t *endpoints; /**< array of local endpoints (one for each local peer including myself) */
|
|
|
|
mca_btl_base_endpoint_t **fbox_in_endpoints; /**< array of fast box in endpoints */
|
|
|
|
unsigned int num_fbox_in_endpoints; /**< number of fast boxes to poll */
|
|
|
|
struct vader_fifo_t *my_fifo; /**< pointer to the local fifo */
|
2011-10-27 20:22:46 +00:00
|
|
|
|
2014-09-23 18:11:22 +00:00
|
|
|
opal_list_t pending_endpoints; /**< list of endpoints with pending fragments */
|
2014-10-17 17:06:33 -06:00
|
|
|
opal_list_t pending_fragments; /**< fragments pending remote completion */
|
|
|
|
|
|
|
|
/* knem stuff */
|
|
|
|
#if OPAL_BTL_VADER_HAVE_KNEM
|
|
|
|
unsigned int knem_dma_min; /**< minimum size to enable DMA for knem transfers (0 disables) */
|
|
|
|
#endif
|
2011-10-20 21:39:44 +00:00
|
|
|
};
|
|
|
|
typedef struct mca_btl_vader_component_t mca_btl_vader_component_t;
|
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_MODULE_DECLSPEC extern mca_btl_vader_component_t mca_btl_vader_component;
|
2011-10-20 21:39:44 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* VADER BTL Interface
|
|
|
|
*/
|
|
|
|
struct mca_btl_vader_t {
|
|
|
|
mca_btl_base_module_t super; /**< base BTL interface */
|
|
|
|
bool btl_inited; /**< flag indicating if btl has been inited */
|
|
|
|
mca_btl_base_module_error_cb_fn_t error_cb;
|
2014-10-17 17:06:33 -06:00
|
|
|
#if OPAL_BTL_VADER_HAVE_KNEM
|
|
|
|
int knem_fd;
|
|
|
|
#endif
|
2011-10-20 21:39:44 +00:00
|
|
|
};
|
|
|
|
typedef struct mca_btl_vader_t mca_btl_vader_t;
|
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_MODULE_DECLSPEC extern mca_btl_vader_t mca_btl_vader;
|
2011-10-20 21:39:44 +00:00
|
|
|
|
2013-07-11 20:54:12 +00:00
|
|
|
/* number of peers on the node (not including self) */
|
2014-07-26 21:48:23 +00:00
|
|
|
#define MCA_BTL_VADER_NUM_LOCAL_PEERS opal_process_info.num_local_peers
|
2013-07-11 20:54:12 +00:00
|
|
|
|
|
|
|
/* local rank in the group */
|
2014-07-26 21:48:23 +00:00
|
|
|
#define MCA_BTL_VADER_LOCAL_RANK opal_process_info.my_local_rank
|
2013-07-11 20:54:12 +00:00
|
|
|
|
2011-10-27 20:22:46 +00:00
|
|
|
/* memcpy is faster at larger sizes but is undefined if the
|
|
|
|
pointers are aliased (TODO -- readd alias check) */
|
|
|
|
static inline void vader_memmove (void *dst, void *src, size_t size)
|
|
|
|
{
|
2013-03-27 22:10:02 +00:00
|
|
|
if (size >= (size_t) mca_btl_vader_component.memcpy_limit) {
|
2011-11-02 15:07:57 +00:00
|
|
|
memcpy (dst, src, size);
|
2011-10-27 20:22:46 +00:00
|
|
|
} else {
|
2011-11-02 15:07:57 +00:00
|
|
|
memmove (dst, src, size);
|
2011-10-27 20:22:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-10-20 21:39:44 +00:00
|
|
|
/**
|
|
|
|
* Initiate a send to the peer.
|
|
|
|
*
|
|
|
|
* @param btl (IN) BTL module
|
|
|
|
* @param peer (IN) BTL peer addressing
|
|
|
|
*/
|
|
|
|
int mca_btl_vader_send(struct mca_btl_base_module_t *btl,
|
2011-11-02 15:07:57 +00:00
|
|
|
struct mca_btl_base_endpoint_t *endpoint,
|
|
|
|
struct mca_btl_base_descriptor_t *descriptor,
|
|
|
|
mca_btl_base_tag_t tag);
|
2011-10-20 21:39:44 +00:00
|
|
|
|
|
|
|
/**
|
2011-10-26 22:15:42 +00:00
|
|
|
* Initiate an inline send to the peer.
|
2011-10-20 21:39:44 +00:00
|
|
|
*
|
|
|
|
* @param btl (IN) BTL module
|
|
|
|
* @param peer (IN) BTL peer addressing
|
|
|
|
*/
|
|
|
|
int mca_btl_vader_sendi (struct mca_btl_base_module_t *btl,
|
2011-11-02 15:07:57 +00:00
|
|
|
struct mca_btl_base_endpoint_t *endpoint,
|
|
|
|
struct opal_convertor_t *convertor,
|
|
|
|
void *header, size_t header_size,
|
|
|
|
size_t payload_size, uint8_t order,
|
|
|
|
uint32_t flags, mca_btl_base_tag_t tag,
|
|
|
|
mca_btl_base_descriptor_t **descriptor);
|
2011-10-20 21:39:44 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initiate an synchronous put.
|
|
|
|
*
|
|
|
|
* @param btl (IN) BTL module
|
|
|
|
* @param endpoint (IN) BTL addressing information
|
|
|
|
* @param descriptor (IN) Description of the data to be transferred
|
|
|
|
*/
|
2014-10-17 17:06:33 -06:00
|
|
|
#if OPAL_BTL_VADER_HAVE_XPMEM
|
2014-11-19 23:22:43 -07:00
|
|
|
int mca_btl_vader_put_xpmem (struct mca_btl_base_module_t *btl,
|
|
|
|
struct mca_btl_base_endpoint_t *endpoint,
|
|
|
|
struct mca_btl_base_descriptor_t *des);
|
2014-10-17 17:06:33 -06:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if OPAL_BTL_VADER_HAVE_CMA
|
2014-11-19 23:22:43 -07:00
|
|
|
int mca_btl_vader_put_cma (struct mca_btl_base_module_t *btl,
|
|
|
|
struct mca_btl_base_endpoint_t *endpoint,
|
|
|
|
struct mca_btl_base_descriptor_t *des);
|
2014-10-17 17:06:33 -06:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if OPAL_BTL_VADER_HAVE_KNEM
|
2014-11-19 23:22:43 -07:00
|
|
|
int mca_btl_vader_put_knem (struct mca_btl_base_module_t *btl,
|
|
|
|
struct mca_btl_base_endpoint_t *endpoint,
|
|
|
|
struct mca_btl_base_descriptor_t *des);
|
2014-10-17 17:06:33 -06:00
|
|
|
#endif
|
2011-10-20 21:39:44 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initiate an synchronous get.
|
|
|
|
*
|
|
|
|
* @param btl (IN) BTL module
|
|
|
|
* @param endpoint (IN) BTL addressing information
|
|
|
|
* @param descriptor (IN) Description of the data to be transferred
|
|
|
|
*/
|
2014-10-17 17:06:33 -06:00
|
|
|
#if OPAL_BTL_VADER_HAVE_XPMEM
|
2014-11-19 23:22:43 -07:00
|
|
|
int mca_btl_vader_get_xpmem (struct mca_btl_base_module_t *btl,
|
|
|
|
struct mca_btl_base_endpoint_t *endpoint,
|
|
|
|
struct mca_btl_base_descriptor_t *des);
|
2014-10-17 17:06:33 -06:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if OPAL_BTL_VADER_HAVE_CMA
|
2014-11-19 23:22:43 -07:00
|
|
|
int mca_btl_vader_get_cma (struct mca_btl_base_module_t *btl,
|
|
|
|
struct mca_btl_base_endpoint_t *endpoint,
|
|
|
|
struct mca_btl_base_descriptor_t *des);
|
2014-10-17 17:06:33 -06:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if OPAL_BTL_VADER_HAVE_KNEM
|
2014-11-19 23:22:43 -07:00
|
|
|
int mca_btl_vader_get_knem (struct mca_btl_base_module_t *btl,
|
|
|
|
struct mca_btl_base_endpoint_t *endpoint,
|
|
|
|
struct mca_btl_base_descriptor_t *des);
|
2014-10-17 17:06:33 -06:00
|
|
|
#endif
|
2011-10-20 21:39:44 +00:00
|
|
|
|
2011-10-26 22:15:42 +00:00
|
|
|
/**
|
|
|
|
* Allocate a segment.
|
|
|
|
*
|
|
|
|
* @param btl (IN) BTL module
|
|
|
|
* @param size (IN) Request segment size.
|
|
|
|
*/
|
|
|
|
mca_btl_base_descriptor_t* mca_btl_vader_alloc (struct mca_btl_base_module_t* btl,
|
2011-11-02 15:07:57 +00:00
|
|
|
struct mca_btl_base_endpoint_t* endpoint,
|
|
|
|
uint8_t order, size_t size, uint32_t flags);
|
2011-10-26 22:15:42 +00:00
|
|
|
|
2011-10-20 21:39:44 +00:00
|
|
|
END_C_DECLS
|
|
|
|
|
|
|
|
#endif
|