diff --git a/src/hotspot/share/gc/g1/g1CollectedHeap.cpp b/src/hotspot/share/gc/g1/g1CollectedHeap.cpp index 145b1545c7a..d1fa03d5b8f 100644 --- a/src/hotspot/share/gc/g1/g1CollectedHeap.cpp +++ b/src/hotspot/share/gc/g1/g1CollectedHeap.cpp @@ -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, diff --git a/src/hotspot/share/gc/g1/g1ConcurrentMark.cpp b/src/hotspot/share/gc/g1/g1ConcurrentMark.cpp index 2c35ae70702..9bfcd48ef48 100644 --- a/src/hotspot/share/gc/g1/g1ConcurrentMark.cpp +++ b/src/hotspot/share/gc/g1/g1ConcurrentMark.cpp @@ -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); } diff --git a/src/hotspot/share/gc/g1/g1HRPrinter.cpp b/src/hotspot/share/gc/g1/g1HRPrinter.cpp new file mode 100644 index 00000000000..af83284f061 --- /dev/null +++ b/src/hotspot/share/gc/g1/g1HRPrinter.cpp @@ -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); + } + } +} diff --git a/src/hotspot/share/gc/g1/g1HRPrinter.hpp b/src/hotspot/share/gc/g1/g1HRPrinter.hpp index 4266f78e5a7..9a522a4029e 100644 --- a/src/hotspot/share/gc/g1/g1HRPrinter.hpp +++ b/src/hotspot/share/gc/g1/g1HRPrinter.hpp @@ -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);