Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/gc_verbose_java/VerboseWriterTrace.cpp
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
/* TODO (stefanbu) Tracing story unavailable for OMR, this file should be moved back to verbose */
25
26
#include "j9cfg.h"
27
28
#include "VerboseWriterTrace.hpp"
29
30
#include "EnvironmentBase.hpp"
31
#include "GCExtensions.hpp"
32
33
#define _UTE_STATIC_
34
#include "ut_j9vgc.h"
35
36
MM_VerboseWriterTrace::MM_VerboseWriterTrace(MM_EnvironmentBase *env) :
37
MM_VerboseWriter(VERBOSE_WRITER_TRACE)
38
,_componentLoaded(false)
39
{
40
/* no implementation */
41
}
42
43
/**
44
* Create a new MM_VerboseWriterTrace instance.
45
* @return Pointer to the new MM_VerboseWriterTrace.
46
*/
47
MM_VerboseWriterTrace *
48
MM_VerboseWriterTrace::newInstance(MM_EnvironmentBase *env)
49
{
50
MM_GCExtensions *extensions = MM_GCExtensions::getExtensions(env->getOmrVM());
51
52
MM_VerboseWriterTrace *agent = (MM_VerboseWriterTrace *)extensions->getForge()->allocate(sizeof(MM_VerboseWriterTrace), MM_AllocationCategory::DIAGNOSTIC, J9_GET_CALLSITE());
53
if (agent) {
54
new(agent) MM_VerboseWriterTrace(env);
55
if(!agent->initialize(env)){
56
agent->kill(env);
57
agent = NULL;
58
}
59
}
60
return agent;
61
}
62
63
/**
64
* Initializes the MM_VerboseWriterTrace instance.
65
*/
66
bool
67
MM_VerboseWriterTrace::initialize(MM_EnvironmentBase *env)
68
{
69
return MM_VerboseWriter::initialize(env);
70
}
71
72
/**
73
*/
74
void
75
MM_VerboseWriterTrace::endOfCycle(MM_EnvironmentBase *env)
76
{
77
}
78
79
/**
80
* Closes the agents output stream.
81
*/
82
void
83
MM_VerboseWriterTrace::closeStream(MM_EnvironmentBase *env)
84
{
85
}
86
87
void
88
MM_VerboseWriterTrace::outputString(MM_EnvironmentBase *env, const char* string)
89
{
90
if(!_componentLoaded) {
91
/* If this is the first time in, we have to load the j9vgc trace component.
92
* Can't do it at startup because the trace engine initializes too late */
93
UT_MODULE_LOADED(J9_UTINTERFACE_FROM_VM((J9JavaVM *)env->getLanguageVM()));
94
_componentLoaded = true;
95
}
96
97
/* Call the tracepoint that outputs the line of verbosegc */
98
Trc_VGC_Verbosegc(env->getLanguageVMThread(), string);
99
}
100
101