/**
* Copyright (C) Mellanox Technologies Ltd. 2018-2019. ALL RIGHTS RESERVED.
* See file LICENSE for terms.
*/
#ifndef UCT_CUDA_IPC_EP_H
#define UCT_CUDA_IPC_EP_H
#include <uct/api/uct.h>
#include <uct/base/uct_iface.h>
#include <ucs/type/class.h>
#include "cuda_ipc_md.h"
#include "cuda_ipc_cache.h"
typedef struct uct_cuda_ipc_ep_addr {
int ep_id;
} uct_cuda_ipc_ep_addr_t;
typedef struct uct_cuda_ipc_ep {
uct_base_ep_t super;
uct_cuda_ipc_cache_t *remote_memh_cache;
} uct_cuda_ipc_ep_t;
UCS_CLASS_DECLARE_NEW_FUNC(uct_cuda_ipc_ep_t, uct_ep_t, const uct_ep_params_t *);
UCS_CLASS_DECLARE_DELETE_FUNC(uct_cuda_ipc_ep_t, uct_ep_t);
ucs_status_t uct_cuda_ipc_ep_get_zcopy(uct_ep_h tl_ep,
const uct_iov_t *iov, size_t iovcnt,
uint64_t remote_addr, uct_rkey_t rkey,
uct_completion_t *comp);
ucs_status_t uct_cuda_ipc_ep_put_zcopy(uct_ep_h tl_ep,
const uct_iov_t *iov, size_t iovcnt,
uint64_t remote_addr, uct_rkey_t rkey,
uct_completion_t *comp);
#endif