8264027: Refactor "CLEANUP" region printing
Reviewed-by: kbarrett, ayang
This commit is contained in:
parent
eb6330e4f0
commit
bf26a2558f
@ -4031,7 +4031,6 @@ void G1CollectedHeap::free_region(HeapRegion* hr, FreeRegionList* free_list) {
|
|||||||
void G1CollectedHeap::free_humongous_region(HeapRegion* hr,
|
void G1CollectedHeap::free_humongous_region(HeapRegion* hr,
|
||||||
FreeRegionList* free_list) {
|
FreeRegionList* free_list) {
|
||||||
assert(hr->is_humongous(), "this is only for humongous regions");
|
assert(hr->is_humongous(), "this is only for humongous regions");
|
||||||
assert(free_list != NULL, "pre-condition");
|
|
||||||
hr->clear_humongous();
|
hr->clear_humongous();
|
||||||
free_region(hr, free_list);
|
free_region(hr, free_list);
|
||||||
}
|
}
|
||||||
@ -4183,6 +4182,7 @@ class G1FreeCollectionSetTask : public AbstractGangTask {
|
|||||||
|
|
||||||
// Free the region and and its remembered set.
|
// Free the region and and its remembered set.
|
||||||
_g1h->free_region(r, NULL);
|
_g1h->free_region(r, NULL);
|
||||||
|
_g1h->hr_printer()->cleanup(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
void handle_failed_region(HeapRegion* r) {
|
void handle_failed_region(HeapRegion* r) {
|
||||||
@ -4336,16 +4336,14 @@ void G1CollectedHeap::free_collection_set(G1CollectionSet* collection_set, G1Eva
|
|||||||
}
|
}
|
||||||
|
|
||||||
class G1FreeHumongousRegionClosure : public HeapRegionClosure {
|
class G1FreeHumongousRegionClosure : public HeapRegionClosure {
|
||||||
private:
|
|
||||||
FreeRegionList* _free_region_list;
|
|
||||||
HeapRegionSet* _proxy_set;
|
HeapRegionSet* _proxy_set;
|
||||||
uint _humongous_objects_reclaimed;
|
uint _humongous_objects_reclaimed;
|
||||||
uint _humongous_regions_reclaimed;
|
uint _humongous_regions_reclaimed;
|
||||||
size_t _freed_bytes;
|
size_t _freed_bytes;
|
||||||
public:
|
public:
|
||||||
|
|
||||||
G1FreeHumongousRegionClosure(FreeRegionList* free_region_list) :
|
G1FreeHumongousRegionClosure() :
|
||||||
_free_region_list(free_region_list), _proxy_set(NULL), _humongous_objects_reclaimed(0), _humongous_regions_reclaimed(0), _freed_bytes(0) {
|
_proxy_set(NULL), _humongous_objects_reclaimed(0), _humongous_regions_reclaimed(0), _freed_bytes(0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool do_heap_region(HeapRegion* r) {
|
virtual bool do_heap_region(HeapRegion* r) {
|
||||||
@ -4430,7 +4428,8 @@ public:
|
|||||||
_freed_bytes += r->used();
|
_freed_bytes += r->used();
|
||||||
r->set_containing_set(NULL);
|
r->set_containing_set(NULL);
|
||||||
_humongous_regions_reclaimed++;
|
_humongous_regions_reclaimed++;
|
||||||
g1h->free_humongous_region(r, _free_region_list);
|
g1h->free_humongous_region(r, NULL);
|
||||||
|
g1h->hr_printer()->cleanup(r);
|
||||||
r = next;
|
r = next;
|
||||||
} while (r != NULL);
|
} while (r != NULL);
|
||||||
|
|
||||||
@ -4461,22 +4460,11 @@ void G1CollectedHeap::eagerly_reclaim_humongous_regions() {
|
|||||||
|
|
||||||
double start_time = os::elapsedTime();
|
double start_time = os::elapsedTime();
|
||||||
|
|
||||||
FreeRegionList local_cleanup_list("Local Humongous Cleanup List");
|
G1FreeHumongousRegionClosure cl;
|
||||||
|
|
||||||
G1FreeHumongousRegionClosure cl(&local_cleanup_list);
|
|
||||||
heap_region_iterate(&cl);
|
heap_region_iterate(&cl);
|
||||||
|
|
||||||
remove_from_old_gen_sets(0, 0, cl.humongous_regions_reclaimed());
|
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());
|
decrement_summary_bytes(cl.bytes_freed());
|
||||||
|
|
||||||
phase_times()->record_fast_reclaim_humongous_time_ms((os::elapsedTime() - start_time) * 1000.0,
|
phase_times()->record_fast_reclaim_humongous_time_ms((os::elapsedTime() - start_time) * 1000.0,
|
||||||
|
@ -1288,14 +1288,7 @@ void G1ConcurrentMark::reclaim_empty_regions() {
|
|||||||
if (!empty_regions_list.is_empty()) {
|
if (!empty_regions_list.is_empty()) {
|
||||||
log_debug(gc)("Reclaimed %u empty regions", empty_regions_list.length());
|
log_debug(gc)("Reclaimed %u empty regions", empty_regions_list.length());
|
||||||
// Now print the empty regions list.
|
// Now print the empty regions list.
|
||||||
G1HRPrinter* hrp = _g1h->hr_printer();
|
_g1h->hr_printer()->cleanup(&empty_regions_list);
|
||||||
if (hrp->is_active()) {
|
|
||||||
FreeRegionListIterator iter(&empty_regions_list);
|
|
||||||
while (iter.more_available()) {
|
|
||||||
HeapRegion* hr = iter.get_next();
|
|
||||||
hrp->cleanup(hr);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// And actually make them available.
|
// And actually make them available.
|
||||||
_g1h->prepend_to_freelist(&empty_regions_list);
|
_g1h->prepend_to_freelist(&empty_regions_list);
|
||||||
}
|
}
|
||||||
|
38
src/hotspot/share/gc/g1/g1HRPrinter.cpp
Normal file
38
src/hotspot/share/gc/g1/g1HRPrinter.cpp
Normal 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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,6 +30,8 @@
|
|||||||
|
|
||||||
#define SKIP_RETIRED_FULL_REGIONS 1
|
#define SKIP_RETIRED_FULL_REGIONS 1
|
||||||
|
|
||||||
|
class FreeRegionList;
|
||||||
|
|
||||||
class G1HRPrinter {
|
class G1HRPrinter {
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -86,6 +88,8 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cleanup(FreeRegionList* free_list);
|
||||||
|
|
||||||
void post_compaction(HeapRegion* hr) {
|
void post_compaction(HeapRegion* hr) {
|
||||||
if (is_active()) {
|
if (is_active()) {
|
||||||
print("POST-COMPACTION", hr);
|
print("POST-COMPACTION", hr);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user