RFC: linux-aarch64 and LSE support
dean.long at oracle.com
dean.long at oracle.com
Thu Sep 22 23:40:42 UTC 2022
On 9/20/22 4:15 AM, Andrew Haley wrote:
> > (I'm also not getting the point about a lack of
> > barrier-ordered-after, but maybe I'm just confused.)
>
> The lack of barrier-ordered-after is why we need a fence after all ops
> for conservative.
>
> (In fact we don't: all Arm hardware in existence works without the
> trailing fence. And probably always will. But the Arm spec allows
> reordering, even though available hardware doesn't. This is annoying,
> but that's life.)
I'm probably missing something too, because I don't understand this
either. If the atomic op has acquire-release semantics, then this part
of the spec seems like it means no fence after is required:
(older spec)
"At least one of RW1 and RW2 is generated by an atomic instruction with
both Acquire and
Release semantics."
(newer spec)
"RW1 is a memory write effect W1 and is generated by an atomic
instruction with both Acquire
and Release semantics." (if the cas succeeded)
"RW1 is a memory read effect R1, except a Tag-Check-read, and is
generated by an instruction
with Acquire or AcquirePC semantics." (if the cas failed)
Also, since "Barrier-ordered-before" describes when RW1 "happened
before" RW2 (or RW2 "happened after" RW1, right?), I don't understand
why an additional "barrier-ordered-after" would be desired.
dl
More information about the hotspot-dev
mailing list