[mpiwg-rma] Inconsistency of MPI_WIN_FENCE semantic
Rajeev Thakur
thakur at mcs.anl.gov
Tue Feb 25 23:36:47 CST 2014
I don't find it confusing. It makes the case where the barrier is not needed even more clear.
In the example below, if the second fence didn't have a NOPRECEDE, even a deferred implementation will need to do a barrier because it doesn't know if the process is a target of RMA operations from other processes.
If NOPRECEDE is called, it must be called on all processes, so then it is clear that no one is doing RMA.
So "in particular" might in fact be better than "for example".
On Feb 25, 2014, at 11:25 PM, "Balaji, Pavan" <balaji at anl.gov>
wrote:
>
> Why do you want that MPI_MODE_NOPRECEDE? What’s its purpose?
>
> — Pavan
>
> On Feb 25, 2014, at 11:24 PM, Rajeev Thakur <thakur at mcs.anl.gov> wrote:
>
>> Instead of "in particular" if it said "for example, a call with assert equal to MPI_MODE_NOPRECEDE" would it help?
>>
>> On Feb 25, 2014, at 11:14 PM, "Balaji, Pavan" <balaji at anl.gov>
>> wrote:
>>
>>>
>>> If that was indeed the intention, then the wording is very unfortunate. I’d recommend not having the mention of MPI_MODE_NOPRECEDE at all. It serves no real purpose and ends up confusing things.
>>>
>>> — Pavan
>>>
>>> On Feb 25, 2014, at 11:09 PM, Rajeev Thakur <thakur at mcs.anl.gov> wrote:
>>>
>>>> It means to say that in the example below, the second fence (which does not end any epoch) does not necessarily act as a barrier. The NOPRECEDE makes it very clear (and hence the "in particular a call with assert=NOPRECEDE") that no RMA calls were issued prior to that fence.
>>>>
>>>> Fence
>>>> x=1
>>>> Fence(NOPRECEDE)
>>>> Put
>>>> Fence
>>>>
>>>> Note that a fence "completes an RMA access epoch if it was preceded by another fence call and the local process issued RMA communication calls on win between these two calls. The call completes an RMA exposure epoch if it was preceded by another fence call and the local window was the target of RMA accesses between these two calls."
>>>>
>>>> So the second fence does not complete any epoch, which the user has made even more clear with the assert, and so it need not be a barrier.
>>>>
>>>>
>>>> On Feb 25, 2014, at 10:58 PM, "Balaji, Pavan" <balaji at anl.gov>
>>>> wrote:
>>>>
>>>>>
>>>>> Then the following sentence in the standard is weird:
>>>>>
>>>>> "a call to MPI_WIN_FENCE that is known not to end any epoch (in particular a call with assert equal to MPI_MODE_NOPRECEDE) does not necessarily act as a barrier”
>>>>>
>>>>> Why this special treatment for NOPRECEDE as no WIN_FENCE has barrier semantics?
>>>>>
>>>>> — Pavan
>>>>>
>>>>> On Feb 25, 2014, at 10:54 PM, Rajeev Thakur <thakur at mcs.anl.gov> wrote:
>>>>>
>>>>>> Agreed that the handshake can't be done in the RMA operation.
>>>>>>
>>>>>> If you choose to implement fence eagerly, i.e., perform RMA ops as they are called, the first fence will have to be a barrier.
>>>>>>
>>>>>> But if you choose to implement the deferred fence, the first fence and all RMA ops can be deferred until the fence that completes the epoch.
>>>>>>
>>>>>>
>>>>>> On Feb 25, 2014, at 10:46 PM, "Zhao, Xin" <xinzhao3 at illinois.edu>
>>>>>> wrote:
>>>>>>
>>>>>>> I agree with this. If the handshake is done in the first RMA operation after the fence, then that operation becomes blocking. In Standard P418 it says all communication calls are non-blocking.
>>>>>>>
>>>>>>> Xin
>>>>>>> ________________________________________
>>>>>>> From: mpiwg-rma [mpiwg-rma-bounces at lists.mpi-forum.org] on behalf of Balaji, Pavan [balaji at anl.gov]
>>>>>>> Sent: Tuesday, February 25, 2014 9:38 PM
>>>>>>> To: MPI WG Remote Memory Access working group
>>>>>>> Subject: Re: [mpiwg-rma] Inconsistency of MPI_WIN_FENCE semantic
>>>>>>>
>>>>>>> In practice, it’ll need to have barrier semantics. Otherwise, PUT will need to be a two-sided operation to ensure that it’s not issued before the other process calls MPI_WIN_FENCE.
>>>>>>>
>>>>>>> — Pavan
>>>>>>>
>>>>>>> On Feb 25, 2014, at 9:21 PM, Rajeev Thakur <thakur at mcs.anl.gov> wrote:
>>>>>>>
>>>>>>>>> (1) On P440-P441 it say that "RMA operations on win started by a process after the fence call returns will access their target window only after MPI_WIN_FENCE has been called by the target process". This requires MPI_WIN_FENCE that starts an epoch to act as an barrier.
>>>>>>>>
>>>>>>>> It only says "RMA operations on win started by a process after the fence call returns will access their target window only after MPI_WIN_FENCE has been called by the target process". NOT "This requires MPI_WIN_FENCE that starts an epoch to act as an barrier."
>>>>>>>>
>>>>>>>> Why does the fence have to act as a barrier. The handshake could be done when first RMA operation is called after the fence.
>>>>>>>>
>>>>>>>> Rajeev
>>>>>>>>
>>>>>>>>
>>>>>>>> On Feb 25, 2014, at 8:41 PM, "Zhao, Xin" <xinzhao3 at illinois.edu> wrote:
>>>>>>>>
>>>>>>>>> Hi all,
>>>>>>>>>
>>>>>>>>> There is an inconsistency of MPI_WIN_FENCE semantic in MPI 3.0 Standard that makes me confused:
>>>>>>>>>
>>>>>>>>> (1) On P440-P441 it say that "RMA operations on win started by a process after the fence call returns will access their target window only after MPI_WIN_FENCE has been called by the target process". This requires MPI_WIN_FENCE that starts an epoch to act as an barrier.
>>>>>>>>>
>>>>>>>>> (2) However, (1) contradict with the word at end of P441: "a call to MPI_WIN_FENCE that is known not to end any epoch (in particular a call with assert equal to MPI_MODE_NOPRECEDE) does not necessarily act as a barrier".
>>>>>>>>>
>>>>>>>>> Should the word of (1) add: "when MPI_MODE_NOPRECEDE is not given"?
>>>>>>>>>
>>>>>>>>> Thanks,
>>>>>>>>>
>>>>>>>>> Xin
>>>>>>>>>
>>>>>>>>> _______________________________________________
>>>>>>>>> mpiwg-rma mailing list
>>>>>>>>> mpiwg-rma at lists.mpi-forum.org
>>>>>>>>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>>>>>>>>
>>>>>>>> _______________________________________________
>>>>>>>> mpiwg-rma mailing list
>>>>>>>> mpiwg-rma at lists.mpi-forum.org
>>>>>>>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>>>>>>>
>>>>>>> _______________________________________________
>>>>>>> mpiwg-rma mailing list
>>>>>>> mpiwg-rma at lists.mpi-forum.org
>>>>>>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>>>>>>> _______________________________________________
>>>>>>> mpiwg-rma mailing list
>>>>>>> mpiwg-rma at lists.mpi-forum.org
>>>>>>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>>>>>>
>>>>>> _______________________________________________
>>>>>> mpiwg-rma mailing list
>>>>>> mpiwg-rma at lists.mpi-forum.org
>>>>>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>>>>>
>>>>> _______________________________________________
>>>>> mpiwg-rma mailing list
>>>>> mpiwg-rma at lists.mpi-forum.org
>>>>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>>>>
>>>> _______________________________________________
>>>> mpiwg-rma mailing list
>>>> mpiwg-rma at lists.mpi-forum.org
>>>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>>>
>>> _______________________________________________
>>> mpiwg-rma mailing list
>>> mpiwg-rma at lists.mpi-forum.org
>>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>>
>> _______________________________________________
>> mpiwg-rma mailing list
>> mpiwg-rma at lists.mpi-forum.org
>> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
>
> _______________________________________________
> mpiwg-rma mailing list
> mpiwg-rma at lists.mpi-forum.org
> http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-rma
More information about the mpiwg-rma
mailing list