RFR (S) 8078438: Interpreter should support conditional card marks (UseCondCardMark)
Andrew Haley
aph at redhat.com
Tue Apr 28 15:03:29 UTC 2015
On 04/28/2015 02:28 PM, Mikael Gerdin wrote:
>
> On 2015-04-28 15:13, Andrew Haley wrote:
>> On 04/28/2015 02:06 PM, Mikael Gerdin wrote:
>>>
>>> On 2015-04-28 14:45, Andrew Haley wrote:
>>>> On 04/28/2015 11:56 AM, Thomas Schatzl wrote:
>>>>> Somewhat related, note that C2 adds a MemBarRelease before the actual
>>>>> card table store (see StoreCMNode) I think to ensure store ordering (the
>>>>> card mark must be visible after the reference write). So the given
>>>>> aarch64 code seems to be missing something already.
>>>>
>>>> I don't think it's missing anything. It has the barrier in the correct
>>>> place when G1 is in use, and CMS isn't supposed to need one.
>>>
>>> I think it does depend on StoreStore ordering, the field write must be
>>> visible if the dirty card byte is visible.
>>
>> Hmm. We were told otherwise here before. Does the code which scans
>> the card table use a load barrier after each read of the card? If not
>> the StoreStore won't have any effect anyway.
>
> Consider the following sequence of events:
> Mutator: CMS-preclean:
> # o.x == NULL
> o.x = a
> card[o >> 9] = 0x0 finds card[o >> 9] == 0x0
> reads o.x, finds NULL
> writes card[o >> 9] = 0x1
> # o.x == a becomes visible
>
> CMS-remark occurs, o.x is not scanned because card[o >> 9] == 0x1 which
> is not dirty.
I see.
> There's no load barrier in the card scanning code that I'm aware of.
In which case the store barrier won't have any effect. I see your
point, but there really is no point fixing only one end of this bug.
If this ordering matters there really has to be a barrier after
reading the card.
Thanks,
Andrew.
More information about the hotspot-gc-dev
mailing list