8235260: Shenandoah: Don't allow recycle-assist until concurrent roots are done

Reviewed-by: zgu
This commit is contained in:
Roman Kennke 2019-12-03 21:23:27 +01:00
parent e70386f23a
commit 3e0a524547
2 changed files with 7 additions and 7 deletions

View File

@ -115,7 +115,7 @@ HeapWord* ShenandoahFreeSet::allocate_single(ShenandoahAllocRequest& req, bool&
size_t idx = c - 1; size_t idx = c - 1;
if (is_mutator_free(idx)) { if (is_mutator_free(idx)) {
ShenandoahHeapRegion* r = _heap->get_region(idx); ShenandoahHeapRegion* r = _heap->get_region(idx);
if (is_empty_or_trash(r)) { if (can_allocate_from(r)) {
flip_to_gc(r); flip_to_gc(r);
HeapWord *result = try_allocate_in(r, req, in_new_region); HeapWord *result = try_allocate_in(r, req, in_new_region);
if (result != NULL) { if (result != NULL) {
@ -279,7 +279,7 @@ HeapWord* ShenandoahFreeSet::allocate_contiguous(ShenandoahAllocRequest& req) {
// If regions are not adjacent, then current [beg; end] is useless, and we may fast-forward. // If regions are not adjacent, then current [beg; end] is useless, and we may fast-forward.
// If region is not completely free, the current [beg; end] is useless, and we may fast-forward. // If region is not completely free, the current [beg; end] is useless, and we may fast-forward.
if (!is_mutator_free(end) || !is_empty_or_trash(_heap->get_region(end))) { if (!is_mutator_free(end) || !can_allocate_from(_heap->get_region(end))) {
end++; end++;
beg = end; beg = end;
continue; continue;
@ -342,8 +342,8 @@ HeapWord* ShenandoahFreeSet::allocate_contiguous(ShenandoahAllocRequest& req) {
return _heap->get_region(beg)->bottom(); return _heap->get_region(beg)->bottom();
} }
bool ShenandoahFreeSet::is_empty_or_trash(ShenandoahHeapRegion *r) { bool ShenandoahFreeSet::can_allocate_from(ShenandoahHeapRegion *r) {
return r->is_empty() || r->is_trash(); return r->is_empty() || (r->is_trash() && !_heap->is_concurrent_root_in_progress());
} }
size_t ShenandoahFreeSet::alloc_capacity(ShenandoahHeapRegion *r) { size_t ShenandoahFreeSet::alloc_capacity(ShenandoahHeapRegion *r) {
@ -384,7 +384,7 @@ void ShenandoahFreeSet::flip_to_gc(ShenandoahHeapRegion* r) {
size_t idx = r->region_number(); size_t idx = r->region_number();
assert(_mutator_free_bitmap.at(idx), "Should be in mutator view"); assert(_mutator_free_bitmap.at(idx), "Should be in mutator view");
assert(is_empty_or_trash(r), "Should not be allocated"); assert(can_allocate_from(r), "Should not be allocated");
_mutator_free_bitmap.clear_bit(idx); _mutator_free_bitmap.clear_bit(idx);
_collector_free_bitmap.set_bit(idx); _collector_free_bitmap.set_bit(idx);
@ -443,7 +443,7 @@ void ShenandoahFreeSet::rebuild() {
if (reserved >= to_reserve) break; if (reserved >= to_reserve) break;
ShenandoahHeapRegion* region = _heap->get_region(idx); ShenandoahHeapRegion* region = _heap->get_region(idx);
if (_mutator_free_bitmap.at(idx) && is_empty_or_trash(region)) { if (_mutator_free_bitmap.at(idx) && can_allocate_from(region)) {
_mutator_free_bitmap.clear_bit(idx); _mutator_free_bitmap.clear_bit(idx);
_collector_free_bitmap.set_bit(idx); _collector_free_bitmap.set_bit(idx);
size_t ac = alloc_capacity(region); size_t ac = alloc_capacity(region);

View File

@ -67,7 +67,7 @@ private:
void try_recycle_trashed(ShenandoahHeapRegion *r); void try_recycle_trashed(ShenandoahHeapRegion *r);
bool is_empty_or_trash(ShenandoahHeapRegion *r); bool can_allocate_from(ShenandoahHeapRegion *r);
size_t alloc_capacity(ShenandoahHeapRegion *r); size_t alloc_capacity(ShenandoahHeapRegion *r);
bool has_no_alloc_capacity(ShenandoahHeapRegion *r); bool has_no_alloc_capacity(ShenandoahHeapRegion *r);