Shared memory access control mechanism for processes created by MPI

后端 未结 2 1912
悲哀的现实
悲哀的现实 2021-01-07 12:20

I have a shared memory used by multiple processes, these processes are created using MPI.

Now I need a mechanism to control the access of this shared me

相关标签:
2条回答
  • 2021-01-07 12:32

    No, MPI doesn't provide any support for shared memory. In fact, MPI would not want to support shared memory. The reason is that a program written with MPI is supposed to scale to a large number of processors, and a large number of processors never have shared memory.

    However, it may happen, and often does, that groups of small number of processors (in that set of large number of processors) do have shared memory. To utilize that shared memory however, OpenMP is used.

    OpenMP is very simple. I strongly suggest you learn it.

    0 讨论(0)
  • 2021-01-07 12:35

    MPI actually does provide support for shared memory now (as of version 3.0). You might try looking at the One-sided communication chapter (http://www.mpi-forum.org/docs/mpi-3.0/mpi30-report.pdf) starting with MPI_WIN_ALLOCATE_SHARED (11.2.3). To use this, you'll have to make sure you have an implementation that supports it. I know that the most recent versions of both MPICH and Open MPI work.

    0 讨论(0)
提交回复
热议问题