Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/z/codegen/J9UnresolvedDataSnippet.hpp
6004 views
1
/*******************************************************************************
2
* Copyright (c) 2000, 2019 IBM Corp. and others
3
*
4
* This program and the accompanying materials are made available under
5
* the terms of the Eclipse Public License 2.0 which accompanies this
6
* distribution and is available at https://www.eclipse.org/legal/epl-2.0/
7
* or the Apache License, Version 2.0 which accompanies this distribution and
8
* is available at https://www.apache.org/licenses/LICENSE-2.0.
9
*
10
* This Source Code may also be made available under the following
11
* Secondary Licenses when the conditions for such availability set
12
* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU
13
* General Public License, version 2 with the GNU Classpath
14
* Exception [1] and GNU General Public License, version 2 with the
15
* OpenJDK Assembly Exception [2].
16
*
17
* [1] https://www.gnu.org/software/classpath/license.html
18
* [2] http://openjdk.java.net/legal/assembly-exception.html
19
*
20
* 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
21
*******************************************************************************/
22
23
#ifndef J9_ZUNRESOLVEDDATASNIPPET_INCL
24
#define J9_ZUNRESOLVEDDATASNIPPET_INCL
25
26
/*
27
* The following #define and typedef must appear before any #includes in this file
28
*/
29
#ifndef J9_UNRESOLVEDDATASNIPPET_CONNECTOR
30
#define J9_UNRESOLVEDDATASNIPPET_CONNECTOR
31
namespace J9 { namespace Z { class UnresolvedDataSnippet; } }
32
namespace J9 { typedef J9::Z::UnresolvedDataSnippet UnresolvedDataSnippetConnector; }
33
#else
34
#error J9::Z::UnresolvedDataSnippet expected to be a primary connector, but a J9 connector is already defined
35
#endif
36
37
#include "compiler/codegen/J9UnresolvedDataSnippet.hpp"
38
39
#include <stdint.h>
40
#include "codegen/Snippet.hpp"
41
#include "il/SymbolReference.hpp"
42
43
namespace TR { class S390WritableDataSnippet; }
44
namespace TR { class CodeGenerator; }
45
namespace TR { class Instruction; }
46
namespace TR { class MemoryReference; }
47
namespace TR { class Node; }
48
namespace TR { class Symbol; }
49
50
namespace J9
51
{
52
53
namespace Z
54
{
55
56
class UnresolvedDataSnippet : public J9::UnresolvedDataSnippet
57
{
58
/** _branchInstruction is actually the instruction which branch to the UDS. */
59
TR::Instruction *_branchInstruction;
60
TR::SymbolReference *_dataSymbolReference;
61
TR::MemoryReference *_memoryReference;
62
bool _isStore;
63
64
/**
65
*_dataReferenceInstruction is the instruction
66
* that references it. The address of this will be resolved
67
* when emitting the snippet code.
68
*/
69
TR::Instruction *_dataReferenceInstruction;
70
TR::S390WritableDataSnippet *_unresolvedData;
71
uint8_t *_literalPoolPatchAddress;
72
uint8_t *_literalPoolSlot; ///< For trace file generation
73
74
public:
75
76
UnresolvedDataSnippet(TR::CodeGenerator *, TR::Node *, TR::SymbolReference *s, bool isStore, bool canCauseGC);
77
78
virtual Kind getKind() { return IsUnresolvedData; }
79
80
TR::Instruction *getBranchInstruction() {return _branchInstruction;}
81
TR::Instruction *setBranchInstruction(TR::Instruction *i)
82
{
83
return _branchInstruction = i;
84
}
85
86
TR::Instruction *getDataReferenceInstruction() {return _dataReferenceInstruction;}
87
88
TR::Instruction *setDataReferenceInstruction(TR::Instruction *i);
89
90
TR::SymbolReference *getDataSymbolReference() {return _dataSymbolReference;}
91
92
/** Create Unresolved Data in writable data area */
93
TR::S390WritableDataSnippet *createUnresolvedData(TR::CodeGenerator *cg, TR::Node * n);
94
95
TR::S390WritableDataSnippet *getUnresolvedData()
96
{
97
return _unresolvedData;
98
}
99
100
uint8_t *getLiteralPoolPatchAddress() { return _literalPoolPatchAddress;}
101
uint8_t *setLiteralPoolPatchAddress(uint8_t *cursor)
102
{
103
return _literalPoolPatchAddress = cursor;
104
}
105
uint8_t *getLiteralPoolSlot() { return _literalPoolSlot;}
106
uint8_t *setLiteralPoolSlot(uint8_t *cursor)
107
{
108
return _literalPoolSlot = cursor;
109
}
110
111
TR::Symbol *getDataSymbol() {return _dataSymbolReference->getSymbol();}
112
TR::MemoryReference *getMemoryReference() {return _memoryReference;}
113
TR::MemoryReference *setMemoryReference(TR::MemoryReference *mr)
114
{return _memoryReference = mr;}
115
116
bool isInstanceData();
117
118
bool resolveForStore() {return _isStore;}
119
virtual uint8_t *getAddressOfDataReference();
120
121
virtual uint8_t *emitSnippetBody();
122
123
virtual uint32_t getLength(int32_t estimatedSnippetStart);
124
};
125
126
}
127
128
}
129
130
#endif
131
132