Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/aarch64/codegen/MemoryReference.hpp
6004 views
1
/*******************************************************************************
2
* Copyright (c) 2019, 2022 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 TR_MEMORYREFERENCE_INCL
24
#define TR_MEMORYREFERENCE_INCL
25
26
#include "codegen/ARM64ShiftCode.hpp"
27
#include "codegen/J9MemoryReference.hpp"
28
29
namespace TR { class Snippet; }
30
31
namespace TR
32
{
33
34
class OMR_EXTENSIBLE MemoryReference : public J9::MemoryReferenceConnector
35
{
36
private:
37
38
MemoryReference(TR::CodeGenerator *cg)
39
: J9::MemoryReferenceConnector(cg) {}
40
41
MemoryReference(
42
TR::Register *br,
43
TR::Register *ir,
44
TR::CodeGenerator *cg)
45
: J9::MemoryReferenceConnector(br, ir, cg) {}
46
47
MemoryReference(
48
TR::Register *br,
49
TR::Register *ir,
50
uint8_t scale,
51
TR::CodeGenerator *cg)
52
: J9::MemoryReferenceConnector(br, ir, scale, cg) {}
53
54
MemoryReference(
55
TR::Register *br,
56
int32_t disp,
57
TR::CodeGenerator *cg)
58
: J9::MemoryReferenceConnector(br, disp, cg) {}
59
60
MemoryReference(
61
TR::Node *node,
62
TR::CodeGenerator *cg)
63
: J9::MemoryReferenceConnector(node, cg) {}
64
65
MemoryReference(
66
TR::Node *node,
67
TR::SymbolReference *symRef,
68
TR::CodeGenerator *cg)
69
: J9::MemoryReferenceConnector(node, symRef, cg) {}
70
71
public:
72
73
static TR::MemoryReference *create(TR::CodeGenerator *cg);
74
static TR::MemoryReference *createWithIndexReg(TR::CodeGenerator *cg, TR::Register *baseReg, TR::Register *indexReg, uint8_t scale = 0, TR::ARM64ExtendCode extendCode = TR::ARM64ExtendCode::EXT_UXTX);
75
static TR::MemoryReference *createWithDisplacement(TR::CodeGenerator *cg, TR::Register *baseReg, int64_t displacement);
76
static TR::MemoryReference *createWithRootLoadOrStore(TR::CodeGenerator *cg, TR::Node *rootLoadOrStore);
77
static TR::MemoryReference *createWithSymRef(TR::CodeGenerator *cg, TR::Node *node, TR::SymbolReference *symRef);
78
};
79
80
} // TR
81
82
#endif
83
84