RFR(XS) 8153834: G1 Card table verification fails due to concurrent region cleanup

Erik Helin erik.helin at oracle.com
Tue Apr 12 12:56:44 UTC 2016


On 2016-04-12, Mikael Gerdin wrote:
> Hi all,
> 
> Please review this small fix to an issue with -XX:+G1VerifyCTCleanup we
> discovered recently.
> The problem is that concurrent region freeing
> (G1ConcurrentMark::complete_cleanup()) can run concurrently with a young gc
> after the cleanup pause. If the concurrent cleanup is not finished when the
> young gc verifies the card table then the verification can see 0s in the
> card table where there should be none.
> 
> Suggested fix is to have not-PRODUCT vms await concurrent region freeing
> before verifying the card table by calling wait_while_free_regions_coming()
> 
> Bug: https://bugs.openjdk.java.net/browse/JDK-8153834
> Webrev: http://cr.openjdk.java.net/~mgerdin/8153834/webrev.0

Looks good to me, Reviewed.

Thanks,
Erik

> Testing: RBT GC testing in progress, local testing of reproducer
> 
> /Mikael



More information about the hotspot-gc-dev mailing list