Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/runtime/compiler/aarch64/codegen/J9CodeGenerator.hpp
6004 views
1
/*******************************************************************************
2
* Copyright (c) 2019, 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 J9_ARM64_CODEGENERATOR_INCL
24
#define J9_ARM64_CODEGENERATOR_INCL
25
26
/*
27
* The following #define and typedef must appear before any #includes in this file
28
*/
29
#ifndef J9_CODEGENERATOR_CONNECTOR
30
#define J9_CODEGENERATOR_CONNECTOR
31
namespace J9 { namespace ARM64 { class CodeGenerator; } }
32
namespace J9 { typedef J9::ARM64::CodeGenerator CodeGeneratorConnector; }
33
#else
34
#error J9::ARM64::CodeGenerator expected to be a primary connector, but a J9 connector is already defined
35
#endif
36
37
#include "compiler/codegen/J9CodeGenerator.hpp"
38
#include "codegen/LinkageConventionsEnum.hpp"
39
40
namespace TR { class Recompilation; }
41
42
namespace J9
43
{
44
45
namespace ARM64
46
{
47
48
class OMR_EXTENSIBLE CodeGenerator : public J9::CodeGenerator
49
{
50
51
protected:
52
53
CodeGenerator(TR::Compilation *comp);
54
55
public:
56
57
void initialize();
58
59
/**
60
* @brief Allocates recompilation information
61
*/
62
TR::Recompilation *allocateRecompilationInfo();
63
64
/**
65
* @brief Gets or creates a TR::Linkage object
66
* @param[in] lc : linkage convention
67
* @return created linkage object
68
*/
69
TR::Linkage *createLinkage(TR_LinkageConventions lc);
70
71
/**
72
* @brief Encode a BL (or B) instruction to the specified symbol
73
* @param[in] symRef : target symbol
74
* @param[in] cursor : instruction cursor
75
* @param[in] node : node
76
* @param[in] omitLink : use `b` instruction if true
77
* @return Endoded BL (or B) instruction
78
*/
79
uint32_t encodeHelperBranchAndLink(TR::SymbolReference *symRef, uint8_t *cursor, TR::Node *node, bool omitLink = false);
80
81
bool inlineDirectCall(TR::Node *node, TR::Register *&resultReg);
82
83
/**
84
* @brief Generates pre-prologue
85
* @param[in] data : binary encoding data
86
*/
87
void generateBinaryEncodingPrePrologue(TR_ARM64BinaryEncodingData &data);
88
89
/**
90
* @brief Generates switch-to-interpreter pre-prologue
91
* @param[in] cursor : cursor
92
* @param[in] node : node
93
*/
94
TR::Instruction *generateSwitchToInterpreterPrePrologue(TR::Instruction *cursor, TR::Node *node);
95
96
bool supportsDirectJNICallsForAOT() { return true; }
97
98
/**
99
* \brief Determines whether the code generator supports stack allocations
100
*/
101
bool supportsStackAllocations() { return true; }
102
103
/**
104
* @brief Answers whether isInstance inline fast helper is supported
105
* @return true if isInstance inline fast helper is supported
106
*/
107
bool supportsInliningOfIsInstance();
108
109
/**
110
* @brief Answers whether inlining of the specified recognized method should be suppressed
111
* @return true if inlining of the method should be suppressed
112
*/
113
bool suppressInliningOfRecognizedMethod(TR::RecognizedMethod method);
114
};
115
116
}
117
118
}
119
120
#endif
121
122