[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <0c309dd3-f8c1-4945-b8f1-154b2a775216@huaweicloud.com>
Date: Tue, 21 May 2024 11:57:29 +0200
From: Jonas Oberhauser <jonas.oberhauser@...weicloud.com>
To: Alan Stern <stern@...land.harvard.edu>,
Hernan Ponce de Leon <hernan.poncedeleon@...weicloud.com>
Cc: "Paul E. McKenney" <paulmck@...nel.org>, linux-kernel@...r.kernel.org,
linux-arch@...r.kernel.org, kernel-team@...a.com, parri.andrea@...il.com,
boqun.feng@...il.com, j.alglave@....ac.uk, luc.maranget@...ia.fr,
Joel Fernandes <joel@...lfernandes.org>
Subject: Re: LKMM: Making RMW barriers explicit
Am 5/18/2024 um 2:31 AM schrieb Alan Stern:
> On Thu, May 16, 2024 at 10:44:05AM +0200, Hernan Ponce de Leon wrote:
>> On 5/16/2024 10:31 AM, Jonas Oberhauser wrote:
>>>
>>>
>>> Am 5/16/2024 um 3:43 AM schrieb Alan Stern:
>>>> Hernan and Jonas:
>>>>
>>>> Can you explain more fully the changes you want to make to herd7 and/or
>>>> the LKMM? The goal is to make the memory barriers currently implicit in
>>>> RMW operations explicit, but I couldn't understand how you propose to do
>>>> this.
>>>>
>>>> Are you going to change herd7 somehow, and if so, how? It seems like
>>>> you should want to provide sufficient information so that the .bell
>>>> and .cat files can implement the appropriate memory barriers associated
>>>> with each RMW operation. What additional information is needed? And
>>>> how (explained in English, not by quoting source code) will the .bell
>>>> and .cat files make use of this information?
>>>>
>>>> Alan
>>>
>>>
>>> I don't know whether herd7 needs to be changed. Probably, herd7 does the
>>> following:
>>> - if a tag called Mb appears on an rmw instruction (by instruction I
>>> mean things like xchg(), atomic_inc_return_relaxed()), replace it with
>>> one of those things:
>>> * full mb ; once (the rmw) ; full mb, if a value returning
>>> (successful) rmw
>>> * once (the rmw) otherwise
>>> - everything else gets translated 1:1 into some internal representation
>>
>> This is my understanding from reading the source code of CSem.ml in herd7's
>> repo.
>>
>> Also, this is exactly what dartagnan is currently doing.
>>
>>>
>>> What I'm proposing is:
>>> 1. remove this transpilation step,
>>> 2. and instead allow the Mb tag to actually appear on RMW instructions
>>> 3. change the cat file to explicitly define the behavior of the Mb tag
>>> on RMW instructions
>>
>> These are the exact 3 things I changed in dartagnan for testing what Jonas
>> proposed.
>>
>> I am not sure if further changes are needed for herd7.
>
> Okay, good. This answers the first part of what I asked. What about
> the second part? That is, how will the changes to the .def, .bell, and
> .cat files achieve your goals?
>
> Alan
Firstly, we'd allow 'mb as a barrier mode in events, e.g.
instructions RMW[{'once,'acquire,'release,'mb}]
then the Mb tags would appear in the graph. And then I'd define the
ordering explicitly. One way is to say that an Mb tag orders all memory
accesses before(or at) the tag with all memory accesses after(or at) the
tag, except the accesses of the rmw with each other.
This is the same as the full fence before the read, which orders all
memory accesses before the read with every access after(or at) the read,
plus the full fence after the write, which orders all memory accesses
before(or at) the write with all accesses after the write.
That would be done by adding
[M] ; (po \ rmw) & (po^?; [RMW_MB] ; po^?) ; [M]
to ppo.
One could also split it into two rules to keep with the "two full
fences" analogy. Maybe a good way would be like this:
[M] ; po; [RMW_MB & R] ; po^? ; [M]
[M] ; po^?; [RMW_MB & W] ; po ; [M]
Hope that makes sense,
jonas
Powered by blists - more mailing lists