2012-04-25 00:19:06 +04:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
2005-05-24 02:06:50 +04:00
|
|
|
/*
|
2005-11-05 22:57:48 +03:00
|
|
|
* Copyright (c) 2004-2005 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.
|
2005-05-24 02:06:50 +04:00
|
|
|
* 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.
|
2009-04-21 18:41:51 +04:00
|
|
|
* Copyright (c) 2009 IBM Corporation. All rights reserved.
|
2012-04-25 00:19:15 +04:00
|
|
|
* Copyright (c) 2012 Los Alamos National Security, LLC. All rights
|
|
|
|
* reserved.
|
2005-05-24 02:06:50 +04:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
*/
|
2005-05-24 02:22:20 +04:00
|
|
|
#ifndef MCA_PML_OB1_HEADER_H
|
|
|
|
#define MCA_PML_OB1_HEADER_H
|
2005-05-24 02:06:50 +04:00
|
|
|
|
|
|
|
#include "ompi_config.h"
|
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
|
|
#include <sys/types.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_NETINET_IN_H
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#endif
|
|
|
|
|
2006-02-26 03:45:54 +03:00
|
|
|
#include "opal/types.h"
|
2008-04-18 00:43:56 +04:00
|
|
|
#include "opal/util/arch.h"
|
2009-03-18 00:34:30 +03:00
|
|
|
#include "ompi/mca/btl/btl.h"
|
|
|
|
#include "ompi/proc/proc.h"
|
2006-02-26 03:45:54 +03:00
|
|
|
|
2008-01-30 03:09:45 +03:00
|
|
|
#define MCA_PML_OB1_HDR_TYPE_MATCH (MCA_BTL_TAG_PML + 1)
|
|
|
|
#define MCA_PML_OB1_HDR_TYPE_RNDV (MCA_BTL_TAG_PML + 2)
|
|
|
|
#define MCA_PML_OB1_HDR_TYPE_RGET (MCA_BTL_TAG_PML + 3)
|
|
|
|
#define MCA_PML_OB1_HDR_TYPE_ACK (MCA_BTL_TAG_PML + 4)
|
|
|
|
#define MCA_PML_OB1_HDR_TYPE_NACK (MCA_BTL_TAG_PML + 5)
|
|
|
|
#define MCA_PML_OB1_HDR_TYPE_FRAG (MCA_BTL_TAG_PML + 6)
|
|
|
|
#define MCA_PML_OB1_HDR_TYPE_GET (MCA_BTL_TAG_PML + 7)
|
|
|
|
#define MCA_PML_OB1_HDR_TYPE_PUT (MCA_BTL_TAG_PML + 8)
|
|
|
|
#define MCA_PML_OB1_HDR_TYPE_FIN (MCA_BTL_TAG_PML + 9)
|
2005-05-24 02:06:50 +04:00
|
|
|
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_HDR_FLAGS_ACK 1 /* is an ack required */
|
|
|
|
#define MCA_PML_OB1_HDR_FLAGS_NBO 2 /* is the hdr in network byte order */
|
2005-06-22 00:58:24 +04:00
|
|
|
#define MCA_PML_OB1_HDR_FLAGS_PIN 4 /* is user buffer pinned */
|
2005-11-11 18:33:25 +03:00
|
|
|
#define MCA_PML_OB1_HDR_FLAGS_CONTIG 8 /* is user buffer contiguous */
|
2008-03-27 11:56:43 +03:00
|
|
|
#define MCA_PML_OB1_HDR_FLAGS_NORDMA 16 /* rest will be send by copy-in-out */
|
2005-05-24 02:06:50 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Common hdr attributes - must be first element in each hdr type
|
|
|
|
*/
|
|
|
|
struct mca_pml_ob1_common_hdr_t {
|
|
|
|
uint8_t hdr_type; /**< type of envelope */
|
|
|
|
uint8_t hdr_flags; /**< flags indicating how fragment should be processed */
|
|
|
|
};
|
|
|
|
typedef struct mca_pml_ob1_common_hdr_t mca_pml_ob1_common_hdr_t;
|
|
|
|
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_COMMON_HDR_NTOH(h)
|
|
|
|
#define MCA_PML_OB1_COMMON_HDR_HTON(h)
|
2005-05-24 02:06:50 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Header definition for the first fragment, contains the
|
|
|
|
* attributes required to match the corresponding posted receive.
|
|
|
|
*/
|
|
|
|
struct mca_pml_ob1_match_hdr_t {
|
|
|
|
mca_pml_ob1_common_hdr_t hdr_common; /**< common attributes */
|
2005-08-17 22:23:38 +04:00
|
|
|
uint16_t hdr_ctx; /**< communicator index */
|
|
|
|
int32_t hdr_src; /**< source rank */
|
|
|
|
int32_t hdr_tag; /**< user tag */
|
|
|
|
uint16_t hdr_seq; /**< message sequence number */
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2006-12-04 23:11:42 +03:00
|
|
|
uint8_t hdr_padding[2]; /**< explicitly pad to 16 bytes. Compilers seem to already prefer to do this, but make it explicit just in case */
|
|
|
|
#endif
|
2005-05-24 02:06:50 +04:00
|
|
|
};
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2008-05-30 07:58:39 +04:00
|
|
|
#define OMPI_PML_OB1_MATCH_HDR_LEN 16
|
|
|
|
#else
|
|
|
|
#define OMPI_PML_OB1_MATCH_HDR_LEN 14
|
|
|
|
#endif
|
|
|
|
|
2005-05-24 02:06:50 +04:00
|
|
|
typedef struct mca_pml_ob1_match_hdr_t mca_pml_ob1_match_hdr_t;
|
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG
|
2009-02-27 08:24:06 +03:00
|
|
|
#define MCA_PML_OB1_MATCH_HDR_FILL(h) \
|
|
|
|
do { \
|
|
|
|
(h).hdr_padding[0] = 0; \
|
|
|
|
(h).hdr_padding[1] = 0; \
|
|
|
|
} while(0)
|
|
|
|
#else
|
|
|
|
#define MCA_PML_OB1_MATCH_HDR_FILL(h)
|
2009-05-07 00:11:28 +04:00
|
|
|
#endif /* OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG */
|
2009-02-27 08:24:06 +03:00
|
|
|
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_MATCH_HDR_NTOH(h) \
|
2009-02-27 08:24:06 +03:00
|
|
|
do { \
|
2005-05-24 02:22:20 +04:00
|
|
|
MCA_PML_OB1_COMMON_HDR_NTOH((h).hdr_common); \
|
2005-08-17 22:23:38 +04:00
|
|
|
(h).hdr_ctx = ntohs((h).hdr_ctx); \
|
2005-05-24 02:06:50 +04:00
|
|
|
(h).hdr_src = ntohl((h).hdr_src); \
|
|
|
|
(h).hdr_tag = ntohl((h).hdr_tag); \
|
2005-08-17 22:23:38 +04:00
|
|
|
(h).hdr_seq = ntohs((h).hdr_seq); \
|
2009-02-27 08:24:06 +03:00
|
|
|
} while (0)
|
2005-05-24 02:06:50 +04:00
|
|
|
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_MATCH_HDR_HTON(h) \
|
2009-02-27 08:24:06 +03:00
|
|
|
do { \
|
2005-05-24 02:22:20 +04:00
|
|
|
MCA_PML_OB1_COMMON_HDR_HTON((h).hdr_common); \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_MATCH_HDR_FILL(h); \
|
2005-08-17 22:23:38 +04:00
|
|
|
(h).hdr_ctx = htons((h).hdr_ctx); \
|
2005-05-24 02:06:50 +04:00
|
|
|
(h).hdr_src = htonl((h).hdr_src); \
|
|
|
|
(h).hdr_tag = htonl((h).hdr_tag); \
|
2005-08-17 22:23:38 +04:00
|
|
|
(h).hdr_seq = htons((h).hdr_seq); \
|
2009-02-27 08:24:06 +03:00
|
|
|
} while (0)
|
|
|
|
|
2005-05-24 02:06:50 +04:00
|
|
|
/**
|
|
|
|
* Header definition for the first fragment when an acknowledgment
|
|
|
|
* is required. This could be the first fragment of a large message
|
|
|
|
* or a short message that requires an ack (synchronous).
|
|
|
|
*/
|
|
|
|
struct mca_pml_ob1_rendezvous_hdr_t {
|
|
|
|
mca_pml_ob1_match_hdr_t hdr_match;
|
2005-08-17 22:23:38 +04:00
|
|
|
uint64_t hdr_msg_length; /**< message length */
|
2005-06-01 18:34:22 +04:00
|
|
|
ompi_ptr_t hdr_src_req; /**< pointer to source request - returned in ack */
|
2005-05-24 02:06:50 +04:00
|
|
|
};
|
|
|
|
typedef struct mca_pml_ob1_rendezvous_hdr_t mca_pml_ob1_rendezvous_hdr_t;
|
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG
|
2009-02-27 08:24:06 +03:00
|
|
|
#define MCA_PML_OB1_RNDV_HDR_FILL(h) \
|
|
|
|
MCA_PML_OB1_MATCH_HDR_FILL((h).hdr_match)
|
|
|
|
#else
|
|
|
|
#define MCA_PML_OB1_RNDV_HDR_FILL(h)
|
2009-05-07 00:11:28 +04:00
|
|
|
#endif /* OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG */
|
2009-02-27 08:24:06 +03:00
|
|
|
|
2006-12-04 23:11:42 +03:00
|
|
|
/* Note that hdr_src_req is not put in network byte order because it
|
|
|
|
is never processed by the receiver, other than being copied into
|
|
|
|
the ack header */
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_RNDV_HDR_NTOH(h) \
|
2005-05-24 02:06:50 +04:00
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_MATCH_HDR_NTOH((h).hdr_match); \
|
|
|
|
(h).hdr_msg_length = ntoh64((h).hdr_msg_length); \
|
2005-05-24 02:06:50 +04:00
|
|
|
} while (0)
|
|
|
|
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_RNDV_HDR_HTON(h) \
|
2005-05-24 02:06:50 +04:00
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_MATCH_HDR_HTON((h).hdr_match); \
|
|
|
|
MCA_PML_OB1_RNDV_HDR_FILL(h); \
|
|
|
|
(h).hdr_msg_length = hton64((h).hdr_msg_length); \
|
2005-05-24 02:06:50 +04:00
|
|
|
} while (0)
|
|
|
|
|
2005-08-17 22:23:38 +04:00
|
|
|
/**
|
|
|
|
* Header definition for a combined rdma rendezvous/get
|
|
|
|
*/
|
|
|
|
struct mca_pml_ob1_rget_hdr_t {
|
|
|
|
mca_pml_ob1_rendezvous_hdr_t hdr_rndv;
|
|
|
|
uint32_t hdr_seg_cnt; /**< number of segments for rdma */
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2006-12-04 23:11:42 +03:00
|
|
|
uint8_t hdr_padding[4];
|
|
|
|
#endif
|
|
|
|
ompi_ptr_t hdr_des; /**< source descriptor */
|
2005-08-17 22:23:38 +04:00
|
|
|
};
|
|
|
|
typedef struct mca_pml_ob1_rget_hdr_t mca_pml_ob1_rget_hdr_t;
|
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG
|
2009-02-27 08:24:06 +03:00
|
|
|
#define MCA_PML_OB1_RGET_HDR_FILL(h) \
|
|
|
|
do { \
|
|
|
|
MCA_PML_OB1_RNDV_HDR_FILL((h).hdr_rndv); \
|
|
|
|
(h).hdr_padding[0] = 0; \
|
|
|
|
(h).hdr_padding[1] = 0; \
|
|
|
|
(h).hdr_padding[2] = 0; \
|
|
|
|
(h).hdr_padding[3] = 0; \
|
|
|
|
} while(0)
|
|
|
|
#else
|
|
|
|
#define MCA_PML_OB1_RGET_HDR_FILL(h)
|
2009-05-07 00:11:28 +04:00
|
|
|
#endif /* OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG */
|
2009-02-27 08:24:06 +03:00
|
|
|
|
2007-08-29 01:23:44 +04:00
|
|
|
#define MCA_PML_OB1_RGET_HDR_NTOH(h) \
|
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_RNDV_HDR_NTOH((h).hdr_rndv); \
|
|
|
|
(h).hdr_seg_cnt = ntohl((h).hdr_seg_cnt); \
|
2007-08-29 01:23:44 +04:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define MCA_PML_OB1_RGET_HDR_HTON(h) \
|
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_RNDV_HDR_HTON((h).hdr_rndv); \
|
|
|
|
MCA_PML_OB1_RGET_HDR_FILL(h); \
|
|
|
|
(h).hdr_seg_cnt = htonl((h).hdr_seg_cnt); \
|
2007-08-29 01:23:44 +04:00
|
|
|
} while (0)
|
|
|
|
|
2005-05-24 02:06:50 +04:00
|
|
|
/**
|
|
|
|
* Header for subsequent fragments.
|
|
|
|
*/
|
|
|
|
struct mca_pml_ob1_frag_hdr_t {
|
2005-08-17 22:23:38 +04:00
|
|
|
mca_pml_ob1_common_hdr_t hdr_common; /**< common attributes */
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2006-12-04 23:11:42 +03:00
|
|
|
uint8_t hdr_padding[6];
|
|
|
|
#endif
|
2005-05-24 02:06:50 +04:00
|
|
|
uint64_t hdr_frag_offset; /**< offset into message */
|
2005-06-01 18:34:22 +04:00
|
|
|
ompi_ptr_t hdr_src_req; /**< pointer to source request */
|
|
|
|
ompi_ptr_t hdr_dst_req; /**< pointer to matched receive */
|
2005-05-24 02:06:50 +04:00
|
|
|
};
|
|
|
|
typedef struct mca_pml_ob1_frag_hdr_t mca_pml_ob1_frag_hdr_t;
|
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG
|
2009-02-27 08:24:06 +03:00
|
|
|
#define MCA_PML_OB1_FRAG_HDR_FILL(h) \
|
|
|
|
do { \
|
|
|
|
(h).hdr_padding[0] = 0; \
|
|
|
|
(h).hdr_padding[1] = 0; \
|
|
|
|
(h).hdr_padding[2] = 0; \
|
|
|
|
(h).hdr_padding[3] = 0; \
|
|
|
|
(h).hdr_padding[4] = 0; \
|
|
|
|
(h).hdr_padding[5] = 0; \
|
|
|
|
} while(0)
|
|
|
|
#else
|
|
|
|
#define MCA_PML_OB1_FRAG_HDR_FILL(h)
|
2009-05-07 00:11:28 +04:00
|
|
|
#endif /* OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG */
|
2009-02-27 08:24:06 +03:00
|
|
|
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_FRAG_HDR_NTOH(h) \
|
2005-05-24 02:06:50 +04:00
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_COMMON_HDR_NTOH((h).hdr_common); \
|
|
|
|
(h).hdr_frag_offset = ntoh64((h).hdr_frag_offset); \
|
2005-05-24 02:06:50 +04:00
|
|
|
} while (0)
|
|
|
|
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_FRAG_HDR_HTON(h) \
|
2005-05-24 02:06:50 +04:00
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_COMMON_HDR_HTON((h).hdr_common); \
|
|
|
|
MCA_PML_OB1_FRAG_HDR_FILL(h); \
|
|
|
|
(h).hdr_frag_offset = hton64((h).hdr_frag_offset); \
|
2005-05-24 02:06:50 +04:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Header used to acknowledgment outstanding fragment(s).
|
|
|
|
*/
|
2005-06-01 18:34:22 +04:00
|
|
|
|
2005-05-24 02:06:50 +04:00
|
|
|
struct mca_pml_ob1_ack_hdr_t {
|
2005-06-01 18:34:22 +04:00
|
|
|
mca_pml_ob1_common_hdr_t hdr_common; /**< common attributes */
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2006-12-04 23:11:42 +03:00
|
|
|
uint8_t hdr_padding[6];
|
|
|
|
#endif
|
2005-06-01 18:34:22 +04:00
|
|
|
ompi_ptr_t hdr_src_req; /**< source request */
|
|
|
|
ompi_ptr_t hdr_dst_req; /**< matched receive request */
|
2007-06-03 12:30:07 +04:00
|
|
|
uint64_t hdr_send_offset; /**< starting point of copy in/out */
|
2005-05-24 02:06:50 +04:00
|
|
|
};
|
|
|
|
typedef struct mca_pml_ob1_ack_hdr_t mca_pml_ob1_ack_hdr_t;
|
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG
|
2009-02-27 08:24:06 +03:00
|
|
|
#define MCA_PML_OB1_ACK_HDR_FILL(h) \
|
|
|
|
do { \
|
|
|
|
(h).hdr_padding[0] = 0; \
|
|
|
|
(h).hdr_padding[1] = 0; \
|
|
|
|
(h).hdr_padding[2] = 0; \
|
|
|
|
(h).hdr_padding[3] = 0; \
|
|
|
|
(h).hdr_padding[4] = 0; \
|
|
|
|
(h).hdr_padding[5] = 0; \
|
|
|
|
} while (0)
|
|
|
|
#else
|
|
|
|
#define MCA_PML_OB1_ACK_HDR_FILL(h)
|
2009-05-07 00:11:28 +04:00
|
|
|
#endif /* OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG */
|
2009-02-27 08:24:06 +03:00
|
|
|
|
2006-12-04 23:11:42 +03:00
|
|
|
/* Note that the request headers are not put in NBO because the
|
|
|
|
src_req is already in receiver's byte order and the dst_req is not
|
|
|
|
used by the receiver for anything other than backpointers in return
|
|
|
|
headers */
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_ACK_HDR_NTOH(h) \
|
2005-05-24 02:06:50 +04:00
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_COMMON_HDR_NTOH((h).hdr_common); \
|
|
|
|
(h).hdr_send_offset = ntoh64((h).hdr_send_offset); \
|
2005-05-24 02:06:50 +04:00
|
|
|
} while (0)
|
|
|
|
|
2005-05-24 02:22:20 +04:00
|
|
|
#define MCA_PML_OB1_ACK_HDR_HTON(h) \
|
2005-05-24 02:06:50 +04:00
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_COMMON_HDR_HTON((h).hdr_common); \
|
|
|
|
MCA_PML_OB1_ACK_HDR_FILL(h); \
|
|
|
|
(h).hdr_send_offset = hton64((h).hdr_send_offset); \
|
2005-05-24 02:06:50 +04:00
|
|
|
} while (0)
|
|
|
|
|
2005-06-09 00:37:19 +04:00
|
|
|
/**
|
|
|
|
* Header used to initiate an RDMA operation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct mca_pml_ob1_rdma_hdr_t {
|
|
|
|
mca_pml_ob1_common_hdr_t hdr_common; /**< common attributes */
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2006-12-04 23:11:42 +03:00
|
|
|
uint8_t hdr_padding[2]; /** two to pad out the hdr to a 4 byte alignment. hdr_req will then be 8 byte aligned after 4 for hdr_seg_cnt */
|
|
|
|
#endif
|
|
|
|
uint32_t hdr_seg_cnt; /**< number of segments for rdma */
|
2005-08-17 22:23:38 +04:00
|
|
|
ompi_ptr_t hdr_req; /**< destination request */
|
|
|
|
ompi_ptr_t hdr_des; /**< source descriptor */
|
2012-06-14 21:29:58 +04:00
|
|
|
ompi_ptr_t hdr_recv_req; /**< receive request (NTH: needed for put fallback on send) */
|
2005-06-10 00:16:33 +04:00
|
|
|
uint64_t hdr_rdma_offset; /**< current offset into user buffer */
|
2005-06-30 09:50:55 +04:00
|
|
|
mca_btl_base_segment_t hdr_segs[1]; /**< list of segments for rdma */
|
2005-06-09 00:37:19 +04:00
|
|
|
};
|
|
|
|
typedef struct mca_pml_ob1_rdma_hdr_t mca_pml_ob1_rdma_hdr_t;
|
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG
|
2009-02-27 08:24:06 +03:00
|
|
|
#define MCA_PML_OB1_RDMA_HDR_FILL(h) \
|
|
|
|
do { \
|
|
|
|
(h).hdr_padding[0] = 0; \
|
|
|
|
(h).hdr_padding[1] = 0; \
|
|
|
|
} while(0)
|
|
|
|
#else
|
|
|
|
#define MCA_PML_OB1_RDMA_HDR_FILL(h)
|
2009-05-07 00:11:28 +04:00
|
|
|
#endif /* OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG */
|
2009-02-27 08:24:06 +03:00
|
|
|
|
2007-08-29 01:23:44 +04:00
|
|
|
#define MCA_PML_OB1_RDMA_HDR_NTOH(h) \
|
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_COMMON_HDR_NTOH((h).hdr_common); \
|
|
|
|
(h).hdr_seg_cnt = ntohl((h).hdr_seg_cnt); \
|
|
|
|
(h).hdr_rdma_offset = ntoh64((h).hdr_rdma_offset); \
|
2007-08-29 01:23:44 +04:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define MCA_PML_OB1_RDMA_HDR_HTON(h) \
|
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_COMMON_HDR_HTON((h).hdr_common); \
|
|
|
|
MCA_PML_OB1_RDMA_HDR_FILL(h); \
|
|
|
|
(h).hdr_seg_cnt = htonl((h).hdr_seg_cnt); \
|
|
|
|
(h).hdr_rdma_offset = hton64((h).hdr_rdma_offset); \
|
2007-08-29 01:23:44 +04:00
|
|
|
} while (0)
|
|
|
|
|
2005-06-10 00:16:33 +04:00
|
|
|
/**
|
|
|
|
* Header used to complete an RDMA operation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct mca_pml_ob1_fin_hdr_t {
|
|
|
|
mca_pml_ob1_common_hdr_t hdr_common; /**< common attributes */
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2009-04-21 18:41:51 +04:00
|
|
|
uint8_t hdr_padding[2];
|
2006-12-04 23:11:42 +03:00
|
|
|
#endif
|
2007-06-03 12:31:58 +04:00
|
|
|
uint32_t hdr_fail; /**< RDMA operation failed */
|
2009-04-21 18:41:51 +04:00
|
|
|
ompi_ptr_t hdr_des; /**< completed descriptor */
|
2005-06-10 00:16:33 +04:00
|
|
|
};
|
|
|
|
typedef struct mca_pml_ob1_fin_hdr_t mca_pml_ob1_fin_hdr_t;
|
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG
|
2009-02-27 08:24:06 +03:00
|
|
|
#define MCA_PML_OB1_FIN_HDR_FILL(h) \
|
|
|
|
do { \
|
|
|
|
(h).hdr_padding[0] = 0; \
|
|
|
|
(h).hdr_padding[1] = 0; \
|
|
|
|
} while (0)
|
|
|
|
#else
|
|
|
|
#define MCA_PML_OB1_FIN_HDR_FILL(h)
|
2009-05-07 00:11:28 +04:00
|
|
|
#endif /* OPAL_ENABLE_HETEROGENEOUS_SUPPORT && OPAL_ENABLE_DEBUG */
|
2009-02-27 08:24:06 +03:00
|
|
|
|
2006-02-26 03:45:54 +03:00
|
|
|
#define MCA_PML_OB1_FIN_HDR_NTOH(h) \
|
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_COMMON_HDR_NTOH((h).hdr_common); \
|
2006-02-26 03:45:54 +03:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define MCA_PML_OB1_FIN_HDR_HTON(h) \
|
|
|
|
do { \
|
2009-02-27 08:24:06 +03:00
|
|
|
MCA_PML_OB1_COMMON_HDR_HTON((h).hdr_common); \
|
|
|
|
MCA_PML_OB1_FIN_HDR_FILL(h); \
|
2006-02-26 03:45:54 +03:00
|
|
|
} while (0)
|
|
|
|
|
2005-05-24 02:06:50 +04:00
|
|
|
/**
|
|
|
|
* Union of defined hdr types.
|
|
|
|
*/
|
|
|
|
union mca_pml_ob1_hdr_t {
|
|
|
|
mca_pml_ob1_common_hdr_t hdr_common;
|
|
|
|
mca_pml_ob1_match_hdr_t hdr_match;
|
|
|
|
mca_pml_ob1_rendezvous_hdr_t hdr_rndv;
|
2005-08-17 22:23:38 +04:00
|
|
|
mca_pml_ob1_rget_hdr_t hdr_rget;
|
2005-05-24 02:06:50 +04:00
|
|
|
mca_pml_ob1_frag_hdr_t hdr_frag;
|
|
|
|
mca_pml_ob1_ack_hdr_t hdr_ack;
|
2005-06-09 00:37:19 +04:00
|
|
|
mca_pml_ob1_rdma_hdr_t hdr_rdma;
|
2005-06-10 00:16:33 +04:00
|
|
|
mca_pml_ob1_fin_hdr_t hdr_fin;
|
2005-05-24 02:06:50 +04:00
|
|
|
};
|
|
|
|
typedef union mca_pml_ob1_hdr_t mca_pml_ob1_hdr_t;
|
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if !defined(WORDS_BIGENDIAN) && OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2007-12-16 11:45:44 +03:00
|
|
|
static inline __opal_attribute_always_inline__ void
|
|
|
|
ob1_hdr_ntoh(mca_pml_ob1_hdr_t *hdr, const uint8_t hdr_type)
|
|
|
|
{
|
|
|
|
if(!(hdr->hdr_common.hdr_flags & MCA_PML_OB1_HDR_FLAGS_NBO))
|
|
|
|
return;
|
|
|
|
|
|
|
|
switch(hdr_type) {
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_MATCH:
|
|
|
|
MCA_PML_OB1_MATCH_HDR_NTOH(hdr->hdr_match);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_RNDV:
|
|
|
|
MCA_PML_OB1_RNDV_HDR_NTOH(hdr->hdr_rndv);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_RGET:
|
|
|
|
MCA_PML_OB1_RGET_HDR_NTOH(hdr->hdr_rget);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_ACK:
|
|
|
|
MCA_PML_OB1_ACK_HDR_NTOH(hdr->hdr_ack);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_FRAG:
|
|
|
|
MCA_PML_OB1_FRAG_HDR_NTOH(hdr->hdr_frag);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_PUT:
|
|
|
|
MCA_PML_OB1_RDMA_HDR_NTOH(hdr->hdr_rdma);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_FIN:
|
|
|
|
MCA_PML_OB1_FIN_HDR_NTOH(hdr->hdr_fin);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
assert(0);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
#define ob1_hdr_ntoh(h, t) do{}while(0)
|
|
|
|
#endif
|
2005-05-24 02:06:50 +04:00
|
|
|
|
2009-05-07 00:11:28 +04:00
|
|
|
#if OPAL_ENABLE_HETEROGENEOUS_SUPPORT
|
2007-12-16 11:45:44 +03:00
|
|
|
#define ob1_hdr_hton(h, t, p) \
|
|
|
|
ob1_hdr_hton_intr((mca_pml_ob1_hdr_t*)h, t, p)
|
|
|
|
static inline __opal_attribute_always_inline__ void
|
|
|
|
ob1_hdr_hton_intr(mca_pml_ob1_hdr_t *hdr, const uint8_t hdr_type,
|
|
|
|
const ompi_proc_t *proc)
|
|
|
|
{
|
|
|
|
#ifdef WORDS_BIGENDIAN
|
|
|
|
hdr->hdr_common.hdr_flags |= MCA_PML_OB1_HDR_FLAGS_NBO;
|
|
|
|
#else
|
|
|
|
|
2008-04-18 00:43:56 +04:00
|
|
|
if(!(proc->proc_arch & OPAL_ARCH_ISBIGENDIAN))
|
2007-12-16 11:45:44 +03:00
|
|
|
return;
|
|
|
|
|
|
|
|
hdr->hdr_common.hdr_flags |= MCA_PML_OB1_HDR_FLAGS_NBO;
|
|
|
|
switch(hdr_type) {
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_MATCH:
|
|
|
|
MCA_PML_OB1_MATCH_HDR_HTON(hdr->hdr_match);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_RNDV:
|
|
|
|
MCA_PML_OB1_RNDV_HDR_HTON(hdr->hdr_rndv);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_RGET:
|
|
|
|
MCA_PML_OB1_RGET_HDR_HTON(hdr->hdr_rget);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_ACK:
|
|
|
|
MCA_PML_OB1_ACK_HDR_HTON(hdr->hdr_ack);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_FRAG:
|
|
|
|
MCA_PML_OB1_FRAG_HDR_HTON(hdr->hdr_frag);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_PUT:
|
|
|
|
MCA_PML_OB1_RDMA_HDR_HTON(hdr->hdr_rdma);
|
|
|
|
break;
|
|
|
|
case MCA_PML_OB1_HDR_TYPE_FIN:
|
|
|
|
MCA_PML_OB1_FIN_HDR_HTON(hdr->hdr_fin);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
assert(0);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
#define ob1_hdr_hton(h, t, p) do{}while(0)
|
|
|
|
#endif
|
2005-05-24 02:06:50 +04:00
|
|
|
#endif
|