Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/aarch64/codegen/Instruction.hpp
6004 views
1
/*******************************************************************************
2
* Copyright (c) 2019, 2020 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/J9Instruction.hpp"
27
#include "codegen/RegisterDependency.hpp"
28
29
namespace TR
30
{
31
class Instruction;
32
33
class OMR_EXTENSIBLE Instruction : public J9::InstructionConnector
34
{
35
public:
36
37
/**
38
* @brief Constructor
39
* @param[in] op : opcode
40
* @param[in] node : node
41
* @param[in] precedingInstruction : preceding instruction
42
* @param[in] cg : CodeGenerator
43
*/
44
Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::Instruction *precedingInstruction,
45
TR::CodeGenerator *cg)
46
: J9::InstructionConnector(cg, precedingInstruction, op, node)
47
{
48
}
49
50
/**
51
* @brief Constructor
52
* @param[in] op : opcode
53
* @param[in] node : node
54
* @param[in] cg : CodeGenerator
55
*/
56
Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::CodeGenerator *cg)
57
: J9::InstructionConnector(cg, op, node)
58
{
59
}
60
61
/**
62
* @brief Constructor
63
* @param[in] op : opcode
64
* @param[in] node : node
65
* @param[in] cond : register dependency conditions
66
* @param[in] precedingInstruction : preceding instruction
67
* @param[in] cg : CodeGenerator
68
*/
69
Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::RegisterDependencyConditions *cond,
70
TR::Instruction *precedingInstruction, TR::CodeGenerator *cg)
71
: J9::InstructionConnector(cg, precedingInstruction, op, node)
72
{
73
self()->setDependencyConditions(cond);
74
if (cond)
75
cond->bookKeepingRegisterUses(self(), cg);
76
}
77
78
/**
79
* @brief Constructor
80
* @param[in] op : opcode
81
* @param[in] node : node
82
* @param[in] cond : register dependency conditions
83
* @param[in] cg : CodeGenerator
84
*/
85
Instruction(TR::InstOpCode::Mnemonic op, TR::Node *node, TR::RegisterDependencyConditions *cond,
86
TR::CodeGenerator *cg)
87
: J9::InstructionConnector(cg, op, node)
88
{
89
self()->setDependencyConditions(cond);
90
if (cond)
91
cond->bookKeepingRegisterUses(self(), cg);
92
}
93
94
};
95
96
} // TR
97
98
#include "codegen/J9Instruction_inlines.hpp"
99
100
/**
101
* @brief Type cast for instruction cursor
102
* @param[in] i : instruction cursor
103
* @return instruction cursor
104
*/
105
inline uint32_t *toARM64Cursor(uint8_t *i) { return (uint32_t *)i; }
106
107
#endif
108
109