diff --git a/src/hotspot/share/gc/epsilon/epsilonHeap.cpp b/src/hotspot/share/gc/epsilon/epsilonHeap.cpp index 3b81eb41996..78d08a4dd5a 100644 --- a/src/hotspot/share/gc/epsilon/epsilonHeap.cpp +++ b/src/hotspot/share/gc/epsilon/epsilonHeap.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2018, Red Hat, Inc. All rights reserved. + * Copyright (c) 2017, 2020, Red Hat, Inc. 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 @@ -101,10 +101,7 @@ size_t EpsilonHeap::unsafe_max_tlab_alloc(Thread* thr) const { } EpsilonHeap* EpsilonHeap::heap() { - CollectedHeap* heap = Universe::heap(); - assert(heap != NULL, "Uninitialized access to EpsilonHeap::heap()"); - assert(heap->kind() == CollectedHeap::Epsilon, "Not an Epsilon heap"); - return (EpsilonHeap*)heap; + return named_heap(CollectedHeap::Epsilon); } HeapWord* EpsilonHeap::allocate_work(size_t size) { diff --git a/src/hotspot/share/gc/g1/g1CollectedHeap.cpp b/src/hotspot/share/gc/g1/g1CollectedHeap.cpp index e8cdd861cbb..9559f732aa2 100644 --- a/src/hotspot/share/gc/g1/g1CollectedHeap.cpp +++ b/src/hotspot/share/gc/g1/g1CollectedHeap.cpp @@ -2668,13 +2668,6 @@ void G1CollectedHeap::trace_heap(GCWhen::Type when, const GCTracer* gc_tracer) { gc_tracer->report_metaspace_summary(when, metaspace_summary); } -G1CollectedHeap* G1CollectedHeap::heap() { - CollectedHeap* heap = Universe::heap(); - assert(heap != NULL, "Uninitialized access to G1CollectedHeap::heap()"); - assert(heap->kind() == CollectedHeap::G1, "Invalid name"); - return (G1CollectedHeap*)heap; -} - void G1CollectedHeap::gc_prologue(bool full) { assert(InlineCacheBuffer::is_empty(), "should have cleaned up ICBuffer"); diff --git a/src/hotspot/share/gc/g1/g1CollectedHeap.hpp b/src/hotspot/share/gc/g1/g1CollectedHeap.hpp index 71f89d09184..3595b6bd7f2 100644 --- a/src/hotspot/share/gc/g1/g1CollectedHeap.hpp +++ b/src/hotspot/share/gc/g1/g1CollectedHeap.hpp @@ -1293,7 +1293,9 @@ public: // Convenience function to be used in situations where the heap type can be // asserted to be this type. - static G1CollectedHeap* heap(); + static G1CollectedHeap* heap() { + return named_heap(CollectedHeap::G1); + } void set_region_short_lived_locked(HeapRegion* hr); // add appropriate methods for any other surv rate groups diff --git a/src/hotspot/share/gc/parallel/parallelScavengeHeap.cpp b/src/hotspot/share/gc/parallel/parallelScavengeHeap.cpp index 2ed42c16f0e..b2645223d87 100644 --- a/src/hotspot/share/gc/parallel/parallelScavengeHeap.cpp +++ b/src/hotspot/share/gc/parallel/parallelScavengeHeap.cpp @@ -689,13 +689,6 @@ void ParallelScavengeHeap::trace_heap(GCWhen::Type when, const GCTracer* gc_trac gc_tracer->report_metaspace_summary(when, metaspace_summary); } -ParallelScavengeHeap* ParallelScavengeHeap::heap() { - CollectedHeap* heap = Universe::heap(); - assert(heap != NULL, "Uninitialized access to ParallelScavengeHeap::heap()"); - assert(heap->kind() == CollectedHeap::Parallel, "Invalid name"); - return (ParallelScavengeHeap*)heap; -} - CardTableBarrierSet* ParallelScavengeHeap::barrier_set() { return barrier_set_cast(BarrierSet::barrier_set()); } diff --git a/src/hotspot/share/gc/parallel/parallelScavengeHeap.hpp b/src/hotspot/share/gc/parallel/parallelScavengeHeap.hpp index 54f4ca72b73..34321547b7b 100644 --- a/src/hotspot/share/gc/parallel/parallelScavengeHeap.hpp +++ b/src/hotspot/share/gc/parallel/parallelScavengeHeap.hpp @@ -126,7 +126,9 @@ class ParallelScavengeHeap : public CollectedHeap { static PSGCAdaptivePolicyCounters* gc_policy_counters() { return _gc_policy_counters; } - static ParallelScavengeHeap* heap(); + static ParallelScavengeHeap* heap() { + return named_heap(CollectedHeap::Parallel); + } CardTableBarrierSet* barrier_set(); PSCardTable* card_table(); diff --git a/src/hotspot/share/gc/serial/serialHeap.cpp b/src/hotspot/share/gc/serial/serialHeap.cpp index 16108fe8256..4aea11ff702 100644 --- a/src/hotspot/share/gc/serial/serialHeap.cpp +++ b/src/hotspot/share/gc/serial/serialHeap.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -31,10 +31,7 @@ #include "services/memoryManager.hpp" SerialHeap* SerialHeap::heap() { - CollectedHeap* heap = Universe::heap(); - assert(heap != NULL, "Uninitialized access to SerialHeap::heap()"); - assert(heap->kind() == CollectedHeap::Serial, "Invalid name"); - return static_cast(heap); + return named_heap(CollectedHeap::Serial); } SerialHeap::SerialHeap() : diff --git a/src/hotspot/share/gc/shared/collectedHeap.hpp b/src/hotspot/share/gc/shared/collectedHeap.hpp index 8a6936d2e37..9a4d2ff19ec 100644 --- a/src/hotspot/share/gc/shared/collectedHeap.hpp +++ b/src/hotspot/share/gc/shared/collectedHeap.hpp @@ -29,6 +29,7 @@ #include "gc/shared/gcWhen.hpp" #include "gc/shared/verifyOption.hpp" #include "memory/allocation.hpp" +#include "memory/universe.hpp" #include "runtime/handles.hpp" #include "runtime/perfData.hpp" #include "runtime/safepoint.hpp" @@ -177,6 +178,20 @@ class CollectedHeap : public CHeapObj { Shenandoah }; + protected: + // Get a pointer to the derived heap object. Used to implement + // derived class heap() functions rather than being called directly. + template + static T* named_heap(Name kind) { + CollectedHeap* heap = Universe::heap(); + assert(heap != NULL, "Uninitialized heap"); + assert(kind == heap->kind(), "Heap kind %u should be %u", + static_cast(heap->kind()), static_cast(kind)); + return static_cast(heap); + } + + public: + static inline size_t filler_array_max_size() { return _filler_array_max_size; } diff --git a/src/hotspot/share/gc/shared/genCollectedHeap.cpp b/src/hotspot/share/gc/shared/genCollectedHeap.cpp index c5cf68eda14..e32356a9d5d 100644 --- a/src/hotspot/share/gc/shared/genCollectedHeap.cpp +++ b/src/hotspot/share/gc/shared/genCollectedHeap.cpp @@ -1199,10 +1199,8 @@ void GenCollectedHeap::save_marks() { } GenCollectedHeap* GenCollectedHeap::heap() { - CollectedHeap* heap = Universe::heap(); - assert(heap != NULL, "Uninitialized access to GenCollectedHeap::heap()"); - assert(heap->kind() == CollectedHeap::Serial, "Invalid name"); - return (GenCollectedHeap*) heap; + // SerialHeap is the only subtype of GenCollectedHeap. + return named_heap(CollectedHeap::Serial); } #if INCLUDE_SERIALGC diff --git a/src/hotspot/share/gc/z/zCollectedHeap.cpp b/src/hotspot/share/gc/z/zCollectedHeap.cpp index 80056a6cd84..bb7734d707e 100644 --- a/src/hotspot/share/gc/z/zCollectedHeap.cpp +++ b/src/hotspot/share/gc/z/zCollectedHeap.cpp @@ -41,10 +41,7 @@ #include "utilities/align.hpp" ZCollectedHeap* ZCollectedHeap::heap() { - CollectedHeap* heap = Universe::heap(); - assert(heap != NULL, "Uninitialized access to ZCollectedHeap::heap()"); - assert(heap->kind() == CollectedHeap::Z, "Invalid name"); - return (ZCollectedHeap*)heap; + return named_heap(CollectedHeap::Z); } ZCollectedHeap::ZCollectedHeap() :