8286814: Shenandoah: RedefineRunningMethods.java test failed with Loom
Reviewed-by: shade
This commit is contained in:
parent
b5a3d2843b
commit
cd5bfe7b97
@ -2308,10 +2308,20 @@ void ShenandoahHeap::flush_liveness_cache(uint worker_id) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool ShenandoahHeap::requires_barriers(stackChunkOop obj) const {
|
bool ShenandoahHeap::requires_barriers(stackChunkOop obj) const {
|
||||||
ShenandoahHeapRegion* region = heap_region_containing(obj);
|
if (is_idle()) return false;
|
||||||
bool allocated_after_mark_start = marking_context()->allocated_after_mark_start(obj);
|
|
||||||
bool requires_concmark_barriers = is_concurrent_mark_in_progress() && !allocated_after_mark_start;
|
// Objects allocated after marking start are implicitly alive, don't need any barriers during
|
||||||
bool requires_loadref_barriers = has_forwarded_objects() && cast_from_oop<HeapWord*>(obj) < heap_region_containing(obj)->get_update_watermark();
|
// marking phase.
|
||||||
bool requires_deep_loadref_barriers = allocated_after_mark_start && has_forwarded_objects();
|
if (is_concurrent_mark_in_progress() && marking_context()->allocated_after_mark_start(obj)) {
|
||||||
return requires_concmark_barriers || requires_loadref_barriers || requires_deep_loadref_barriers;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Objects allocated after evacuation start are guaranteed in to-space, don't need any barriers
|
||||||
|
// during evacuation/update references phases.
|
||||||
|
if (has_forwarded_objects() &&
|
||||||
|
cast_from_oop<HeapWord*>(obj) >= heap_region_containing(obj)->get_update_watermark()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1285,8 +1285,8 @@ stackChunkOop Freeze<ConfigT>::allocate_chunk(size_t stack_size) {
|
|||||||
if (fast_oop != nullptr) {
|
if (fast_oop != nullptr) {
|
||||||
assert(!chunk->requires_barriers(), "Unfamiliar GC requires barriers on TLAB allocation");
|
assert(!chunk->requires_barriers(), "Unfamiliar GC requires barriers on TLAB allocation");
|
||||||
} else {
|
} else {
|
||||||
assert(!UseZGC || !chunk->requires_barriers(), "Allocated ZGC object requires barriers");
|
assert(!UseZGC || !UseShenandoahGC || !chunk->requires_barriers(), "Allocated ZGC/ShenandoahGC object requires barriers");
|
||||||
_barriers = !UseZGC && chunk->requires_barriers();
|
_barriers = !UseZGC && !UseShenandoahGC && chunk->requires_barriers();
|
||||||
|
|
||||||
if (_barriers) {
|
if (_barriers) {
|
||||||
log_develop_trace(continuations)("allocation requires barriers");
|
log_develop_trace(continuations)("allocation requires barriers");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user