StarPU Internal Handbook
starpu_mpi_nmad.h
Go to the documentation of this file.
1/* StarPU --- Runtime system for heterogeneous multicore architectures.
2 *
3 * Copyright (C) 2020-2021 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
4 *
5 * StarPU is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU Lesser General Public License as published by
7 * the Free Software Foundation; either version 2.1 of the License, or (at
8 * your option) any later version.
9 *
10 * StarPU is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 *
14 * See the GNU Lesser General Public License in COPYING.LGPL for more details.
15 */
16
17#ifndef __STARPU_MPI_NMAD_H__
18#define __STARPU_MPI_NMAD_H__
19
20#include <starpu.h>
21#include <stdlib.h>
22#include <mpi.h>
23#include <common/config.h>
24#include <common/list.h>
25
28#ifdef STARPU_USE_MPI_NMAD
29
30#ifdef __cplusplus
31extern "C"
32{
33#endif
34
35int _starpu_mpi_progress_init(struct _starpu_mpi_argc_argv *argc_argv);
36void _starpu_mpi_progress_shutdown(void **value);
37
38//#ifdef STARPU_SIMGRID
39//void _starpu_mpi_wait_for_initialization();
40//#endif
41
42int _starpu_mpi_barrier(MPI_Comm comm);
43int _starpu_mpi_wait_for_all(MPI_Comm comm);
44int _starpu_mpi_wait(starpu_mpi_req *public_req, MPI_Status *status);
45int _starpu_mpi_test(starpu_mpi_req *public_req, int *flag, MPI_Status *status);
46
47void _starpu_mpi_isend_func(struct _starpu_mpi_req *req);
48void _starpu_mpi_irecv_func(struct _starpu_mpi_req *req);
49void _starpu_mpi_handle_request_termination(struct _starpu_mpi_req *req);
50void _starpu_mpi_handle_pending_request(struct _starpu_mpi_req *req);
51void _starpu_mpi_handle_received_data(struct _starpu_mpi_req* req);
52
53#ifdef __cplusplus
54}
55#endif
56
57#endif /* STARPU_USE_MPI_NMAD */
58#endif /* __STARPU_MPI_NMAD_H__ */
Definition: starpu_mpi_private.h:354
Definition: starpu_mpi_private.h:241