dat.h revision 7c478bd95313f5f23a4c958a745db2134aa03244
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright (c) 2002-2004, Network Appliance, Inc. All rights reserved.
*/
/*
* Copyright 2004 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#ifndef _DAT_H_
#define _DAT_H_
#pragma ident "%Z%%M% %I% %E% SMI"
/*
*
* HEADER: dat.h
*
* PURPOSE: defines the common DAT API for uDAPL and kDAPL.
*
* Description: Header file for "uDAPL: User Direct Access Programming
* Library, Version: 1.2"
*
* Mapping rules:
* All global symbols are prepended with "DAT_" or "dat_"
* All DAT objects have an 'api' tag which, such as 'ep' or 'lmr'
* The method table is in the provider definition structure.
*
*
*/
#ifdef __cplusplus
extern "C" {
#endif
#include <dat/dat_error.h>
/* Generic DAT types */
typedef char *DAT_NAME_PTR; /* Format for ia_name and attributes */
#define DAT_NAME_MAX_LENGTH 256
/*
* Used for provider, vendor, transport, hardware specific attributes
* definitions.
*/
typedef struct dat_named_attr {
const char *name; /* Name of attribute */
const char *value; /* Value of attribute */
} DAT_NAMED_ATTR;
typedef enum dat_boolean {
DAT_FALSE = 0,
DAT_TRUE = 1
} DAT_BOOLEAN;
typedef union dat_context {
DAT_PVOID as_ptr;
DAT_UINT64 as_64;
DAT_UVERYLONG as_index;
} DAT_CONTEXT;
typedef DAT_CONTEXT DAT_DTO_COOKIE;
typedef DAT_CONTEXT DAT_RMR_COOKIE;
typedef enum dat_completion_flags {
/* Completes with notification */
DAT_COMPLETION_DEFAULT_FLAG = 0x00,
/* Completions suppressed if successful */
DAT_COMPLETION_SUPPRESS_FLAG = 0x01,
/* Sender controlled notification for recv completion */
DAT_COMPLETION_SOLICITED_WAIT_FLAG = 0x02,
/* Completions with unsignaled notifications */
DAT_COMPLETION_UNSIGNALLED_FLAG = 0x04,
/* Do not start processing until all previous RDMA reads complete. */
DAT_COMPLETION_BARRIER_FENCE_FLAG = 0x08,
/*
* Only valid for uDAPL as EP attribute for Recv Completion flags.
* Waiter unblocking is controlled by Threshold value of dat_evd_wait.
* UNSIGNALLED for RECV not allowed when EP has this attribute
*/
DAT_COMPLETION_EVD_THRESHOLD_FLAG = 0x10
} DAT_COMPLETION_FLAGS;
typedef DAT_UINT32 DAT_TIMEOUT; /* microseconds */
/* timeout = infinity */
#define DAT_TIMEOUT_INFINITE ((DAT_TIMEOUT) ~0)
/* dat handles */
typedef DAT_PVOID DAT_HANDLE;
typedef DAT_HANDLE DAT_CR_HANDLE;
typedef DAT_HANDLE DAT_EP_HANDLE;
typedef DAT_HANDLE DAT_EVD_HANDLE;
typedef DAT_HANDLE DAT_IA_HANDLE;
typedef DAT_HANDLE DAT_LMR_HANDLE;
typedef DAT_HANDLE DAT_PSP_HANDLE;
typedef DAT_HANDLE DAT_PZ_HANDLE;
typedef DAT_HANDLE DAT_RMR_HANDLE;
typedef DAT_HANDLE DAT_RSP_HANDLE;
typedef DAT_HANDLE DAT_SRQ_HANDLE;
/* dat NULL handles */
#define DAT_HANDLE_NULL ((DAT_HANDLE)NULL)
typedef DAT_SOCK_ADDR *DAT_IA_ADDRESS_PTR;
typedef DAT_UINT64 DAT_CONN_QUAL;
typedef DAT_UINT64 DAT_PORT_QUAL;
/* QOS definitions */
typedef enum dat_qos {
DAT_QOS_BEST_EFFORT = 0x00,
DAT_QOS_HIGH_THROUGHPUT = 0x01,
DAT_QOS_LOW_LATENCY = 0x02,
/* not low latency, nor high throughput */
DAT_QOS_ECONOMY = 0x04,
/* both low latency and high throughput */
DAT_QOS_PREMIUM = 0x08
} DAT_QOS;
/*
* FLAGS
*/
typedef enum dat_connect_flags {
DAT_CONNECT_DEFAULT_FLAG = 0x00,
DAT_CONNECT_MULTIPATH_FLAG = 0x01
} DAT_CONNECT_FLAGS;
typedef enum dat_close_flags {
DAT_CLOSE_ABRUPT_FLAG = 0x00,
DAT_CLOSE_GRACEFUL_FLAG = 0x01
} DAT_CLOSE_FLAGS;
#define DAT_CLOSE_DEFAULT DAT_CLOSE_ABRUPT_FLAG
typedef enum dat_evd_flags {
DAT_EVD_SOFTWARE_FLAG = 0x001,
DAT_EVD_CR_FLAG = 0x010,
DAT_EVD_DTO_FLAG = 0x020,
DAT_EVD_CONNECTION_FLAG = 0x040,
DAT_EVD_RMR_BIND_FLAG = 0x080,
DAT_EVD_ASYNC_FLAG = 0x100,
/* DAT events only, no software events */
DAT_EVD_DEFAULT_FLAG = 0x1F0
} DAT_EVD_FLAGS;
typedef enum dat_psp_flags {
DAT_PSP_CONSUMER_FLAG = 0x00, /* Consumer creates an endpoint */
DAT_PSP_PROVIDER_FLAG = 0x01 /* Provider creates an endpoint */
} DAT_PSP_FLAGS;
/*
* Memory Buffers
*
* Both LMR and RMR triplets specify 64-bit addresses in the local host's byte
* order, even when that exceeds the size of a DAT_PVOID for the host
* architecture.
*/
/*
* Both LMR and RMR Triplets specify 64-bit addresses in the local host
* order, even when that exceeds the size of a void pointer for the host
* architecture. The DAT_VADDR type that represents addresses is in the
* native byte-order of the local host. Helper macros that allow Consumers
* to convert DAT_VADDR into various orders that might be useful for
* inclusion of RMR Triplets into a payload of a message follow.
*
* DAT defines the following macros to convert the fields on an RMR Triplet
* to defined byte orders to allow their export by the Consumer over wire
* protocols. DAT does not define how the two peers decide which byte should be
* used.
*
* DAT_LMRC_TO_LSB(lmrc) returns the supplied LMR Context in ls-byte
* order.
* DAT_LMRC_TO_MSB(lmrc) returns the supplied LMR Context in ms-byte
* order.
* DAT_RMRC_TO_LSB(rmrc) returns the supplied RMR Context in ls-byte
* order.
* DAT_RMRC_TO_MSB(rmrc) returns the supplied RMR Context in ms-byte
* order.
* DAT_VADDR_TO_LSB(vaddr) returns the supplied Virtual Address in ls-byte
* order.
* DAT_VADDR_TO_MSB(vaddr) returns the supplied Virtual Address in
* ms-byte order.
* DAT_VLEN_TO_LSB(vlen) returns the supplied length in ls-byte order.
* DAT_VLEN_TO_MSB(vlen) returns the supplied length in ms-byte order.
*
* Consumers are free to use 64-bit or 32-bit arithmetic for local or remote
* memory address and length manipulation in their preferred byte-order. Only
* the LMR and RMR Triplets passed to a Provider as part of a Posted DTO are
* required to be in 64-bit address and local host order formats. Providers
* shall convert RMR_Triplets to a Transport-required wire format.
*
* For the best performance, Consumers should align each buffer segment to
* the boundary specified by the dat_optimal_alignment.
*/
typedef DAT_UINT32 DAT_LMR_CONTEXT;
typedef DAT_UINT32 DAT_RMR_CONTEXT;
typedef DAT_UINT64 DAT_VLEN;
typedef DAT_UINT64 DAT_VADDR;
typedef struct dat_provider_attr DAT_PROVIDER_ATTR;
typedef struct dat_evd_param DAT_EVD_PARAM;
typedef struct dat_lmr_param DAT_LMR_PARAM;
/*
* It is legal for Consumer to specify zero for segment_length
* of the dat_lmr_triplet. When 0 is specified for the
* segment_length then the other two elements of the
* dat_lmr_triplet are irrelevant and can be invalid.
*/
typedef struct dat_lmr_triplet {
DAT_LMR_CONTEXT lmr_context;
DAT_UINT32 pad;
DAT_VADDR virtual_address;
DAT_VLEN segment_length;
} DAT_LMR_TRIPLET;
typedef struct dat_rmr_triplet {
DAT_RMR_CONTEXT rmr_context;
DAT_UINT32 pad;
DAT_VADDR target_address;
DAT_VLEN segment_length;
} DAT_RMR_TRIPLET;
/*
* The extra padding ensures that context, address, and length parameters are
* aligned on 64-bit boundaries.
*/
/* Memory privileges */
typedef enum dat_mem_priv_flags {
DAT_MEM_PRIV_NONE_FLAG = 0x00,
DAT_MEM_PRIV_LOCAL_READ_FLAG = 0x01,
DAT_MEM_PRIV_REMOTE_READ_FLAG = 0x02,
DAT_MEM_PRIV_LOCAL_WRITE_FLAG = 0x10,
DAT_MEM_PRIV_REMOTE_WRITE_FLAG = 0x20,
DAT_MEM_PRIV_ALL_FLAG = 0x33
} DAT_MEM_PRIV_FLAGS;
/*
* For backwards compatibility with DAT-1.0 memory privileges values
* are supported
*/
#define DAT_MEM_PRIV_READ_FLAG (DAT_MEM_PRIV_LOCAL_READ_FLAG | \
DAT_MEM_PRIV_REMOTE_READ_FLAG)
#define DAT_MEM_PRIV_WRITE_FLAG (DAT_MEM_PRIV_LOCAL_WRITE_FLAG | \
DAT_MEM_PRIV_REMOTE_WRITE_FLAG)
/* LMR Arguments Mask */
typedef enum dat_lmr_param_mask {
DAT_LMR_FIELD_IA_HANDLE = 0x001,
DAT_LMR_FIELD_MEM_TYPE = 0x002,
DAT_LMR_FIELD_REGION_DESC = 0x004,
DAT_LMR_FIELD_LENGTH = 0x008,
DAT_LMR_FIELD_PZ_HANDLE = 0x010,
DAT_LMR_FIELD_MEM_PRIV = 0x020,
DAT_LMR_FIELD_LMR_CONTEXT = 0x040,
DAT_LMR_FIELD_RMR_CONTEXT = 0x080,
DAT_LMR_FIELD_REGISTERED_SIZE = 0x100,
DAT_LMR_FIELD_REGISTERED_ADDRESS = 0x200,
DAT_LMR_FIELD_ALL = 0x3FF
} DAT_LMR_PARAM_MASK;
/* RMR Argumments & RMR Arguments Mask */
typedef struct dat_rmr_param {
DAT_IA_HANDLE ia_handle;
DAT_PZ_HANDLE pz_handle;
DAT_LMR_TRIPLET lmr_triplet;
DAT_MEM_PRIV_FLAGS mem_priv;
DAT_RMR_CONTEXT rmr_context;
} DAT_RMR_PARAM;
typedef enum dat_rmr_param_mask {
DAT_RMR_FIELD_IA_HANDLE = 0x01,
DAT_RMR_FIELD_PZ_HANDLE = 0x02,
DAT_RMR_FIELD_LMR_TRIPLET = 0x04,
DAT_RMR_FIELD_MEM_PRIV = 0x08,
DAT_RMR_FIELD_RMR_CONTEXT = 0x10,
DAT_RMR_FIELD_ALL = 0x1F
} DAT_RMR_PARAM_MASK;
/* Provider attributes */
typedef enum dat_iov_ownership {
/* Not modification by provider, consumer can use anytime. */
DAT_IOV_CONSUMER = 0x0,
/* Provider does not modify returned IOV DTO on completion. */
DAT_IOV_PROVIDER_NOMOD = 0x1,
/* Provider may modify IOV DTO on completion, can't trust it. */
DAT_IOV_PROVIDER_MOD = 0x2
} DAT_IOV_OWNERSHIP;
typedef enum dat_ep_creator_for_psp {
DAT_PSP_CREATES_EP_NEVER, /* provider never creates endpoint */
DAT_PSP_CREATES_EP_IFASKED, /* provider creates endpoint if asked */
DAT_PSP_CREATES_EP_ALWAYS /* provider always creates endpoint */
} DAT_EP_CREATOR_FOR_PSP;
/* General Interface Adapter attributes. These apply to both udat and kdat. */
/* To support backwards compatibility for DAPL-1.0 */
#define max_rdma_read_per_ep max_rdma_read_per_ep_in
#define DAT_IA_FIELD_IA_MAX_DTO_PER_OP DAT_IA_FIELD_IA_ MAX_DTO_PER_EP_IN
/* to support backwards compatibility for DAPL-1.0 & DAPL-1.1 */
#define max_mtu_size max_message_size
typedef struct dat_ia_attr
{
char adapter_name[DAT_NAME_MAX_LENGTH];
char vendor_name[DAT_NAME_MAX_LENGTH];
DAT_UINT32 hardware_version_major;
DAT_UINT32 hardware_version_minor;
DAT_UINT32 firmware_version_major;
DAT_UINT32 firmware_version_minor;
DAT_IA_ADDRESS_PTR ia_address_ptr;
DAT_COUNT max_eps;
DAT_COUNT max_dto_per_ep;
DAT_COUNT max_rdma_read_per_ep_in;
DAT_COUNT max_rdma_read_per_ep_out;
DAT_COUNT max_evds;
DAT_COUNT max_evd_qlen;
DAT_COUNT max_iov_segments_per_dto;
DAT_COUNT max_lmrs;
DAT_VLEN max_lmr_block_size;
DAT_VADDR max_lmr_virtual_address;
DAT_COUNT max_pzs;
DAT_VLEN max_message_size;
DAT_VLEN max_rdma_size;
DAT_COUNT max_rmrs;
DAT_VADDR max_rmr_target_address;
DAT_COUNT max_srqs;
DAT_COUNT max_ep_per_srq;
DAT_COUNT max_recv_per_srq;
DAT_COUNT max_iov_segments_per_rdma_read;
DAT_COUNT max_iov_segments_per_rdma_write;
DAT_COUNT max_rdma_read_in;
DAT_COUNT max_rdma_read_out;
DAT_BOOLEAN max_rdma_read_per_ep_in_guaranteed;
DAT_BOOLEAN max_rdma_read_per_ep_out_guaranteed;
DAT_COUNT num_transport_attr;
DAT_NAMED_ATTR *transport_attr;
DAT_COUNT num_vendor_attr;
DAT_NAMED_ATTR *vendor_attr;
} DAT_IA_ATTR;
/* To support backwards compatibility for DAPL-1.0 & DAPL-1.1 */
#define DAT_IA_FIELD_IA_MAX_MTU_SIZE DAT_IA_FIELD_IA_MAX_MESSAGE_SIZE
typedef DAT_UINT64 DAT_IA_ATTR_MASK;
#define DAT_IA_FIELD_IA_ADAPTER_NAME UINT64_C(0x000000001)
#define DAT_IA_FIELD_IA_VENDOR_NAME UINT64_C(0x000000002)
#define DAT_IA_FIELD_IA_HARDWARE_MAJOR_VERSION UINT64_C(0x000000004)
#define DAT_IA_FIELD_IA_HARDWARE_MINOR_VERSION UINT64_C(0x000000008)
#define DAT_IA_FIELD_IA_FIRMWARE_MAJOR_VERSION UINT64_C(0x000000010)
#define DAT_IA_FIELD_IA_FIRMWARE_MINOR_VERSION UINT64_C(0x000000020)
#define DAT_IA_FIELD_IA_ADDRESS_PTR UINT64_C(0x000000040)
#define DAT_IA_FIELD_IA_MAX_EPS UINT64_C(0x000000080)
#define DAT_IA_FIELD_IA_MAX_DTO_PER_EP UINT64_C(0x000000100)
#define DAT_IA_FIELD_IA_MAX_RDMA_READ_PER_EP_IN UINT64_C(0x000000200)
#define DAT_IA_FIELD_IA_MAX_RDMA_READ_PER_EP_OUT UINT64_C(0x000000400)
#define DAT_IA_FIELD_IA_MAX_EVDS UINT64_C(0x000000800)
#define DAT_IA_FIELD_IA_MAX_EVD_QLEN UINT64_C(0x000001000)
#define DAT_IA_FIELD_IA_MAX_IOV_SEGMENTS_PER_DTO UINT64_C(0x000002000)
#define DAT_IA_FIELD_IA_MAX_LMRS UINT64_C(0x000004000)
#define DAT_IA_FIELD_IA_MAX_LMR_BLOCK_SIZE UINT64_C(0x000008000)
#define DAT_IA_FIELD_IA_MAX_LMR_VIRTUAL_ADDRESS UINT64_C(0x000010000)
#define DAT_IA_FIELD_IA_MAX_PZS UINT64_C(0x000020000)
#define DAT_IA_FIELD_IA_MAX_MESSAGE_SIZE UINT64_C(0x000040000)
#define DAT_IA_FIELD_IA_MAX_RDMA_SIZE UINT64_C(0x000080000)
#define DAT_IA_FIELD_IA_MAX_RMRS UINT64_C(0x000100000)
#define DAT_IA_FIELD_IA_MAX_RMR_TARGET_ADDRESS UINT64_C(0x000200000)
#define DAT_IA_FIELD_IA_MAX_SRQS UINT64_C(0x000400000)
#define DAT_IA_FIELD_IA_MAX_EP_PER_SRQ UINT64_C(0x000800000)
#define DAT_IA_FIELD_IA_MAX_RECV_PER_SRQ UINT64_C(0x001000000)
#define DAT_IA_FIELD_IA_MAX_IOV_SEGMENTS_PER_RDMA_READ UINT64_C(0x002000000)
#define DAT_IA_FIELD_IA_MAX_IOV_SEGMENTS_PER_RDMA_WRITE UINT64_C(0x004000000)
#define DAT_IA_FIELD_IA_MAX_RDMA_READ_IN UINT64_C(0x008000000)
#define DAT_IA_FIELD_IA_MAX_RDMA_READ_OUT UINT64_C(0x010000000)
#define DAT_IA_FIELD_IA_MAX_RDMA_READ_PER_EP_IN_GUARANTEED \
UINT64_C(0x020000000)
#define DAT_IA_FIELD_IA_MAX_RDMA_READ_PER_EP_OUT_GUARANTEED \
UINT64_C(0x040000000)
#define DAT_IA_FIELD_IA_NUM_TRANSPORT_ATTR UINT64_C(0x080000000)
#define DAT_IA_FIELD_IA_TRANSPORT_ATTR UINT64_C(0x100000000)
#define DAT_IA_FIELD_IA_NUM_VENDOR_ATTR UINT64_C(0x200000000)
#define DAT_IA_FIELD_IA_VENDOR_ATTR UINT64_C(0x400000000)
/* To support backwards compatibility for DAPL-1.0 & DAPL-1.1 */
#define DAT_IA_ALL DAT_IA_FIELD_ALL
#define DAT_IA_FIELD_ALL UINT64_C(0x7FFFFFFFF)
#define DAT_IA_FIELD_NONE UINT64_C(0x0)
/* Endpoint attributes */
typedef enum dat_service_type {
DAT_SERVICE_TYPE_RC /* reliable connections */
} DAT_SERVICE_TYPE;
typedef struct dat_ep_attr {
DAT_SERVICE_TYPE service_type;
DAT_VLEN max_message_size;
DAT_VLEN max_rdma_size;
DAT_QOS qos;
DAT_COMPLETION_FLAGS recv_completion_flags;
DAT_COMPLETION_FLAGS request_completion_flags;
DAT_COUNT max_recv_dtos;
DAT_COUNT max_request_dtos;
DAT_COUNT max_recv_iov;
DAT_COUNT max_request_iov;
DAT_COUNT max_rdma_read_in;
DAT_COUNT max_rdma_read_out;
DAT_COUNT srq_soft_hw;
DAT_COUNT max_rdma_read_iov;
DAT_COUNT max_rdma_write_iov;
DAT_COUNT ep_transport_specific_count;
DAT_NAMED_ATTR * ep_transport_specific;
DAT_COUNT ep_provider_specific_count;
DAT_NAMED_ATTR * ep_provider_specific;
} DAT_EP_ATTR;
/* Endpoint Parameters */
/* For backwards compatability */
#define DAT_EP_STATE_ERROR DAT_EP_STATE_DISCONNECTED
typedef enum dat_ep_state {
DAT_EP_STATE_UNCONNECTED, /* quiescent state */
DAT_EP_STATE_UNCONFIGURED_UNCONNECTED,
DAT_EP_STATE_RESERVED,
DAT_EP_STATE_UNCONFIGURED_RESERVED,
DAT_EP_STATE_PASSIVE_CONNECTION_PENDING,
DAT_EP_STATE_UNCONFIGURED_PASSIVE,
DAT_EP_STATE_ACTIVE_CONNECTION_PENDING,
DAT_EP_STATE_TENTATIVE_CONNECTION_PENDING,
DAT_EP_STATE_UNCONFIGURED_TENTATIVE,
DAT_EP_STATE_CONNECTED,
DAT_EP_STATE_DISCONNECT_PENDING,
DAT_EP_STATE_DISCONNECTED,
DAT_EP_STATE_COMPLETION_PENDING
} DAT_EP_STATE;
typedef struct dat_ep_param {
DAT_IA_HANDLE ia_handle;
DAT_EP_STATE ep_state;
DAT_IA_ADDRESS_PTR local_ia_address_ptr;
DAT_PORT_QUAL local_port_qual;
DAT_IA_ADDRESS_PTR remote_ia_address_ptr;
DAT_PORT_QUAL remote_port_qual;
DAT_PZ_HANDLE pz_handle;
DAT_EVD_HANDLE recv_evd_handle;
DAT_EVD_HANDLE request_evd_handle;
DAT_EVD_HANDLE connect_evd_handle;
DAT_SRQ_HANDLE srq_handle;
DAT_EP_ATTR ep_attr;
} DAT_EP_PARAM;
typedef DAT_UINT64 DAT_EP_PARAM_MASK;
#define DAT_EP_FIELD_IA_HANDLE UINT64_C(0x00000001)
#define DAT_EP_FIELD_EP_STATE UINT64_C(0x00000002)
#define DAT_EP_FIELD_LOCAL_IA_ADDRESS_PTR UINT64_C(0x00000004)
#define DAT_EP_FIELD_LOCAL_PORT_QUAL UINT64_C(0x00000008)
#define DAT_EP_FIELD_REMOTE_IA_ADDRESS_PTR UINT64_C(0x00000010)
#define DAT_EP_FIELD_REMOTE_PORT_QUAL UINT64_C(0x00000020)
#define DAT_EP_FIELD_PZ_HANDLE UINT64_C(0x00000040)
#define DAT_EP_FIELD_RECV_EVD_HANDLE UINT64_C(0x00000080)
#define DAT_EP_FIELD_REQUEST_EVD_HANDLE UINT64_C(0x00000100)
#define DAT_EP_FIELD_CONNECT_EVD_HANDLE UINT64_C(0x00000200)
#define DAT_EP_FIELD_SRQ_HANDLE UINT64_C(0x00000400)
/* Remainder of values from EP_ATTR, 0x00001000 and up */
#define DAT_EP_FIELD_EP_ATTR_SERVICE_TYPE UINT64_C(0x00001000)
#define DAT_EP_FIELD_EP_ATTR_MAX_MESSAGE_SIZE UINT64_C(0x00002000)
#define DAT_EP_FIELD_EP_ATTR_MAX_RDMA_SIZE UINT64_C(0x00004000)
#define DAT_EP_FIELD_EP_ATTR_QOS UINT64_C(0x00008000)
#define DAT_EP_FIELD_EP_ATTR_RECV_COMPLETION_FLAGS UINT64_C(0x00010000)
#define DAT_EP_FIELD_EP_ATTR_REQUEST_COMPLETION_FLAGS UINT64_C(0x00020000)
#define DAT_EP_FIELD_EP_ATTR_MAX_RECV_DTOS UINT64_C(0x00040000)
#define DAT_EP_FIELD_EP_ATTR_MAX_REQUEST_DTOS UINT64_C(0x00080000)
#define DAT_EP_FIELD_EP_ATTR_MAX_RECV_IOV UINT64_C(0x00100000)
#define DAT_EP_FIELD_EP_ATTR_MAX_REQUEST_IOV UINT64_C(0x00200000)
#define DAT_EP_FIELD_EP_ATTR_MAX_RDMA_READ_IN UINT64_C(0x00400000)
#define DAT_EP_FIELD_EP_ATTR_MAX_RDMA_READ_OUT UINT64_C(0x00800000)
#define DAT_EP_FIELD_EP_ATTR_SRQ_SOFT_HW UINT64_C(0x01000000)
#define DAT_EP_FIELD_EP_ATTR_MAX_RDMA_READ_IOV UINT64_C(0x02000000)
#define DAT_EP_FIELD_EP_ATTR_MAX_RDMA_WRITE_IOV UINT64_C(0x04000000)
#define DAT_EP_FIELD_EP_ATTR_NUM_TRANSPORT_ATTR UINT64_C(0x08000000)
#define DAT_EP_FIELD_EP_ATTR_TRANSPORT_SPECIFIC_ATTR UINT64_C(0x10000000)
#define DAT_EP_FIELD_EP_ATTR_NUM_PROVIDER_ATTR UINT64_C(0x20000000)
#define DAT_EP_FIELD_EP_ATTR_PROVIDER_SPECIFIC_ATTR UINT64_C(0x40000000)
#define DAT_EP_FIELD_EP_ATTR_ALL UINT64_C(0x7FFFF000)
#define DAT_EP_FIELD_ALL UINT64_C(0x7FFFF7FF)
#define DAT_WATERMARK_INFINITE ((DAT_COUNT)~0)
#define DAT_HW_DEFAULT DAT_WATERMARK_INFINITE
#define DAT_SRQ_LW_DEFAULT 0x0
typedef enum dat_srq_state {
DAT_SRQ_STATE_OPERATIONAL,
DAT_SRQ_STATE_ERROR
} DAT_SRQ_STATE;
#define DAT_VALUE_UNKNOWN (((DAT_COUNT) ~0)-1)
typedef struct dat_srq_attr {
DAT_COUNT max_recv_dtos;
DAT_COUNT max_recv_iov;
DAT_COUNT low_watermark;
} DAT_SRQ_ATTR;
typedef struct dat_srq_param {
DAT_IA_HANDLE ia_handle;
DAT_SRQ_STATE srq_state;
DAT_PZ_HANDLE pz_handle;
DAT_COUNT max_recv_dtos;
DAT_COUNT max_recv_iov;
DAT_COUNT low_watermark;
DAT_COUNT available_dto_count;
DAT_COUNT outstanding_dto_count;
} DAT_SRQ_PARAM;
typedef enum dat_srq_param_mask {
DAT_SRQ_FIELD_IA_HANDLE = 0x001,
DAT_SRQ_FIELD_SRQ_STATE = 0x002,
DAT_SRQ_FIELD_PZ_HANDLE = 0x004,
DAT_SRQ_FIELD_MAX_RECV_DTO = 0x008,
DAT_SRQ_FIELD_MAX_RECV_IOV = 0x010,
DAT_SRQ_FIELD_LOW_WATERMARK = 0x020,
DAT_SRQ_FIELD_AVAILABLE_DTO_COUNT = 0x040,
DAT_SRQ_FIELD_OUTSTANDING_DTO_COUNT = 0x080,
DAT_SRQ_FIELD_ALL = 0x0FF
} DAT_SRQ_PARAM_MASK;
/* PZ Parameters */
typedef struct dat_pz_param {
DAT_IA_HANDLE ia_handle;
} DAT_PZ_PARAM;
typedef enum dat_pz_param_mask {
DAT_PZ_FIELD_IA_HANDLE = 0x01,
DAT_PZ_FIELD_ALL = 0x01
} DAT_PZ_PARAM_MASK;
/* PSP Parameters */
typedef struct dat_psp_param {
DAT_IA_HANDLE ia_handle;
DAT_CONN_QUAL conn_qual;
DAT_EVD_HANDLE evd_handle;
DAT_PSP_FLAGS psp_flags;
} DAT_PSP_PARAM;
typedef enum dat_psp_param_mask {
DAT_PSP_FIELD_IA_HANDLE = 0x01,
DAT_PSP_FIELD_CONN_QUAL = 0x02,
DAT_PSP_FIELD_EVD_HANDLE = 0x04,
DAT_PSP_FIELD_PSP_FLAGS = 0x08,
DAT_PSP_FIELD_ALL = 0x0F
} DAT_PSP_PARAM_MASK;
/* RSP Parameters */
typedef struct dat_rsp_param {
DAT_IA_HANDLE ia_handle;
DAT_CONN_QUAL conn_qual;
DAT_EVD_HANDLE evd_handle;
DAT_EP_HANDLE ep_handle;
} DAT_RSP_PARAM;
typedef enum dat_rsp_param_mask {
DAT_RSP_FIELD_IA_HANDLE = 0x01,
DAT_RSP_FIELD_CONN_QUAL = 0x02,
DAT_RSP_FIELD_EVD_HANDLE = 0x04,
DAT_RSP_FIELD_EP_HANDLE = 0x08,
DAT_RSP_FIELD_ALL = 0x0F
} DAT_RSP_PARAM_MASK;
/*
* Connection Request Parameters.
*
* The Connection Request does not provide Remote Endpoint attributes.
* If a local Consumer needs this information, the remote Consumer should
* encode it into Private Data.
*/
typedef struct dat_cr_param {
/* Remote IA whose Endpoint requested the connection. */
DAT_IA_ADDRESS_PTR remote_ia_address_ptr;
/* Port qualifier of the remote Endpoint of the requested connection. */
DAT_PORT_QUAL remote_port_qual;
/* Size of the Private Data. */
DAT_COUNT private_data_size;
/*
* Pointer to the Private Data passed by remote side in the Connection
* Request.
*/
DAT_PVOID private_data;
/*
* The local Endpoint provided by the Service Point for the requested
* connection. It is the only Endpoint that can accept a Connection
* Request on this Service Point. The value DAT_HANDLE_NULL represents
* that there is no associated local Endpoint for the requested
* connection.
*/
DAT_EP_HANDLE local_ep_handle;
} DAT_CR_PARAM;
typedef enum dat_cr_param_mask {
DAT_CR_FIELD_REMOTE_IA_ADDRESS_PTR = 0x01,
DAT_CR_FIELD_REMOTE_PORT_QUAL = 0x02,
DAT_CR_FIELD_PRIVATE_DATA_SIZE = 0x04,
DAT_CR_FIELD_PRIVATE_DATA = 0x08,
DAT_CR_FIELD_LOCAL_EP_HANDLE = 0x10,
DAT_CR_FIELD_ALL = 0x1F
} DAT_CR_PARAM_MASK;
/*
* *********************** Events *****************************************
*/
/* Completion status flags */
/* dto completion status */
/* For backwards compatability */
#define DAT_DTO_LENGTH_ERROR DAT_DTO_ERR_LOCAL_LENGTH
#define DAT_DTO_FAILURE DAT_DTO_ERR_FLUSHED
typedef enum dat_dto_completion_status {
DAT_DTO_SUCCESS = 0,
DAT_DTO_ERR_FLUSHED = 1,
DAT_DTO_ERR_LOCAL_LENGTH = 2,
DAT_DTO_ERR_LOCAL_EP = 3,
DAT_DTO_ERR_LOCAL_PROTECTION = 4,
DAT_DTO_ERR_BAD_RESPONSE = 5,
DAT_DTO_ERR_REMOTE_ACCESS = 6,
DAT_DTO_ERR_REMOTE_RESPONDER = 7,
DAT_DTO_ERR_TRANSPORT = 8,
DAT_DTO_ERR_RECEIVER_NOT_READY = 9,
DAT_DTO_ERR_PARTIAL_PACKET = 10,
DAT_RMR_OPERATION_FAILED = 11
} DAT_DTO_COMPLETION_STATUS;
/* RMR completion status */
/* For backwards compatability */
#define DAT_RMR_BIND_SUCCESS DAT_DTO_SUCCESS
#define DAT_RMR_BIND_FAILURE DAT_DTO_ERR_FLUSHED
#define DAT_RMR_BIND_COMPLETION_STATUS DAT_DTO_COMPLETION_STATUS
/* Completion group structs (six total) */
/* DTO completion event data */
/* transferred_length is not defined if status is not DAT_SUCCESS */
typedef struct dat_dto_completion_event_data {
DAT_EP_HANDLE ep_handle;
DAT_DTO_COOKIE user_cookie;
DAT_DTO_COMPLETION_STATUS status;
DAT_VLEN transfered_length;
} DAT_DTO_COMPLETION_EVENT_DATA;
/* RMR bind completion event data */
typedef struct dat_rmr_bind_completion_event_data {
DAT_RMR_HANDLE rmr_handle;
DAT_RMR_COOKIE user_cookie;
DAT_RMR_BIND_COMPLETION_STATUS status;
} DAT_RMR_BIND_COMPLETION_EVENT_DATA;
typedef union dat_sp_handle {
DAT_RSP_HANDLE rsp_handle;
DAT_PSP_HANDLE psp_handle;
} DAT_SP_HANDLE;
/* Connection Request Arrival event data */
typedef struct dat_cr_arrival_event_data {
/*
* Handle to the Service Point that received the Connection Request
* from the remote side. If the Service Point was Reserved, sp is
* DAT_HANDLE_NULL because the reserved Service Point is automatically
* destroyed upon generating this event. Can be PSP or RSP.
*/
DAT_SP_HANDLE sp_handle;
/* Address of the IA on which the Connection Request arrived. */
DAT_IA_ADDRESS_PTR local_ia_address_ptr;
/*
* Connection Qualifier of the IA on which the Service Point received a
* Connection Request.
*/
DAT_CONN_QUAL conn_qual;
/*
* The Connection Request instance created by a Provider for the
* arrived Connection Request. Consumers can find out private_data
* passed by a remote Consumer from cr_handle. It is up to a Consumer
* to dat_cr_accept or dat_cr_reject of the Connection Request.
*/
DAT_CR_HANDLE cr_handle;
} DAT_CR_ARRIVAL_EVENT_DATA;
/* Connection event data */
typedef struct dat_connection_event_data {
DAT_EP_HANDLE ep_handle;
DAT_COUNT private_data_size;
DAT_PVOID private_data;
} DAT_CONNECTION_EVENT_DATA;
/* Async Error event data */
/*
* For unaffiliated asynchronous event dat_handle is ia_handle. For Endpoint
* affiliated asynchronous event dat_handle is ep_handle. For EVD affiliated
* asynchronous event dat_handle is evd_handle. For SRQ affiliated asynchronous
* event dat_handle is srq_handle. For Memory affiliated asynchronous event
* dat_handle is either lmr_handle, rmr_handle or pz_handle.
*/
typedef struct dat_asynch_error_event_data {
DAT_HANDLE dat_handle; /* either IA, EP, EVD, SRQ */
/* LMR, RMR, or PZ handle */
DAT_COUNT reason; /* object specific */
} DAT_ASYNCH_ERROR_EVENT_DATA;
/* The reason is object type specific and its values are defined below */
typedef enum ia_async_error_reason {
DAT_IA_CATASTROPHIC_ERROR,
DAT_IA_OTHER_ERROR
} DAT_IA_ASYNC_ERROR_REASON;
typedef enum ep_async_error_reason {
DAT_EP_TRANSFER_TO_ERROR,
DAT_EP_OTHER_ERROR,
DAT_SRQ_SOFT_HIGH_WATERMARK_EVENT
} DAT_EP_ASYNC_ERROR_REASON;
typedef enum ep_evd_error_reason {
DAT_EVD_OVERFLOW_ERROR,
DAT_EVD_OTHER_ERROR
} DAT_EVD_ASYNC_ERROR_REASON;
typedef enum ep_srq_error_reason {
DAT_SRQ_TRANSFER_TO_ERROR,
DAT_SRQ_OTHER_ERROR,
DAT_SRQ_LOW_WATERMARK_EVENT
} DAT_SRQ_ASYNC_ERROR_REASON;
typedef enum lmr_async_error_reason {
DAT_LMR_OTHER_ERROR
} DAT_LMR_ASYNC_ERROR_REASON;
typedef enum rmr_async_error_reason {
DAT_RMR_OTHER_ERROR
} DAT_RMR_ASYNC_ERROR_REASON;
typedef enum pz_async_error_reason {
DAT_PZ_OTHER_ERROR
} DAT_PZ_ASYNC_ERROR_REASON;
/* Software event data */
typedef struct dat_software_event_data {
DAT_PVOID pointer;
} DAT_SOFTWARE_EVENT_DATA;
typedef enum dat_event_number {
DAT_DTO_COMPLETION_EVENT = 0x00001,
DAT_RMR_BIND_COMPLETION_EVENT = 0x01001,
DAT_CONNECTION_REQUEST_EVENT = 0x02001,
DAT_CONNECTION_EVENT_ESTABLISHED = 0x04001,
DAT_CONNECTION_EVENT_PEER_REJECTED = 0x04002,
DAT_CONNECTION_EVENT_NON_PEER_REJECTED = 0x04003,
DAT_CONNECTION_EVENT_ACCEPT_COMPLETION_ERROR = 0x04004,
DAT_CONNECTION_EVENT_DISCONNECTED = 0x04005,
DAT_CONNECTION_EVENT_BROKEN = 0x04006,
DAT_CONNECTION_EVENT_TIMED_OUT = 0x04007,
DAT_CONNECTION_EVENT_UNREACHABLE = 0x04008,
DAT_ASYNC_ERROR_EVD_OVERFLOW = 0x08001,
DAT_ASYNC_ERROR_IA_CATASTROPHIC = 0x08002,
DAT_ASYNC_ERROR_EP_BROKEN = 0x08003,
DAT_ASYNC_ERROR_TIMED_OUT = 0x08004,
DAT_ASYNC_ERROR_PROVIDER_INTERNAL_ERROR = 0x08005,
DAT_SOFTWARE_EVENT = 0x10001
} DAT_EVENT_NUMBER;
/* Union for event Data */
typedef union dat_event_data {
DAT_DTO_COMPLETION_EVENT_DATA dto_completion_event_data;
DAT_RMR_BIND_COMPLETION_EVENT_DATA rmr_completion_event_data;
DAT_CR_ARRIVAL_EVENT_DATA cr_arrival_event_data;
DAT_CONNECTION_EVENT_DATA connect_event_data;
DAT_ASYNCH_ERROR_EVENT_DATA asynch_error_event_data;
DAT_SOFTWARE_EVENT_DATA software_event_data;
} DAT_EVENT_DATA;
/* Event struct that holds all event information */
typedef struct dat_event {
DAT_EVENT_NUMBER event_number;
DAT_EVD_HANDLE evd_handle;
DAT_EVENT_DATA event_data;
} DAT_EVENT;
/* Provider/registration info */
typedef struct dat_provider_info {
char ia_name[DAT_NAME_MAX_LENGTH];
DAT_UINT32 dapl_version_major;
DAT_UINT32 dapl_version_minor;
DAT_BOOLEAN is_thread_safe;
} DAT_PROVIDER_INFO;
/*
* FUNCTION PROTOTYPES
*/
/*
* IA functions
*
* Note that there are actual 'dat_ia_open' and 'dat_ia_close'
* functions, it is not just a re-directing #define. That is
* because the functions may have to ensure that the provider
* library is loaded before it can call it, and may choose to
* unload the library after the last close.
*/
extern DAT_RETURN dat_ia_openv(
IN const DAT_NAME_PTR, /* provider */
IN DAT_COUNT, /* asynch_evd_min_qlen */
INOUT DAT_EVD_HANDLE *, /* asynch_evd_handle */
OUT DAT_IA_HANDLE *, /* ia_handle */
IN DAT_UINT32, /* dat major version number */
IN DAT_UINT32, /* dat minor version number */
IN DAT_BOOLEAN); /* dat thread safety */
#define dat_ia_open(name, qlen, async_evd, ia) \
dat_ia_openv((name), (qlen), (async_evd), (ia), \
DAT_VERSION_MAJOR, DAT_VERSION_MINOR, \
DAT_THREADSAFE)
extern DAT_RETURN dat_ia_query(
IN DAT_IA_HANDLE, /* ia handle */
OUT DAT_EVD_HANDLE *, /* async_evd_handle */
IN DAT_IA_ATTR_MASK, /* ia_attr_mask */
OUT DAT_IA_ATTR *, /* ia_attr */
IN DAT_PROVIDER_ATTR_MASK, /* provider_attr_mask */
OUT DAT_PROVIDER_ATTR *); /* provider_attr */
extern DAT_RETURN dat_ia_close(
IN DAT_IA_HANDLE, /* ia_handle */
IN DAT_CLOSE_FLAGS); /* close_flags */
/* helper functions */
extern DAT_RETURN dat_set_consumer_context(
IN DAT_HANDLE, /* dat handle */
IN DAT_CONTEXT); /* context */
extern DAT_RETURN dat_get_consumer_context(
IN DAT_HANDLE, /* dat handle */
OUT DAT_CONTEXT *); /* context */
extern DAT_RETURN dat_get_handle_type(
IN DAT_HANDLE, /* dat_handle */
OUT DAT_HANDLE_TYPE *); /* handle_type */
/* CR Functions */
extern DAT_RETURN dat_cr_query(
IN DAT_CR_HANDLE, /* cr_handle */
IN DAT_CR_PARAM_MASK, /* cr_param_mask */
OUT DAT_CR_PARAM *); /* cr_param */
extern DAT_RETURN dat_cr_accept(
IN DAT_CR_HANDLE, /* cr_handle */
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_COUNT, /* private_data_size */
IN const DAT_PVOID); /* private_data */
extern DAT_RETURN dat_cr_reject(
IN DAT_CR_HANDLE);
/*
* For DAT-1.1 and above, this function is defined for both uDAPL and kDAPL.
* For DAT-1.0 it was only defined for uDAPL.
*/
extern DAT_RETURN dat_cr_handoff(
IN DAT_CR_HANDLE, /* cr_handle */
IN DAT_CONN_QUAL); /* handoff */
/* EVD Functions */
extern DAT_RETURN dat_evd_resize(
IN DAT_EVD_HANDLE, /* evd_handle */
IN DAT_COUNT); /* evd_min_qlen */
extern DAT_RETURN dat_evd_post_se(
IN DAT_EVD_HANDLE, /* evd_handle */
IN const DAT_EVENT *); /* event */
extern DAT_RETURN dat_evd_dequeue(
IN DAT_EVD_HANDLE, /* evd_handle */
OUT DAT_EVENT *); /* event */
extern DAT_RETURN dat_evd_query(
IN DAT_EVD_HANDLE, /* evd_handle */
IN DAT_EVD_PARAM_MASK, /* evd_param_mask */
OUT DAT_EVD_PARAM *); /* evd_param */
extern DAT_RETURN dat_evd_free(
IN DAT_EVD_HANDLE); /* evd_handle */
/* EP functions */
extern DAT_RETURN dat_ep_create(
IN DAT_IA_HANDLE, /* ia_handle */
IN DAT_PZ_HANDLE, /* pz_handle */
IN DAT_EVD_HANDLE, /* recv_completion_evd_handle */
IN DAT_EVD_HANDLE, /* request_completion_evd_handle */
IN DAT_EVD_HANDLE, /* connect_evd_handle */
IN const DAT_EP_ATTR *, /* ep_attributes */
OUT DAT_EP_HANDLE *); /* ep_handle */
extern DAT_RETURN dat_ep_query(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_EP_PARAM_MASK, /* ep_param_mask */
OUT DAT_EP_PARAM *); /* ep_param */
extern DAT_RETURN dat_ep_modify(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_EP_PARAM_MASK, /* ep_param_mask */
IN const DAT_EP_PARAM *); /* ep_param */
extern DAT_RETURN dat_ep_connect(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_IA_ADDRESS_PTR, /* remote_ia_address */
IN DAT_CONN_QUAL, /* remote_conn_qual */
IN DAT_TIMEOUT, /* timeout */
IN DAT_COUNT, /* private_data_size */
IN const DAT_PVOID, /* private_data */
IN DAT_QOS, /* quality_of_service */
IN DAT_CONNECT_FLAGS); /* connect_flags */
extern DAT_RETURN dat_ep_dup_connect(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_EP_HANDLE, /* ep_dup_handle */
IN DAT_TIMEOUT, /* timeout */
IN DAT_COUNT, /* private_data_size */
IN const DAT_PVOID, /* private_data */
IN DAT_QOS); /* quality_of_service */
extern DAT_RETURN dat_ep_disconnect(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_CLOSE_FLAGS); /* close_flags */
extern DAT_RETURN dat_ep_post_send(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_COUNT, /* num_segments */
IN DAT_LMR_TRIPLET *, /* local_iov */
IN DAT_DTO_COOKIE, /* user_cookie */
IN DAT_COMPLETION_FLAGS); /* completion_flags */
extern DAT_RETURN dat_ep_post_recv(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_COUNT, /* num_segments */
IN DAT_LMR_TRIPLET *, /* local_iov */
IN DAT_DTO_COOKIE, /* user_cookie */
IN DAT_COMPLETION_FLAGS); /* completion_flags */
extern DAT_RETURN dat_ep_post_rdma_read(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_COUNT, /* num_segments */
IN DAT_LMR_TRIPLET *, /* local_iov */
IN DAT_DTO_COOKIE, /* user_cookie */
IN const DAT_RMR_TRIPLET *, /* remote_iov */
IN DAT_COMPLETION_FLAGS); /* completion_flags */
extern DAT_RETURN dat_ep_post_rdma_write(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_COUNT, /* num_segments */
IN DAT_LMR_TRIPLET *, /* local_iov */
IN DAT_DTO_COOKIE, /* user_cookie */
IN const DAT_RMR_TRIPLET *, /* remote_iov */
IN DAT_COMPLETION_FLAGS); /* completion_flags */
extern DAT_RETURN dat_ep_get_status(
IN DAT_EP_HANDLE, /* ep_handle */
OUT DAT_EP_STATE *, /* ep_state */
OUT DAT_BOOLEAN *, /* recv_idle */
OUT DAT_BOOLEAN *); /* request_idle */
extern DAT_RETURN dat_ep_free(
IN DAT_EP_HANDLE); /* ep_handle */
extern DAT_RETURN dat_ep_reset(
IN DAT_EP_HANDLE); /* ep_handle */
/* LMR functions */
extern DAT_RETURN dat_lmr_query(
IN DAT_LMR_HANDLE, /* lmr_handle */
IN DAT_LMR_PARAM_MASK, /* lmr_param_mask */
OUT DAT_LMR_PARAM *); /* lmr_param */
extern DAT_RETURN dat_lmr_free(
IN DAT_LMR_HANDLE); /* lmr_handle */
/* Non-coherent memory functions */
extern DAT_RETURN dat_lmr_sync_rdma_read(
IN DAT_IA_HANDLE, /* ia_handle */
IN const DAT_LMR_TRIPLET *, /* local_segments */
IN DAT_VLEN); /* num_segments */
extern DAT_RETURN dat_lmr_sync_rdma_write(
IN DAT_IA_HANDLE, /* ia_handle */
IN const DAT_LMR_TRIPLET *, /* local_segments */
IN DAT_VLEN); /* num_segments */
/* RMR Functions */
extern DAT_RETURN dat_rmr_create(
IN DAT_PZ_HANDLE, /* pz_handle */
OUT DAT_RMR_HANDLE *); /* rmr_handle */
extern DAT_RETURN dat_rmr_query(
IN DAT_RMR_HANDLE, /* rmr_handle */
IN DAT_RMR_PARAM_MASK, /* rmr_param_mask */
OUT DAT_RMR_PARAM *); /* rmr_param */
extern DAT_RETURN dat_rmr_bind(
IN DAT_RMR_HANDLE, /* rmr_handle */
IN const DAT_LMR_TRIPLET *, /* lmr_triplet */
IN DAT_MEM_PRIV_FLAGS, /* mem_priv */
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_RMR_COOKIE, /* user_cookie */
IN DAT_COMPLETION_FLAGS, /* completion_flags */
OUT DAT_RMR_CONTEXT *); /* context */
extern DAT_RETURN dat_rmr_free(
IN DAT_RMR_HANDLE); /* rmr_handle */
/* PSP Functions */
extern DAT_RETURN dat_psp_create(
IN DAT_IA_HANDLE, /* ia_handle */
IN DAT_CONN_QUAL, /* conn_qual */
IN DAT_EVD_HANDLE, /* evd_handle */
IN DAT_PSP_FLAGS, /* psp_flags */
OUT DAT_PSP_HANDLE *); /* psp_handle */
extern DAT_RETURN dat_psp_create_any(
IN DAT_IA_HANDLE, /* ia_handle */
OUT DAT_CONN_QUAL *, /* conn_qual */
IN DAT_EVD_HANDLE, /* evd_handle */
IN DAT_PSP_FLAGS, /* psp_flags */
OUT DAT_PSP_HANDLE *); /* psp_handle */
extern DAT_RETURN dat_psp_query(
IN DAT_PSP_HANDLE, /* psp_handle */
IN DAT_PSP_PARAM_MASK, /* psp_param_mask */
OUT DAT_PSP_PARAM *); /* psp_param */
extern DAT_RETURN dat_psp_free(
IN DAT_PSP_HANDLE); /* psp_handle */
/* RSP Functions */
extern DAT_RETURN dat_rsp_create(
IN DAT_IA_HANDLE, /* ia_handle */
IN DAT_CONN_QUAL, /* conn_qual */
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_EVD_HANDLE, /* evd_handle */
OUT DAT_RSP_HANDLE *); /* rsp_handle */
extern DAT_RETURN dat_rsp_query(
IN DAT_RSP_HANDLE, /* rsp_handle */
IN DAT_RSP_PARAM_MASK, /* rsp_param_mask */
OUT DAT_RSP_PARAM *); /* rsp_param */
extern DAT_RETURN dat_rsp_free(
IN DAT_RSP_HANDLE); /* rsp_handle */
/* PZ Functions */
extern DAT_RETURN dat_pz_create(
IN DAT_IA_HANDLE, /* ia_handle */
OUT DAT_PZ_HANDLE *); /* pz_handle */
extern DAT_RETURN dat_pz_query(
IN DAT_PZ_HANDLE, /* pz_handle */
IN DAT_PZ_PARAM_MASK, /* pz_param_mask */
OUT DAT_PZ_PARAM *); /* pz_param */
extern DAT_RETURN dat_pz_free(
IN DAT_PZ_HANDLE); /* pz_handle */
/*
* SRQ functions
*/
extern DAT_RETURN dat_ep_create_with_srq(
IN DAT_IA_HANDLE, /* ia_handle */
IN DAT_PZ_HANDLE, /* pz_handle */
IN DAT_EVD_HANDLE, /* recv_evd_handle */
IN DAT_EVD_HANDLE, /* request_evd_handle */
IN DAT_EVD_HANDLE, /* connect_evd_handle */
IN DAT_SRQ_HANDLE, /* srq_handle */
IN const DAT_EP_ATTR *, /* ep_attributes */
OUT DAT_EP_HANDLE *); /* ep_handle */
extern DAT_RETURN dat_ep_recv_query(
IN DAT_EP_HANDLE, /* ep_handle */
OUT DAT_COUNT *, /* nbufs_allocated */
OUT DAT_COUNT *); /* bufs_alloc_span */
extern DAT_RETURN dat_ep_set_watermark(
IN DAT_EP_HANDLE, /* ep_handle */
IN DAT_COUNT, /* soft_high_watermark */
IN DAT_COUNT); /* hard_high_watermark */
extern DAT_RETURN dat_srq_create(
IN DAT_IA_HANDLE, /* ia_handle */
IN DAT_PZ_HANDLE, /* pz_handle */
IN DAT_SRQ_ATTR *, /* srq_attr */
OUT DAT_SRQ_HANDLE *); /* srq_handle */
extern DAT_RETURN dat_srq_free(
IN DAT_SRQ_HANDLE); /* srq_handle */
extern DAT_RETURN dat_srq_post_recv(
IN DAT_SRQ_HANDLE, /* srq_handle */
IN DAT_COUNT, /* num_segments */
IN DAT_LMR_TRIPLET *, /* local_iov */
IN DAT_DTO_COOKIE); /* user_cookie */
extern DAT_RETURN dat_srq_query(
IN DAT_SRQ_HANDLE, /* srq_handle */
IN DAT_SRQ_PARAM_MASK, /* srq_param_mask */
OUT DAT_SRQ_PARAM *); /* srq_param */
extern DAT_RETURN dat_srq_resize(
IN DAT_SRQ_HANDLE, /* srq_handle */
IN DAT_COUNT); /* srq_max_recv_dto */
extern DAT_RETURN dat_srq_set_lw(
IN DAT_SRQ_HANDLE, /* srq_handle */
IN DAT_COUNT); /* low_watermark */
/*
* DAT registry functions.
*
* Note the dat_ia_open and dat_ia_close functions are linked to
* registration code which "redirects" to the appropriate provider.
*/
extern DAT_RETURN dat_registry_list_providers(
IN DAT_COUNT, /* max_to_return */
OUT DAT_COUNT *, /* entries_returned */
/* dat_provider_list */
OUT DAT_PROVIDER_INFO *(dat_provider_list[]));
/*
* DAT error functions.
*/
extern DAT_RETURN dat_strerror(
IN DAT_RETURN, /* dat function return */
OUT const char **, /* major message string */
OUT const char **); /* minor message string */
#ifdef __cplusplus
}
#endif
#endif /* _DAT_H_ */