1 /*
2 * Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 *
23 */
24
25 #ifndef SHARE_VM_GC_SHENANDOAH_SHENANDOAHYOUNGGENERATION_HPP
26 #define SHARE_VM_GC_SHENANDOAH_SHENANDOAHYOUNGGENERATION_HPP
27
28 #include "gc/shenandoah/shenandoahGeneration.hpp"
29 #include "gc/shenandoah/heuristics/shenandoahYoungHeuristics.hpp"
30
31 class ShenandoahYoungGeneration : public ShenandoahGeneration {
32 private:
33 ShenandoahObjToScanQueueSet* _old_gen_task_queues;
34 ShenandoahYoungHeuristics* _young_heuristics;
35
36 public:
37 ShenandoahYoungGeneration(uint max_queues, size_t max_capacity);
38
39 ShenandoahHeuristics* initialize_heuristics(ShenandoahMode* gc_mode) override;
40
41 const char* name() const override {
42 return "Young";
43 }
44
45 ShenandoahYoungHeuristics* heuristics() const override {
46 return _young_heuristics;
47 }
48
49 void set_concurrent_mark_in_progress(bool in_progress) override;
50 bool is_concurrent_mark_in_progress() override;
51
52 void parallel_heap_region_iterate(ShenandoahHeapRegionClosure* cl) override;
53
54 void parallel_heap_region_iterate_free(ShenandoahHeapRegionClosure* cl) override;
55
56 void heap_region_iterate(ShenandoahHeapRegionClosure* cl) override;
57
58 bool contains(ShenandoahAffiliation affiliation) const override;
59 bool contains(ShenandoahHeapRegion* region) const override;
60 bool contains(oop obj) const override;
61
62 void reserve_task_queues(uint workers) override;
63 void set_old_gen_task_queues(ShenandoahObjToScanQueueSet* old_gen_queues) {
64 _old_gen_task_queues = old_gen_queues;
65 }
66 ShenandoahObjToScanQueueSet* old_gen_task_queues() const override {
67 return _old_gen_task_queues;
68 }
69
70 // Returns true if the young generation is configured to enqueue old
71 // oops for the old generation mark queues.
72 bool is_bootstrap_cycle() {
73 return _old_gen_task_queues != nullptr;
74 }
75
76 size_t available() const override;
77
78 // Do not override available_with_reserve() because that needs to see memory reserved for Collector
79
80 size_t soft_available() const override;
81
82 void prepare_gc() override;
83 };
84
85 #endif // SHARE_VM_GC_SHENANDOAH_SHENANDOAHYOUNGGENERATION_HPP