Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/gc_base/OwnableSynchronizerObjectBuffer.hpp
5985 views
1
2
/*******************************************************************************
3
* Copyright (c) 1991, 2014 IBM Corp. and others
4
*
5
* This program and the accompanying materials are made available under
6
* the terms of the Eclipse Public License 2.0 which accompanies this
7
* distribution and is available at https://www.eclipse.org/legal/epl-2.0/
8
* or the Apache License, Version 2.0 which accompanies this distribution and
9
* is available at https://www.apache.org/licenses/LICENSE-2.0.
10
*
11
* This Source Code may also be made available under the following
12
* Secondary Licenses when the conditions for such availability set
13
* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
14
* General Public License, version 2 with the GNU Classpath
15
* Exception [1] and GNU General Public License, version 2 with the
16
* OpenJDK Assembly Exception [2].
17
*
18
* [1] https://www.gnu.org/software/classpath/license.html
19
* [2] http://openjdk.java.net/legal/assembly-exception.html
20
*
21
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception
22
*******************************************************************************/
23
24
#ifndef OWNABLESYNCHRONIZEROBJECTBUFFER_HPP_
25
#define OWNABLESYNCHRONIZEROBJECTBUFFER_HPP_
26
27
#include "j9.h"
28
#include "j9cfg.h"
29
30
#include "BaseVirtual.hpp"
31
32
class MM_EnvironmentBase;
33
class MM_GCExtensions;
34
class MM_HeapRegionDescriptor;
35
36
/**
37
* A per-thread buffer of recently allocated OwnableSynchronizer objects.
38
* The buffer is periodically flushed to the global list.
39
*/
40
class MM_OwnableSynchronizerObjectBuffer : public MM_BaseVirtual
41
{
42
private:
43
protected:
44
j9object_t _head; /**< the head of the linked list of OwnableSynchronizer objects */
45
j9object_t _tail; /**< the tail of the linked list of OwnableSynchronizer objects */
46
MM_HeapRegionDescriptor* _region; /**< the region in which all buffered objects are located */
47
UDATA _objectCount; /**< the number of buffered objects */
48
const UDATA _maxObjectCount; /**< the maximum number of objects permitted before a forced flush */
49
MM_GCExtensions * const _extensions; /**< a cached pointer to the extensions structure */
50
public:
51
52
private:
53
54
/**
55
* Reset a flushed buffer to the empty state.
56
*/
57
void reset();
58
59
protected:
60
61
virtual bool initialize(MM_EnvironmentBase *env) = 0;
62
virtual void tearDown(MM_EnvironmentBase *env) = 0;
63
64
/**
65
* Flush the contents of the buffer to the appropriate global buffers.
66
* Subclasses must override.
67
* @param env[in] the current thread
68
*/
69
virtual void flushImpl(MM_EnvironmentBase* env);
70
71
public:
72
void kill(MM_EnvironmentBase *env);
73
/**
74
* Add the specified OwnableSynchronizer object to the buffer.
75
* @param env[in] the current thread
76
* @param object[in] the object to add
77
*/
78
void add(MM_EnvironmentBase* env, j9object_t object);
79
80
/**
81
* Flush the contents of the buffer to the appropriate global buffers.
82
* @param env[in] the current thread
83
*/
84
void flush(MM_EnvironmentBase* env);
85
86
/**
87
* Construct a new buffer.
88
* @param extensions[in] the GC extensions
89
* @param maxObjectCount the maximum number of objects permitted before a forced flush
90
*/
91
MM_OwnableSynchronizerObjectBuffer(MM_GCExtensions *extensions, UDATA maxObjectCount);
92
};
93
94
#endif /* OWNABLESYNCHRONIZEROBJECTBUFFER_HPP_ */
95
96