RFR: 8079315: UseCondCardMark broken in conjunction with CMS precleaning
Andrew Haley
aph at redhat.com
Tue May 5 15:18:51 UTC 2015
Hi,
On 05/05/2015 04:02 PM, Vitaly Davidovich wrote:
> I realize this is a correctness fix, but isn't this going to possibly
> defeat any perf gain from using conditional card marking in the first place
> (for CMS)?
It shouldn't do. The idea of the UseCondCardMark AIUI is to reduce
thrashing of card table cache lines across cores. StoreLoad, while
possibly slow, should still be a local operation. So it all depends
on what we're trying to optimize: it's still the right thing to use
on a many-core machine, perhaps not for something smaller.
> Didn't someone suggest a different approach that allows
> store-store to be used still?
Mikael wrote:
> For UseCondCardMark to be correct with CMS with precleaning it would
> require a StoreLoad between the field write and the card table load.
>
> Another approach to solve this partially would be to change the
> condition for the conditional card mark from an equality test aginst 0x0
> (dirty_card_val)
> to a negated equality test of 0xff (clean_card_val)
>
> In that case we would slightly reduce the number of false-sharing
> inducing card writes and still survive the precleaning phase since
> precleaning sets the card to 0x1 (precleaned_card_val).
But I'm at a loss to understand how that helps with the problem of
reading an old value for the card mark. There still has to be some
sort of happens-before relationship between something and the read of
the card mark. What good would a store-store do here?
Andrew.
More information about the hotspot-gc-dev
mailing list