Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/arm/codegen/Instruction.hpp
6004 views
1
/*******************************************************************************
2
* Copyright (c) 2000, 2021 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 TRJ9_INSTRUCTION_INCL
24
#define TRJ9_INSTRUCTION_INCL
25
26
#include "codegen/ARMConditionCode.hpp"
27
#include "codegen/J9Instruction.hpp"
28
29
#include "codegen/RegisterDependency.hpp" // @@@@
30
31
namespace TR
32
{
33
class Instruction;
34
35
class OMR_EXTENSIBLE Instruction : public J9::InstructionConnector
36
{
37
38
public:
39
40
// TODO: need to fix the InstOpCode initialization
41
inline Instruction(TR::Node *node, TR::CodeGenerator *cg);
42
43
inline Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::CodeGenerator *cg);
44
45
inline Instruction(TR::Instruction *precedingInstruction,
46
TR::InstOpCode::Mnemonic op,
47
TR::Node *node,
48
TR::CodeGenerator *cg);
49
50
inline Instruction(TR::InstOpCode::Mnemonic op,
51
TR::Node *node,
52
TR::RegisterDependencyConditions *cond,
53
TR::CodeGenerator *cg);
54
55
inline Instruction(TR::Instruction *precedingInstruction,
56
TR::InstOpCode::Mnemonic op,
57
TR::Node *node,
58
TR::RegisterDependencyConditions *cond,
59
TR::CodeGenerator *cg);
60
};
61
62
}
63
64
#include "codegen/J9Instruction_inlines.hpp"
65
66
TR::Instruction::Instruction(TR::Node *node, TR::CodeGenerator *cg)
67
: J9::InstructionConnector(cg, InstOpCode::bad, node)
68
{
69
self()->setOpCodeValue(TR::InstOpCode::bad);
70
self()->setConditionCode(ARMConditionCodeAL);
71
self()->setDependencyConditions(NULL);
72
}
73
74
TR::Instruction::Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::CodeGenerator *cg)
75
: J9::InstructionConnector(cg, InstOpCode::bad, node)
76
{
77
self()->setOpCodeValue(op);
78
self()->setConditionCode(ARMConditionCodeAL);
79
self()->setDependencyConditions(NULL);
80
}
81
82
TR::Instruction::Instruction(TR::Instruction *precedingInstruction,
83
TR::InstOpCode::Mnemonic op,
84
TR::Node *node,
85
TR::CodeGenerator *cg)
86
: J9::InstructionConnector(cg, precedingInstruction, InstOpCode::bad, node)
87
{
88
self()->setOpCodeValue(op);
89
self()->setConditionCode(ARMConditionCodeAL);
90
self()->setDependencyConditions(NULL);
91
}
92
93
TR::Instruction::Instruction(TR::InstOpCode::Mnemonic op,
94
TR::Node *node,
95
TR::RegisterDependencyConditions *cond,
96
TR::CodeGenerator *cg)
97
: J9::InstructionConnector(cg, InstOpCode::bad, node)
98
{
99
self()->setOpCodeValue(op);
100
self()->setConditionCode(ARMConditionCodeAL);
101
self()->setDependencyConditions(cond);
102
if (cond)
103
cond->incRegisterTotalUseCounts(cg);
104
}
105
106
107
TR::Instruction::Instruction(TR::Instruction *precedingInstruction,
108
TR::InstOpCode::Mnemonic op,
109
TR::Node *node,
110
TR::RegisterDependencyConditions *cond,
111
TR::CodeGenerator *cg)
112
: J9::InstructionConnector(cg, precedingInstruction, InstOpCode::bad, node)
113
{
114
self()->setOpCodeValue(op);
115
self()->setConditionCode(ARMConditionCodeAL);
116
self()->setDependencyConditions(cond);
117
if (cond)
118
cond->incRegisterTotalUseCounts(cg);
119
}
120
121
122
//TODO: these downcasts everywhere need to be removed
123
inline uint32_t * toARMCursor(uint8_t *i) { return (uint32_t *)i; }
124
125
#endif
126
127