8264027: Refactor "CLEANUP" region printing

Reviewed-by: kbarrett, ayang
This commit is contained in:
Thomas Schatzl 2021-04-06 10:03:03 +00:00
parent eb6330e4f0
commit bf26a2558f
4 changed files with 50 additions and 27 deletions

View File

@ -4031,7 +4031,6 @@ void G1CollectedHeap::free_region(HeapRegion* hr, FreeRegionList* free_list) {
void G1CollectedHeap::free_humongous_region(HeapRegion* hr,
FreeRegionList* free_list) {
assert(hr->is_humongous(), "this is only for humongous regions");
assert(free_list != NULL, "pre-condition");
hr->clear_humongous();
free_region(hr, free_list);
}
@ -4183,6 +4182,7 @@ class G1FreeCollectionSetTask : public AbstractGangTask {
// Free the region and and its remembered set.
_g1h->free_region(r, NULL);
_g1h->hr_printer()->cleanup(r);
}
void handle_failed_region(HeapRegion* r) {
@ -4336,16 +4336,14 @@ void G1CollectedHeap::free_collection_set(G1CollectionSet* collection_set, G1Eva
}
class G1FreeHumongousRegionClosure : public HeapRegionClosure {
private:
FreeRegionList* _free_region_list;
HeapRegionSet* _proxy_set;
uint _humongous_objects_reclaimed;
uint _humongous_regions_reclaimed;
size_t _freed_bytes;
public:
G1FreeHumongousRegionClosure(FreeRegionList* free_region_list) :
_free_region_list(free_region_list), _proxy_set(NULL), _humongous_objects_reclaimed(0), _humongous_regions_reclaimed(0), _freed_bytes(0) {
G1FreeHumongousRegionClosure() :
_proxy_set(NULL), _humongous_objects_reclaimed(0), _humongous_regions_reclaimed(0), _freed_bytes(0) {
}
virtual bool do_heap_region(HeapRegion* r) {
@ -4430,7 +4428,8 @@ public:
_freed_bytes += r->used();
r->set_containing_set(NULL);
_humongous_regions_reclaimed++;
g1h->free_humongous_region(r, _free_region_list);
g1h->free_humongous_region(r, NULL);
g1h->hr_printer()->cleanup(r);
r = next;
} while (r != NULL);
@ -4461,22 +4460,11 @@ void G1CollectedHeap::eagerly_reclaim_humongous_regions() {
double start_time = os::elapsedTime();
FreeRegionList local_cleanup_list("Local Humongous Cleanup List");
G1FreeHumongousRegionClosure cl(&local_cleanup_list);
G1FreeHumongousRegionClosure cl;
heap_region_iterate(&cl);
remove_from_old_gen_sets(0, 0, cl.humongous_regions_reclaimed());
G1HRPrinter* hrp = hr_printer();
if (hrp->is_active()) {
FreeRegionListIterator iter(&local_cleanup_list);
while (iter.more_available()) {
HeapRegion* hr = iter.get_next();
hrp->cleanup(hr);
}
}
decrement_summary_bytes(cl.bytes_freed());
phase_times()->record_fast_reclaim_humongous_time_ms((os::elapsedTime() - start_time) * 1000.0,

View File

@ -1288,14 +1288,7 @@ void G1ConcurrentMark::reclaim_empty_regions() {
if (!empty_regions_list.is_empty()) {
log_debug(gc)("Reclaimed %u empty regions", empty_regions_list.length());
// Now print the empty regions list.
G1HRPrinter* hrp = _g1h->hr_printer();
if (hrp->is_active()) {
FreeRegionListIterator iter(&empty_regions_list);
while (iter.more_available()) {
HeapRegion* hr = iter.get_next();
hrp->cleanup(hr);
}
}
_g1h->hr_printer()->cleanup(&empty_regions_list);
// And actually make them available.
_g1h->prepend_to_freelist(&empty_regions_list);
}

View File

@ -0,0 +1,38 @@
/*
* Copyright (c) 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*
*/
#include "precompiled.hpp"
#include "gc/g1/g1HRPrinter.hpp"
#include "gc/g1/heapRegionSet.hpp"
void G1HRPrinter::cleanup(FreeRegionList* cleanup_list) {
if (is_active()) {
FreeRegionListIterator iter(cleanup_list);
while (iter.more_available()) {
HeapRegion* hr = iter.get_next();
cleanup(hr);
}
}
}

View File

@ -1,5 +1,5 @@
/*
* Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@ -30,6 +30,8 @@
#define SKIP_RETIRED_FULL_REGIONS 1
class FreeRegionList;
class G1HRPrinter {
private:
@ -86,6 +88,8 @@ public:
}
}
void cleanup(FreeRegionList* free_list);
void post_compaction(HeapRegion* hr) {
if (is_active()) {
print("POST-COMPACTION", hr);