Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/src/hotspot/share/gc/shenandoah/shenandoahBarrierSet.hpp
40961 views
1
/*
2
* Copyright (c) 2013, 2021, Red Hat, Inc. 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_GC_SHENANDOAH_SHENANDOAHBARRIERSET_HPP
26
#define SHARE_GC_SHENANDOAH_SHENANDOAHBARRIERSET_HPP
27
28
#include "gc/shared/barrierSet.hpp"
29
#include "gc/shenandoah/shenandoahSATBMarkQueueSet.hpp"
30
31
class ShenandoahHeap;
32
class ShenandoahBarrierSetAssembler;
33
34
class ShenandoahBarrierSet: public BarrierSet {
35
private:
36
ShenandoahHeap* const _heap;
37
BufferNode::Allocator _satb_mark_queue_buffer_allocator;
38
ShenandoahSATBMarkQueueSet _satb_mark_queue_set;
39
40
public:
41
ShenandoahBarrierSet(ShenandoahHeap* heap);
42
43
static ShenandoahBarrierSetAssembler* assembler();
44
45
inline static ShenandoahBarrierSet* barrier_set() {
46
return barrier_set_cast<ShenandoahBarrierSet>(BarrierSet::barrier_set());
47
}
48
49
static ShenandoahSATBMarkQueueSet& satb_mark_queue_set() {
50
return barrier_set()->_satb_mark_queue_set;
51
}
52
53
static bool need_load_reference_barrier(DecoratorSet decorators, BasicType type);
54
static bool need_keep_alive_barrier(DecoratorSet decorators, BasicType type);
55
56
static bool is_strong_access(DecoratorSet decorators) {
57
return (decorators & (ON_WEAK_OOP_REF | ON_PHANTOM_OOP_REF | ON_UNKNOWN_OOP_REF)) == 0;
58
}
59
60
static bool is_weak_access(DecoratorSet decorators) {
61
return (decorators & (ON_WEAK_OOP_REF | ON_UNKNOWN_OOP_REF)) != 0;
62
}
63
64
static bool is_phantom_access(DecoratorSet decorators) {
65
return (decorators & ON_PHANTOM_OOP_REF) != 0;
66
}
67
68
static bool is_native_access(DecoratorSet decorators) {
69
return (decorators & IN_NATIVE) != 0;
70
}
71
72
void print_on(outputStream* st) const;
73
74
template <class T>
75
inline void arraycopy_barrier(T* src, T* dst, size_t count);
76
inline void clone_barrier(oop src);
77
void clone_barrier_runtime(oop src);
78
79
virtual void on_thread_create(Thread* thread);
80
virtual void on_thread_destroy(Thread* thread);
81
virtual void on_thread_attach(Thread* thread);
82
virtual void on_thread_detach(Thread* thread);
83
84
static inline oop resolve_forwarded_not_null(oop p);
85
static inline oop resolve_forwarded_not_null_mutator(oop p);
86
static inline oop resolve_forwarded(oop p);
87
88
template <DecoratorSet decorators, typename T>
89
inline void satb_barrier(T* field);
90
inline void satb_enqueue(oop value);
91
inline void iu_barrier(oop obj);
92
93
template <DecoratorSet decorators>
94
inline void keep_alive_if_weak(oop value);
95
inline void keep_alive_if_weak(DecoratorSet decorators, oop value);
96
97
inline void enqueue(oop obj);
98
99
inline oop load_reference_barrier(oop obj);
100
101
template <class T>
102
inline oop load_reference_barrier_mutator(oop obj, T* load_addr);
103
104
template <DecoratorSet decorators, class T>
105
inline oop load_reference_barrier(oop obj, T* load_addr);
106
107
private:
108
template <class T>
109
inline void arraycopy_marking(T* src, T* dst, size_t count);
110
template <class T>
111
inline void arraycopy_evacuation(T* src, size_t count);
112
template <class T>
113
inline void arraycopy_update(T* src, size_t count);
114
115
inline void clone_marking(oop src);
116
inline void clone_evacuation(oop src);
117
inline void clone_update(oop src);
118
119
template <class T, bool HAS_FWD, bool EVAC, bool ENQUEUE>
120
inline void arraycopy_work(T* src, size_t count);
121
122
inline bool need_bulk_update(HeapWord* dst);
123
public:
124
// Callbacks for runtime accesses.
125
template <DecoratorSet decorators, typename BarrierSetT = ShenandoahBarrierSet>
126
class AccessBarrier: public BarrierSet::AccessBarrier<decorators, BarrierSetT> {
127
typedef BarrierSet::AccessBarrier<decorators, BarrierSetT> Raw;
128
129
public:
130
// Heap oop accesses. These accessors get resolved when
131
// IN_HEAP is set (e.g. when using the HeapAccess API), it is
132
// an oop_* overload, and the barrier strength is AS_NORMAL.
133
template <typename T>
134
static oop oop_load_in_heap(T* addr);
135
static oop oop_load_in_heap_at(oop base, ptrdiff_t offset);
136
137
template <typename T>
138
static void oop_store_in_heap(T* addr, oop value);
139
static void oop_store_in_heap_at(oop base, ptrdiff_t offset, oop value);
140
141
template <typename T>
142
static oop oop_atomic_cmpxchg_in_heap(T* addr, oop compare_value, oop new_value);
143
static oop oop_atomic_cmpxchg_in_heap_at(oop base, ptrdiff_t offset, oop compare_value, oop new_value);
144
145
template <typename T>
146
static oop oop_atomic_xchg_in_heap(T* addr, oop new_value);
147
static oop oop_atomic_xchg_in_heap_at(oop base, ptrdiff_t offset, oop new_value);
148
149
template <typename T>
150
static bool oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, T* src_raw,
151
arrayOop dst_obj, size_t dst_offset_in_bytes, T* dst_raw,
152
size_t length);
153
154
// Clone barrier support
155
static void clone_in_heap(oop src, oop dst, size_t size);
156
157
// Support for concurrent roots evacuation, updating and weak roots clearing
158
template <typename T>
159
static oop oop_load_not_in_heap(T* addr);
160
161
// Support for concurrent roots marking
162
template <typename T>
163
static void oop_store_not_in_heap(T* addr, oop value);
164
165
template <typename T>
166
static oop oop_atomic_cmpxchg_not_in_heap(T* addr, oop compare_value, oop new_value);
167
168
template <typename T>
169
static oop oop_atomic_xchg_not_in_heap(T* addr, oop new_value);
170
171
};
172
173
};
174
175
template<>
176
struct BarrierSet::GetName<ShenandoahBarrierSet> {
177
static const BarrierSet::Name value = BarrierSet::ShenandoahBarrierSet;
178
};
179
180
template<>
181
struct BarrierSet::GetType<BarrierSet::ShenandoahBarrierSet> {
182
typedef ::ShenandoahBarrierSet type;
183
};
184
185
#endif // SHARE_GC_SHENANDOAH_SHENANDOAHBARRIERSET_HPP
186
187