17#ifndef __STARPU_MPI_PRIVATE_H__
18#define __STARPU_MPI_PRIVATE_H__
21#include <common/config.h>
23#include <starpu_mpi.h>
38extern starpu_pthread_wait_t _starpu_mpi_thread_wait;
39extern starpu_pthread_queue_t _starpu_mpi_thread_dontsleep;
45 starpu_pthread_queue_t *queue;
49int _starpu_mpi_simgrid_mpi_test(
unsigned *done,
int *flag);
50void _starpu_mpi_simgrid_wait_req(MPI_Request *request, MPI_Status *status, starpu_pthread_queue_t *queue,
unsigned *done);
53struct _starpu_mpi_req* _starpu_mpi_isend_cache_aware(starpu_data_handle_t
data_handle,
int dest, starpu_mpi_tag_t data_tag, MPI_Comm comm,
unsigned detached,
unsigned sync,
int prio,
void (*callback)(
void *),
void *_arg,
int sequential_consistency,
int* cache_flag);
54struct _starpu_mpi_req* _starpu_mpi_irecv_cache_aware(starpu_data_handle_t
data_handle,
int source, starpu_mpi_tag_t data_tag, MPI_Comm comm,
unsigned detached,
unsigned sync,
void (*callback)(
void *),
void *_arg,
int sequential_consistency,
int is_internal_req, starpu_ssize_t count,
int* cache_flag);
56extern int _starpu_debug_rank;
57char *_starpu_mpi_get_mpi_error_code(
int code);
58extern int _starpu_mpi_comm_debug;
60#ifdef STARPU_MPI_VERBOSE
61extern int _starpu_debug_level_min;
62extern int _starpu_debug_level_max;
63void _starpu_mpi_set_debug_level_min(
int level);
64void _starpu_mpi_set_debug_level_max(
int level);
66extern int _starpu_mpi_fake_world_size;
67extern int _starpu_mpi_fake_world_rank;
68extern int _starpu_mpi_use_prio;
69extern int _starpu_mpi_nobind;
70extern int _starpu_mpi_thread_cpuid;
71extern int _starpu_mpi_thread_multiple_send;
72extern int _starpu_mpi_use_coop_sends;
73extern int _starpu_mpi_mem_throttle;
74extern int _starpu_mpi_recv_wait_finalize;
75extern int _starpu_mpi_has_cuda;
76extern int _starpu_mpi_cuda_devid;
77void _starpu_mpi_env_init(
void);
79#ifdef STARPU_NO_ASSERT
80# define STARPU_MPI_ASSERT_MSG(x, msg, ...) do { if (0) { (void) (x); }} while(0)
82# if defined(__CUDACC__) && defined(STARPU_HAVE_WINDOWS)
83int _starpu_debug_rank;
84# define STARPU_MPI_ASSERT_MSG(x, msg, ...) \
87 if (STARPU_UNLIKELY(!(x))) \
89 if (_starpu_debug_rank == -1) starpu_mpi_comm_rank(MPI_COMM_WORLD, &_starpu_debug_rank); \
90 fprintf(stderr, "\n[%d][starpu_mpi][%s][assert failure] " msg "\n\n", _starpu_debug_rank, __starpu_func__, ## __VA_ARGS__); *(int*)NULL = 0; \
94# define STARPU_MPI_ASSERT_MSG(x, msg, ...) \
97 if (STARPU_UNLIKELY(!(x))) \
99 if (_starpu_debug_rank == -1) starpu_mpi_comm_rank(MPI_COMM_WORLD, &_starpu_debug_rank); \
100 fprintf(stderr, "\n[%d][starpu_mpi][%s][assert failure] " msg "\n\n", _starpu_debug_rank, __starpu_func__, ## __VA_ARGS__); \
108#define _STARPU_MPI_MALLOC(ptr, size) do { ptr = malloc(size); STARPU_MPI_ASSERT_MSG(ptr != NULL, "Cannot allocate %ld bytes\n", (long) (size)); } while (0)
109#define _STARPU_MPI_CALLOC(ptr, nmemb, size) do { ptr = calloc(nmemb, size); STARPU_MPI_ASSERT_MSG(ptr != NULL, "Cannot allocate %ld bytes\n", (long) (nmemb*size)); } while (0)
110#define _STARPU_MPI_REALLOC(ptr, size) do { void *_new_ptr = realloc(ptr, size); STARPU_MPI_ASSERT_MSG(_new_ptr != NULL, "Cannot reallocate %ld bytes\n", (long) (size)); ptr = _new_ptr; } while (0)
112#ifdef STARPU_MPI_VERBOSE
113# define _STARPU_MPI_COMM_DEBUG(ptr, count, datatype, node, tag, utag, comm, way) \
116 if (_starpu_mpi_comm_debug) \
119 char _comm_name[128]; \
120 int _comm_name_len; \
122 starpu_mpi_comm_rank(comm, &_rank); \
123 MPI_Type_size(datatype, &__size); \
124 MPI_Comm_get_name(comm, _comm_name, &_comm_name_len); \
125 fprintf(stderr, "[%d][starpu_mpi] :%d:%s:%d:%d:%ld:%s:%p:%ld:%d:%s:%d\n", _rank, _rank, way, node, tag, utag, _comm_name, ptr, count, __size, __starpu_func__ , __LINE__); \
129# define _STARPU_MPI_COMM_TO_DEBUG(ptr, count, datatype, dest, tag, utag, comm) _STARPU_MPI_COMM_DEBUG(ptr, count, datatype, dest, tag, utag, comm, "-->")
130# define _STARPU_MPI_COMM_FROM_DEBUG(ptr, count, datatype, source, tag, utag, comm) _STARPU_MPI_COMM_DEBUG(ptr, count, datatype, source, tag, utag, comm, "<--")
131# define _STARPU_MPI_DEBUG(level, fmt, ...) \
134 if (!_starpu_silent && _starpu_debug_level_min <= level && level <= _starpu_debug_level_max) \
136 if (_starpu_debug_rank == -1) starpu_mpi_comm_rank(MPI_COMM_WORLD, &_starpu_debug_rank); \
137 fprintf(stderr, "%*s[%d][starpu_mpi][%s:%d] " fmt , (_starpu_debug_rank+1)*4, "", _starpu_debug_rank, __starpu_func__ , __LINE__,## __VA_ARGS__); \
142# define _STARPU_MPI_COMM_DEBUG(ptr, count, datatype, node, tag, utag, comm, way) do { } while(0)
143# define _STARPU_MPI_COMM_TO_DEBUG(ptr, count, datatype, dest, tag, utag, comm) do { } while(0)
144# define _STARPU_MPI_COMM_FROM_DEBUG(ptr, count, datatype, source, tag, utag, comm) do { } while(0)
145# define _STARPU_MPI_DEBUG(level, fmt, ...) do { } while(0)
148#define _STARPU_MPI_DISP(fmt, ...) do { if (!_starpu_silent) { \
149 if (_starpu_debug_rank == -1) starpu_mpi_comm_rank(MPI_COMM_WORLD, &_starpu_debug_rank); \
150 fprintf(stderr, "%*s[%d][starpu_mpi][%s:%d] " fmt , (_starpu_debug_rank+1)*4, "", _starpu_debug_rank, __starpu_func__ , __LINE__ ,## __VA_ARGS__); \
151 fflush(stderr); }} while(0)
152#define _STARPU_MPI_MSG(fmt, ...) do { if (_starpu_debug_rank == -1) starpu_mpi_comm_rank(MPI_COMM_WORLD, &_starpu_debug_rank); \
153 fprintf(stderr, "[%d][starpu_mpi][%s:%d] " fmt , _starpu_debug_rank, __starpu_func__ , __LINE__ ,## __VA_ARGS__); \
154 fflush(stderr); } while(0)
156#ifdef STARPU_MPI_EXTRA_VERBOSE
157# define _STARPU_MPI_LOG_IN() do { if (!_starpu_silent) { \
158 if (_starpu_debug_rank == -1) starpu_mpi_comm_rank(MPI_COMM_WORLD, &_starpu_debug_rank); \
159 fprintf(stderr, "%*s[%d][starpu_mpi][%s:%d] -->\n", (_starpu_debug_rank+1)*4, "", _starpu_debug_rank, __starpu_func__ , __LINE__); \
160 fflush(stderr); }} while(0)
161# define _STARPU_MPI_LOG_OUT() do { if (!_starpu_silent) { \
162 if (_starpu_debug_rank == -1) starpu_mpi_comm_rank(MPI_COMM_WORLD, &_starpu_debug_rank); \
163 fprintf(stderr, "%*s[%d][starpu_mpi][%s:%d] <--\n", (_starpu_debug_rank+1)*4, "", _starpu_debug_rank, __starpu_func__, __LINE__); \
164 fflush(stderr); }} while(0)
166# define _STARPU_MPI_LOG_IN()
167# define _STARPU_MPI_LOG_OUT()
170enum _starpu_mpi_request_type
190 starpu_mpi_tag_t data_tag;
197 starpu_data_handle_t data_handle;
200 struct _starpu_mpi_req_multilist_coop_sends reqs;
207 unsigned redirects_sent;
219 unsigned int cache_received;
220 unsigned int ft_induced_cache_received:1;
221 unsigned int ft_induced_cache_received_count:1;
222 unsigned int modified:1;
238struct _starpu_mpi_data *_starpu_mpi_data_get(starpu_data_handle_t data_handle);
253 starpu_ssize_t count;
254 int registered_datatype;
263 struct _starpu_mpi_req_multilist_coop_sends coop_sends;
284 void (*callback)(
void *);
286 int sequential_consistency;
289 long post_sync_jobid;
292 MPI_Status status_store;
293 starpu_pthread_queue_t queue;
308void _starpu_mpi_isend_irecv_common(
struct _starpu_mpi_req *req,
enum starpu_data_access_mode mode,
int sequential_consistency);
330void _starpu_mpi_redux_fill_post_sync_jobid(
const void *
const redux_data_args,
long *
const post_sync_jobid);
334 int srcdst, starpu_mpi_tag_t data_tag, MPI_Comm comm,
335 unsigned detached,
unsigned sync,
int prio,
void (*callback)(
void *),
void *arg,
337 int sequential_consistency,
339 starpu_ssize_t count);
343char *_starpu_mpi_request_type(
enum _starpu_mpi_request_type
request_type);
345struct _starpu_mpi_req *_starpu_mpi_irecv_common(starpu_data_handle_t
data_handle,
int source, starpu_mpi_tag_t data_tag, MPI_Comm comm,
unsigned detached,
unsigned sync,
void (*callback)(
void *),
void *arg,
int sequential_consistency,
int is_internal_req, starpu_ssize_t count,
int prio);
347int _starpu_mpi_choose_node(starpu_data_handle_t
data_handle,
enum starpu_data_access_mode mode);
349void _starpu_mpi_data_flush(starpu_data_handle_t
data_handle);
373 void (*_starpu_mpi_backend_init)(
struct starpu_conf *conf);
374 void (*_starpu_mpi_backend_shutdown)(void);
375 int (*_starpu_mpi_backend_reserve_core)(void);
377 void (*_starpu_mpi_backend_request_fill)(
struct _starpu_mpi_req *req,
int is_internal_req);
378 void (*_starpu_mpi_backend_request_destroy)(
struct _starpu_mpi_req *req);
379 void (*_starpu_mpi_backend_data_clear)(starpu_data_handle_t
data_handle);
380 void (*_starpu_mpi_backend_data_register)(starpu_data_handle_t
data_handle, starpu_mpi_tag_t data_tag);
381 void (*_starpu_mpi_backend_comm_register)(MPI_Comm comm);
384 void (*_starpu_mpi_backend_progress_shutdown)(
void **value);
386 void (*_starpu_mpi_backend_wait_for_initialization)();
389 int (*_starpu_mpi_backend_barrier)(MPI_Comm comm);
390 int (*_starpu_mpi_backend_wait_for_all)(MPI_Comm comm);
391 int (*_starpu_mpi_backend_wait)(starpu_mpi_req *public_req, MPI_Status *status);
392 int (*_starpu_mpi_backend_test)(starpu_mpi_req *public_req,
int *flag, MPI_Status *status);
394 void (*_starpu_mpi_backend_isend_size_func)(
struct _starpu_mpi_req *req);
395 void (*_starpu_mpi_backend_irecv_size_func)(
struct _starpu_mpi_req *req);
#define struct
Definition: list.h:175
Definition: starpu_mpi_mpi_backend.h:59
void _starpu_mpi_coop_send(starpu_data_handle_t data_handle, struct _starpu_mpi_req *req, enum starpu_data_access_mode mode, int sequential_consistency)
void _starpu_mpi_tags_init(void)
struct _starpu_spinlock coop_lock
Definition: starpu_mpi_private.h:230
char * redux_map
Definition: starpu_mpi_private.h:226
struct _starpu_mpi_coop_sends * coop_sends
Definition: starpu_mpi_private.h:232
char ** fargv
Definition: starpu_mpi_private.h:363
int fargc
Definition: starpu_mpi_private.h:361
unsigned nb_future_sends
Definition: starpu_mpi_private.h:235
void _starpu_mpi_submit_ready_request(void *arg)
void _starpu_mpi_release_req_data(struct _starpu_mpi_req *req)
void _starpu_mpi_submit_coop_sends(struct _starpu_mpi_coop_sends *coop_sends, int submit_control, int submit_data)
Definition: starpu_mpi_private.h:355
Definition: starpu_mpi_private.h:196
Definition: starpu_mpi_private.h:215
Definition: starpu_mpi_private.h:182
Definition: starpu_mpi_private.h:188
Definition: starpu_mpi_private.h:42
Definition: starpu_spinlock.h:82
Definition: starpu_mpi_private.h:372
Definition: starpu_mpi_private.h:242
enum _starpu_mpi_request_type request_type
Definition: starpu_mpi_private.h:275
MPI_Datatype datatype
Definition: starpu_mpi_private.h:250
int detached
Definition: starpu_mpi_private.h:282
size_t reserved_size
Definition: starpu_mpi_private.h:270
starpu_data_handle_t data_handle
Definition: starpu_mpi_private.h:244