RFR: JDK-8151336: Root region scanning should be cancelled and disabled when the ConcurrentMarkThread::run_service() exits

Bengt Rutisson bengt.rutisson at oracle.com
Tue Mar 15 11:55:24 UTC 2016


Hi again,

I am working on an update to this webrev. So, please hold off with 
reviews of the patch below.

Thanks,
Bengt

On 2016-03-14 12:23, Bengt Rutisson wrote:
>
> Hi all,
>
> Could I have a couple of reviews for this change?
>
> http://cr.openjdk.java.net/~brutisso/8151336/webrev.00/
> https://bugs.openjdk.java.net/browse/JDK-8151336
>
> The run_service() loop in ConcurrentMarkThread looks like this:
>
>   while (!_should_terminate) {
>     // wait until started is set.
>     sleepBeforeNextCycle();
>     if (_should_terminate) {
>       _cm->root_regions()->cancel_scan();
>       break;
>     }
>     // do all the work
>  }
>
> If a full GC is triggered while the ConcurrentMarkThread is in "do all 
> the work" the full GC will wait for the root region scan. But if we at 
> the same time decide to exit the VM we will set _should_terminate to 
> true, which will cause the while() loop to not continue and we won't 
> get to the cancel_scan call.
>
> The proposed fix moves the call to cancel_scan() until after the while 
> loop has exited. That way we will always cancel any pending root 
> region scanning.
>
> I also introduce a _has_terminated state for G1CMRootRegions to makes 
> sure that another root region scanning can't be initialized once the 
> CM thread has exited. This also called for a rename of cancel_scan() 
> to terminate().
>
> Thanks,
> Bengt




More information about the hotspot-gc-dev mailing list