starpu_mpi_nmad_backend.h 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2009-2020 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. #ifndef __STARPU_MPI_NMAD_BACKEND_H__
  17. #define __STARPU_MPI_NMAD_BACKEND_H__
  18. #include <common/config.h>
  19. /** @file */
  20. #ifdef __cplusplus
  21. extern "C"
  22. {
  23. #endif
  24. #ifdef STARPU_USE_MPI_NMAD
  25. #include <nm_sendrecv_interface.h>
  26. #include <nm_session_interface.h>
  27. #include <nm_mpi_nmad.h>
  28. struct _starpu_mpi_req_backend
  29. {
  30. nm_gate_t gate;
  31. nm_session_t session;
  32. nm_sr_request_t data_request;
  33. piom_cond_t req_cond;
  34. nm_sr_request_t size_req;
  35. /** When datatype is unknown */
  36. struct nm_data_s unknown_datatype_body;
  37. struct nm_data_s unknown_datatype_data;
  38. struct nm_data_s unknown_datatype_size;
  39. };
  40. #endif // STARPU_USE_MPI_NMAD
  41. #ifdef __cplusplus
  42. }
  43. #endif
  44. #endif // __STARPU_MPI_NMAD_BACKEND_H__