2011-08-04 10:15:45 +00:00
|
|
|
/*
|
|
|
|
* 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-2006 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2011 NVIDIA Corporation. All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef OMPI_MCA_COMMON_CUDA_H
|
|
|
|
#define OMPI_MCA_COMMON_CUDA_H
|
2011-12-29 12:31:54 +00:00
|
|
|
#include "ompi/mca/btl/btl.h"
|
|
|
|
|
2012-02-22 23:32:36 +00:00
|
|
|
#define MEMHANDLE_SIZE 8
|
|
|
|
#define EVTHANDLE_SIZE 8
|
|
|
|
struct mca_mpool_common_cuda_reg_t {
|
2011-12-29 12:31:54 +00:00
|
|
|
mca_mpool_base_registration_t base;
|
2012-02-22 23:32:36 +00:00
|
|
|
uint64_t memHandle[MEMHANDLE_SIZE];
|
|
|
|
uint64_t evtHandle[EVTHANDLE_SIZE];
|
2011-12-29 12:31:54 +00:00
|
|
|
uint64_t event;
|
|
|
|
};
|
2012-02-22 23:32:36 +00:00
|
|
|
typedef struct mca_mpool_common_cuda_reg_t mca_mpool_common_cuda_reg_t;
|
2011-12-29 12:31:54 +00:00
|
|
|
|
2013-03-27 21:09:41 +00:00
|
|
|
OMPI_DECLSPEC int mca_common_cuda_register_mca_variables(void);
|
|
|
|
|
2011-08-04 10:15:45 +00:00
|
|
|
OMPI_DECLSPEC void mca_common_cuda_register(void *ptr, size_t amount, char *msg);
|
|
|
|
|
|
|
|
OMPI_DECLSPEC void mca_common_cuda_unregister(void *ptr, char *msg);
|
|
|
|
|
2012-02-22 23:32:36 +00:00
|
|
|
OMPI_DECLSPEC void mca_common_wait_stream_synchronize(mca_mpool_common_cuda_reg_t *rget_reg);
|
2011-12-29 12:31:54 +00:00
|
|
|
|
|
|
|
OMPI_DECLSPEC int mca_common_cuda_memcpy(void *dst, void *src, size_t amount, char *msg,
|
|
|
|
struct mca_btl_base_descriptor_t *, int *done);
|
|
|
|
|
2012-06-15 16:56:30 +00:00
|
|
|
OMPI_DECLSPEC int mca_common_cuda_record_ipc_event(char *msg,
|
|
|
|
struct mca_btl_base_descriptor_t *frag);
|
|
|
|
OMPI_DECLSPEC int mca_common_cuda_record_dtoh_event(char *msg,
|
|
|
|
struct mca_btl_base_descriptor_t *frag);
|
|
|
|
OMPI_DECLSPEC int mca_common_cuda_record_htod_event(char *msg,
|
|
|
|
struct mca_btl_base_descriptor_t *frag);
|
|
|
|
|
|
|
|
OMPI_DECLSPEC void *mca_common_cuda_get_dtoh_stream(void);
|
|
|
|
OMPI_DECLSPEC void *mca_common_cuda_get_htod_stream(void);
|
|
|
|
|
|
|
|
OMPI_DECLSPEC int progress_one_cuda_ipc_event(struct mca_btl_base_descriptor_t **);
|
|
|
|
OMPI_DECLSPEC int progress_one_cuda_dtoh_event(struct mca_btl_base_descriptor_t **);
|
|
|
|
OMPI_DECLSPEC int progress_one_cuda_htod_event(struct mca_btl_base_descriptor_t **);
|
2011-12-29 12:31:54 +00:00
|
|
|
|
2012-02-22 23:32:36 +00:00
|
|
|
OMPI_DECLSPEC int mca_common_cuda_memhandle_matches(mca_mpool_common_cuda_reg_t *new_reg,
|
|
|
|
mca_mpool_common_cuda_reg_t *old_reg);
|
2011-12-29 12:31:54 +00:00
|
|
|
|
|
|
|
OMPI_DECLSPEC void mca_common_cuda_construct_event_and_handle(uint64_t **event, void **handle);
|
|
|
|
OMPI_DECLSPEC void mca_common_cuda_destruct_event(uint64_t *event);
|
|
|
|
|
|
|
|
OMPI_DECLSPEC int cuda_getmemhandle(void *base, size_t, mca_mpool_base_registration_t *newreg,
|
|
|
|
mca_mpool_base_registration_t *hdrreg);
|
|
|
|
OMPI_DECLSPEC int cuda_ungetmemhandle(void *reg_data, mca_mpool_base_registration_t *reg);
|
|
|
|
OMPI_DECLSPEC int cuda_openmemhandle(void *base, size_t size, mca_mpool_base_registration_t *newreg,
|
|
|
|
mca_mpool_base_registration_t *hdrreg);
|
|
|
|
OMPI_DECLSPEC int cuda_closememhandle(void *reg_data, mca_mpool_base_registration_t *reg);
|
|
|
|
|
|
|
|
|
2011-08-04 10:15:45 +00:00
|
|
|
#endif /* OMPI_MCA_COMMON_CUDA_H */
|