btl_udapl_endpoint.h

来自「MPI stands for the Message Passing Inter」· C头文件 代码 · 共 194 行

H
194
字号
/* * Copyright (c) 2004-2006 The Trustees of Indiana University and Indiana *                         University Research and Technology *                         Corporation.  All rights reserved. * Copyright (c) 2004-2005 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      Sandia National Laboratories. All rights *                         reserved. * Copyright (c) 2006      Sun Microsystems, Inc.  All rights reserved. * * $COPYRIGHT$ *  * Additional copyrights may follow *  * $HEADER$ */#ifndef MCA_BTL_UDAPL_ENDPOINT_H#define MCA_BTL_UDAPL_ENDPOINT_H#include "opal/class/opal_list.h"#include "opal/event/event.h"#include "ompi/mca/pml/pml.h"#include "ompi/mca/btl/btl.h"#include "ompi/mca/btl/base/btl_base_error.h"#include "btl_udapl_frag.h"#include "btl_udapl.h"#include "btl_udapl_eager_rdma.h"#if defined(c_plusplus) || defined(__cplusplus)extern "C" {#endif#define BTL_UDAPL_TOKENS(E, C) ((E)->endpoint_sr_tokens[(C)] + \        (((C) == BTL_UDAPL_EAGER_CONNECTION)?(E)->endpoint_eager_rdma_remote.tokens:0))/** * Structure used to publish uDAPL id information to peers. */struct mca_btl_udapl_addr_t {    DAT_CONN_QUAL port;    DAT_SOCK_ADDR addr;};typedef struct mca_btl_udapl_addr_t mca_btl_udapl_addr_t;    /** * State of uDAPL endpoint connection. */typedef enum {    MCA_BTL_UDAPL_CONN_EAGER,    MCA_BTL_UDAPL_CONN_MAX,    MCA_BTL_UDAPL_CONNECTED,    MCA_BTL_UDAPL_CLOSED,    MCA_BTL_UDAPL_FAILED} mca_btl_udapl_endpoint_state_t;/* * Establish a name for the 2 connections opened per peer */typedef enum {    BTL_UDAPL_EAGER_CONNECTION,    BTL_UDAPL_MAX_CONNECTION,    BTL_UDAPL_NUM_CONNECTION} mca_btl_udapl_endpoint_conn_t;    /* * Encapsulate data that describes sendrecv credit information. */struct mca_btl_udapl_sr_credit_t {        mca_btl_udapl_control_header_t control;        uint32_t credits;        int connection; /* 0 == BTL_UDAPL_EAGER_CONNECTION;                           1 == BTL_UDAPL_MAX_CONNECTION */};typedef struct mca_btl_udapl_sr_credit_t mca_btl_udapl_sr_credit_t;/** * An abstraction that represents a connection to a endpoint process. * An instance of mca_btl_base_endpoint_t is associated w/ each process * and BTL pair at startup. However, connections to the endpoint * are established dynamically on an as-needed basis:*/struct mca_btl_base_endpoint_t {    opal_list_item_t            super;    struct mca_btl_udapl_module_t* endpoint_btl;    /**< BTL instance that created this connection */    struct mca_btl_udapl_proc_t*   endpoint_proc;    /**< proc structure corresponding to endpoint */    mca_btl_udapl_endpoint_state_t endpoint_state;    /**< current state of the endpoint connection */    opal_list_t endpoint_eager_frags;    opal_list_t endpoint_max_frags;    /**< pending send frags on this endpoint */    int32_t endpoint_eager_sends;    int32_t endpoint_max_sends;    /**< number of sends that may be posted */    int32_t endpoint_sr_tokens[BTL_UDAPL_NUM_CONNECTION];    /**< number of sends that may be posted */    int32_t endpoint_sr_credits[BTL_UDAPL_NUM_CONNECTION];    /**< number of recvs that are now available */    int32_t endpoint_connection_seq;    /**< sequence number of sendrecv message for the connection est */    opal_mutex_t endpoint_lock;    /**< lock for concurrent access to endpoint state */    mca_btl_udapl_addr_t endpoint_addr;    /**< remote address on the other side of this endpoint */    DAT_EP_HANDLE endpoint_eager;    DAT_EP_HANDLE endpoint_max;    /**< uDAPL endpoint handle */    int32_t endpoint_eager_rdma_index;    /**< index into array of endpoints with RDMA buffers */    mca_btl_udapl_eager_rdma_local_t endpoint_eager_rdma_local;    /**< info about local RDMA buffer */    mca_btl_udapl_eager_rdma_remote_t endpoint_eager_rdma_remote;     /**< info about remote RDMA buffer */};typedef struct mca_btl_base_endpoint_t mca_btl_base_endpoint_t;typedef mca_btl_base_endpoint_t  mca_btl_udapl_endpoint_t;OBJ_CLASS_DECLARATION(mca_btl_udapl_endpoint_t);/* * Start sending data on an endpoint. */int mca_btl_udapl_endpoint_send(mca_btl_base_endpoint_t* endpoint,                                mca_btl_udapl_frag_t* frag);/* * Set up OOB recv callback. */void mca_btl_udapl_endpoint_post_oob_recv(void);/* * Finish establishing a connection */int mca_btl_udapl_endpoint_finish_connect(struct mca_btl_udapl_module_t* btl,                                          mca_btl_udapl_addr_t* addr,                                          int32_t* seq,                                          DAT_EP_HANDLE endpoint);/* * Send number of eager rdma credits */int mca_btl_udapl_endpoint_send_eager_rdma_credits(mca_btl_base_endpoint_t* endpoint);/* * Establish uDAPL endpoint parameters */int mca_btl_udapl_endpoint_get_params(struct mca_btl_udapl_module_t* btl,                                      DAT_EP_PARAM* ep_param);/* * Create uDAPL endpoint */int mca_btl_udapl_endpoint_create(struct mca_btl_udapl_module_t* btl,                                  DAT_EP_HANDLE* udapl_endpoint); /* * Send number of send recv credits */int mca_btl_udapl_endpoint_send_sr_credits(mca_btl_base_endpoint_t* endpoint,                                           const int connection);#if defined(c_plusplus) || defined(__cplusplus)}#endif#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?