Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/gc_modron_standard/ConcurrentSweepGC.cpp
5985 views
1
2
/*******************************************************************************
3
* Copyright (c) 1991, 2017 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
#include "j9.h"
25
#include "j9cfg.h"
26
#include "j9port.h"
27
28
#if defined(J9VM_GC_CONCURRENT_SWEEP)
29
30
#include "ConcurrentSweepGC.hpp"
31
32
#include "ConcurrentSweepScheme.hpp"
33
34
MM_ConcurrentSweepGC *
35
MM_ConcurrentSweepGC::newInstance(MM_EnvironmentBase *env)
36
{
37
MM_ConcurrentSweepGC *globalGC;
38
39
globalGC = (MM_ConcurrentSweepGC *)env->getForge()->allocate(sizeof(MM_ConcurrentSweepGC), MM_AllocationCategory::FIXED, J9_GET_CALLSITE());
40
if (globalGC) {
41
new(globalGC) MM_ConcurrentSweepGC(env);
42
if (!globalGC->initialize(env)) {
43
globalGC->kill(env);
44
globalGC = NULL;
45
}
46
}
47
return globalGC;
48
}
49
50
void
51
MM_ConcurrentSweepGC::internalPreCollect(MM_EnvironmentBase *env, MM_MemorySubSpace *subSpace, MM_AllocateDescription *allocDescription, U_32 gcCode)
52
{
53
/* Finish off any sweep work that was still in progress */
54
MM_ConcurrentSweepScheme *concurrentSweep = (MM_ConcurrentSweepScheme *)_sweepScheme;
55
if(concurrentSweep->isConcurrentSweepActive()) {
56
concurrentSweep->completeSweep(env, ABOUT_TO_GC);
57
}
58
59
MM_ParallelGlobalGC::internalPreCollect(env, subSpace, allocDescription, gcCode);
60
}
61
62
/**
63
* Pay the allocation tax for the mutator.
64
*/
65
void
66
MM_ConcurrentSweepGC::payAllocationTax(MM_EnvironmentBase *env, MM_MemorySubSpace *subspace, MM_MemorySubSpace *baseSubSpace, MM_AllocateDescription *allocDescription)
67
{
68
((MM_ConcurrentSweepScheme *)_sweepScheme)->payAllocationTax(env, baseSubSpace, allocDescription);
69
}
70
71
/**
72
* Replenish a pools free lists to satisfy a given allocate.
73
* The given pool was unable to satisfy an allocation request of (at least) the given size. See if there is work
74
* that can be done to increase the free stores of the pool so that the request can be met.
75
* @note This call is made under the pools allocation lock (or equivalent)
76
* @note Base implementation does no work.
77
* @return True if the pool was replenished with a free entry that can satisfy the size, false otherwise.
78
*/
79
bool
80
MM_ConcurrentSweepGC::replenishPoolForAllocate(MM_EnvironmentBase *env, MM_MemoryPool *memoryPool, UDATA size)
81
{
82
return _sweepScheme->replenishPoolForAllocate(env, memoryPool, size);
83
}
84
85
#endif /* J9VM_GC_CONCURRENT_SWEEP */
86
87