Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/z/codegen/J9MemoryReference.hpp
6004 views
1
/*******************************************************************************
2
* Copyright (c) 2000, 2016 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_Z_MEMORY_REFERENCE_INCL
24
#define J9_Z_MEMORY_REFERENCE_INCL
25
26
/*
27
* The following #define and typedef must appear before any #includes in this file
28
*/
29
#ifndef J9_MEMORY_REFERENCE_CONNECTOR
30
#define J9_MEMORY_REFERENCE_CONNECTOR
31
namespace J9 { namespace Z { class MemoryReference; } }
32
namespace J9 {typedef J9::Z::MemoryReference MemoryReferenceConnector; }
33
#else
34
#error J9::Z::MemoryReference expected to be a primary connector, but a J9 connector is already defined
35
#endif
36
37
#include "codegen/OMRMemoryReference.hpp"
38
39
namespace TR { class Snippet; }
40
41
42
namespace J9
43
{
44
45
namespace Z
46
{
47
48
class OMR_EXTENSIBLE MemoryReference : public OMR::MemoryReferenceConnector
49
{
50
public:
51
MemoryReference(TR::CodeGenerator *cg) : OMR::MemoryReferenceConnector(cg) {}
52
53
MemoryReference(TR::Register *br,
54
int32_t disp,
55
TR::CodeGenerator *cg,
56
const char *name=NULL ) :
57
OMR::MemoryReferenceConnector(br, disp, cg, name) {}
58
59
MemoryReference(TR::Register *br,
60
int32_t disp,
61
TR::SymbolReference *symRef,
62
TR::CodeGenerator *cg) :
63
OMR::MemoryReferenceConnector(br, disp, symRef, cg) {}
64
65
MemoryReference(TR::Register *br,
66
TR::Register *ir,
67
int32_t disp,
68
TR::CodeGenerator *cg) :
69
OMR::MemoryReferenceConnector(br, ir, disp, cg) {}
70
71
MemoryReference(int32_t disp, TR::CodeGenerator *cg, bool isConstantDataSnippet=false) :
72
OMR::MemoryReferenceConnector(disp, cg, isConstantDataSnippet) {}
73
74
MemoryReference(TR::Node *rootLoadOrStore, TR::CodeGenerator *cg, bool canUseRX = false, TR_StorageReference *storageReference=NULL) :
75
OMR::MemoryReferenceConnector(rootLoadOrStore, cg, canUseRX, storageReference) {}
76
77
MemoryReference(TR::Node *addressTree, bool canUseIndex, TR::CodeGenerator *cg) :
78
OMR::MemoryReferenceConnector(addressTree, canUseIndex, cg) {}
79
80
MemoryReference(TR::Node *node, TR::SymbolReference *symRef, TR::CodeGenerator *cg, TR_StorageReference *storageReference=NULL) :
81
OMR::MemoryReferenceConnector(node, symRef, cg, storageReference) {}
82
MemoryReference(TR::Snippet *s, TR::CodeGenerator *cg, TR::Register* base, TR::Node* node) :
83
OMR::MemoryReferenceConnector(s, cg, base, node) {}
84
85
MemoryReference(TR::Snippet *s, TR::Register* indx, int32_t disp, TR::CodeGenerator *cg) :
86
OMR::MemoryReferenceConnector(s, indx, disp, cg) {}
87
88
MemoryReference(MemoryReference& mr, int32_t n, TR::CodeGenerator *cg) :
89
OMR::MemoryReferenceConnector(mr, n, cg) {}
90
91
void addInstrSpecificRelocation(TR::CodeGenerator* cg, TR::Instruction* instr, int32_t disp, uint8_t * cursor);
92
93
94
static bool typeNeedsAlignment(TR::Node *node);
95
96
TR::UnresolvedDataSnippet * createUnresolvedDataSnippet(TR::Node * node, TR::CodeGenerator * cg, TR::SymbolReference * symRef, TR::Register * tempReg, bool isStore);
97
TR::UnresolvedDataSnippet * createUnresolvedDataSnippetForiaload(TR::Node * node, TR::CodeGenerator * cg, TR::SymbolReference * symRef, TR::Register * tempReg, bool & isStore);
98
void createUnresolvedSnippetWithNodeRegister(TR::Node * node, TR::CodeGenerator * cg, TR::SymbolReference * symRef, TR::Register *& writableLiteralPoolRegister);
99
void createUnresolvedDataSnippetForBaseNode(TR::CodeGenerator * cg, TR::Register * writableLiteralPoolRegister);
100
101
void createPatchableDataInLitpool(TR::Node * node, TR::CodeGenerator * cg, TR::Register * tempReg, TR::UnresolvedDataSnippet * uds);
102
103
void incRefCountForOpaquePseudoRegister(TR::Node * node, TR::CodeGenerator * cg, TR::Compilation * comp);
104
105
bool symRefHasTemporaryNegativeOffset();
106
107
void setMemRefAndGetUnresolvedData(TR::Snippet *& snippet);
108
void tryForceFolding(TR::Node *& rootLoadOrStore, TR::CodeGenerator *& cg, TR_StorageReference *& storageReference, TR::SymbolReference *& symRef, TR::Symbol *& symbol,
109
List<TR::Node>& nodesAlreadyEvaluatedBeforeFoldingList);
110
};
111
}
112
113
}
114
115
TR::MemoryReference * reuseS390MemRefFromStorageRef(TR::MemoryReference *baseMR, int32_t offset, TR::Node *node, TR_StorageReference *storageReference, TR::CodeGenerator *cg, bool enforceSSLimits=true);
116
TR::MemoryReference * generateS390MemRefFromStorageRef(TR::Node *node, TR_StorageReference *storageReference, TR::CodeGenerator * cg, bool enforceSSLimits=true, bool isNewTemp=false);
117
TR::MemoryReference * generateS390RightAlignedMemoryReference(TR::Node *node, TR_StorageReference *storageReference, TR::CodeGenerator * cg, bool enforceSSLimits=true, bool isNewTemp=false);
118
TR::MemoryReference * generateS390LeftAlignedMemoryReference(TR::Node *node, TR_StorageReference *storageReference, TR::CodeGenerator * cg, int32_t leftMostByte, bool enforceSSLimits=true, bool isNewTemp=false);
119
120
TR::MemoryReference * reuseS390LeftAlignedMemoryReference(TR::MemoryReference *baseMR, TR::Node *node, TR_StorageReference *storageReference, TR::CodeGenerator *cg, int32_t leftMostByte, bool enforceSSLimits=true);
121
TR::MemoryReference * reuseS390RightAlignedMemoryReference(TR::MemoryReference *baseMR, TR::Node *node, TR_StorageReference *storageReference, TR::CodeGenerator *cg, bool enforceSSLimits=true);
122
123
#endif
124
125