RFR (S): 8033380: Experimental VM flag to enforce access atomicity
Dean Long
dean.long at oracle.com
Wed Feb 12 13:24:10 PST 2014
I don't see a _require_atomic_access field in StoreD/LoadD that could be
checked, so I guess
all platforms are currently guaranteeing volatile double access even
when it is not required.
dl
On 2/12/2014 12:29 AM, Aleksey Shipilev wrote:
> Thanks Dean!
>
> The study of the compiler code, and the generated assembly, and the
> empirical tests seems to indicate double accesses are atomic by
> construction.
>
> Either way, we mark the C2 Store/Load nodes to require atomic access.
> Should there be platform which ignores that flag for doubles, that would
> mean volatile double access atomicity is broken there as well. This
> makes the ground for the VM fix, not the additional work for the
> experimental feature.
>
> -Aleksey.
>
> On 02/12/2014 01:08 AM, Dean Long wrote:
>> It looks to me that C2 will only look at the atomic flag for longs, not
>> doubles, so if you need
>> atomic access to doubles, I think more work needs to be done.
>>
>> dl
>>
>> On 2/11/2014 3:02 AM, Aleksey Shipilev wrote:
>>> Hi,
>>>
>>> I understand we are still closed for integration?
>>>
>>> Please review this small feature meanwhile:
>>> https://bugs.openjdk.java.net/browse/JDK-8033380
>>> http://cr.openjdk.java.net/~shade/8033380/webrev.02/
>>>
>>> TL;DR: JMM 9 may need to extend the access atomicity over longs and
>>> doubles. Luckily, our logic in emitting the relevant access-atomic
>>> instructions is decoupled from memory barriers logic, and so we can
>>> "just" unconditionally go through needs_atomic_access where appropriate.
>>>
>>> Testing:
>>> - full cycle JPRT
>>> - targeted microbenchmarks on x86/ARM/PPC
>>>
>>> Thanks,
>>> -Aleksey
More information about the hotspot-compiler-dev
mailing list