提交 a2f84670 编写于 作者: J johnc

6940894: G1: assert(new_obj != 0 || ... "should be forwarded") for compaction tests

Summary: Humongous regions may contain multiple objects as a result of being retained as to-space from a previous GC and then re-used as to-space after being tagged as humongous. These changes include a check that causes retained to-space regions that are now tagged as humongous to be disregarded and a new to-space region allocated.
Reviewed-by: tonyp, iveresov
上级 fad9ad9d
...@@ -2942,6 +2942,9 @@ void G1CollectedHeap::set_gc_alloc_region(int purpose, HeapRegion* r) { ...@@ -2942,6 +2942,9 @@ void G1CollectedHeap::set_gc_alloc_region(int purpose, HeapRegion* r) {
// the same region // the same region
assert(r == NULL || !r->is_gc_alloc_region(), assert(r == NULL || !r->is_gc_alloc_region(),
"shouldn't already be a GC alloc region"); "shouldn't already be a GC alloc region");
assert(r == NULL || !r->isHumongous(),
"humongous regions shouldn't be used as GC alloc regions");
HeapWord* original_top = NULL; HeapWord* original_top = NULL;
if (r != NULL) if (r != NULL)
original_top = r->top(); original_top = r->top();
...@@ -3084,12 +3087,17 @@ void G1CollectedHeap::get_gc_alloc_regions() { ...@@ -3084,12 +3087,17 @@ void G1CollectedHeap::get_gc_alloc_regions() {
if (alloc_region->in_collection_set() || if (alloc_region->in_collection_set() ||
alloc_region->top() == alloc_region->end() || alloc_region->top() == alloc_region->end() ||
alloc_region->top() == alloc_region->bottom()) { alloc_region->top() == alloc_region->bottom() ||
// we will discard the current GC alloc region if it's in the alloc_region->isHumongous()) {
// collection set (it can happen!), if it's already full (no // we will discard the current GC alloc region if
// point in using it), or if it's empty (this means that it // * it's in the collection set (it can happen!),
// was emptied during a cleanup and it should be on the free // * it's already full (no point in using it),
// list now). // * it's empty (this means that it was emptied during
// a cleanup and it should be on the free list now), or
// * it's humongous (this means that it was emptied
// during a cleanup and was added to the free list, but
// has been subseqently used to allocate a humongous
// object that may be less than the region size).
alloc_region = NULL; alloc_region = NULL;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册