--- a/hotspot/src/share/vm/gc/g1/concurrentMarkThread.cpp Wed Mar 16 15:36:42 2016 +0100
+++ b/hotspot/src/share/vm/gc/g1/concurrentMarkThread.cpp Wed Mar 16 16:42:30 2016 +0100
@@ -117,7 +117,6 @@
// wait until started is set.
sleepBeforeNextCycle();
if (should_terminate()) {
- _cm->root_regions()->cancel_scan();
break;
}
@@ -284,6 +283,7 @@
g1h->register_concurrent_cycle_end();
}
}
+ _cm->root_regions()->cancel_scan();
}
void ConcurrentMarkThread::stop_service() {
--- a/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp Wed Mar 16 15:36:42 2016 +0100
+++ b/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp Wed Mar 16 16:42:30 2016 +0100
@@ -3222,10 +3222,13 @@
_verifier->verify_region_sets_optional();
_verifier->verify_dirty_young_regions();
- // This call will decide whether this pause is an initial-mark
- // pause. If it is, during_initial_mark_pause() will return true
- // for the duration of this pause.
- g1_policy()->decide_on_conc_mark_initiation();
+ // We should not be doing initial mark unless the conc mark thread is running
+ if (!_cmThread->should_terminate()) {
+ // This call will decide whether this pause is an initial-mark
+ // pause. If it is, during_initial_mark_pause() will return true
+ // for the duration of this pause.
+ g1_policy()->decide_on_conc_mark_initiation();
+ }
// We do not allow initial-mark to be piggy-backed on a mixed GC.
assert(!collector_state()->during_initial_mark_pause() ||