-
Notifications
You must be signed in to change notification settings - Fork 392
/
OMRFunctionCallData.hpp
169 lines (146 loc) · 6 KB
/
OMRFunctionCallData.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
/*******************************************************************************
* Copyright (c) 2021, 2021 IBM Corp. and others
*
* This program and the accompanying materials are made available under
* the terms of the Eclipse Public License 2.0 which accompanies this
* distribution and is available at http://eclipse.org/legal/epl-2.0
* or the Apache License, Version 2.0 which accompanies this distribution
* and is available at https://www.apache.org/licenses/LICENSE-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License, v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception [1] and GNU General Public
* License, version 2 with the OpenJDK Assembly Exception [2].
*
* [1] https://www.gnu.org/software/classpath/license.html
* [2] http://openjdk.java.net/legal/assembly-exception.html
*
* 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
*******************************************************************************/
#ifndef OMR_X86_FUNCTIONCALLDATA_INCL
#define OMR_X86_FUNCTIONCALLDATA_INCL
/*
* The following #define and typedef must appear before any #includes in this file
*/
#ifndef OMR_FUNCTIONCALLDATA_CONNECTOR
#define OMR_FUNCTIONCALLDATA_CONNECTOR
namespace OMR { namespace X86 { class FunctionCallData; } }
namespace OMR { typedef OMR::X86::FunctionCallData FunctionCallDataConnector; }
#endif
#include "compiler/objectfmt/OMRFunctionCallData.hpp"
#include "runtime/Runtime.hpp"
namespace TR { class Instruction; }
namespace TR { class SymbolReference; }
namespace TR { class Node; }
namespace TR { class Register; }
namespace TR { class RegisterDependencyConditions; }
namespace TR { class CodeGenerator; }
namespace OMR
{
namespace X86
{
class OMR_EXTENSIBLE FunctionCallData : public OMR::FunctionCallData
{
public:
/**
* @brief X86 specific implementation of FunctionCallData
*
* @param[in] cg : \c TR::CodeGenerator object
* @param[in] methodSymRef : \c TR::SymbolReference of the function to call
* @param[in] callNode : \c TR::Node this function call is associated with
* @param[in] scratchReg : a scratch register to use to emit the dispatch sequence
* @param[in] targetAddress : a specific function address to call that overrides the
* address in the symbol reference; or 0 if none
* @param[in] regDeps : \c TR::RegisterDependency structure for this call
* @param[in] runtimeHelperIndex : the runtime helper index if calling a helper
* @param[in] prevInstr : \c TR::Instruction of the previous instruction, if any
* @param[in] reloKind : the external relocation kind associated with this function call
* @param[in] adjustsFramePointerBy : if non-zero, the adjustment to be made to the internal
* virtual frame pointer by the instruction to perform the function call
* @param[in] useSymInstruction : if true then use "Sym" form instructions that take a
* \c TR::SymbolReference; if false then use equivalent form instructions without
* the \c TR::SymbolReference parameter
* @param[in] bufferAddress : if non-zero and performing an encoding (rather than emitting
* \c TR::Instructions) then emit the function call at this address
* @param[in] useCall : if true, emit a call instruction; if false, emit a jump instruction
*/
FunctionCallData(
TR::CodeGenerator *cg,
TR::SymbolReference *methodSymRef,
TR::Node *callNode,
TR::Register *scratchReg,
uintptr_t targetAddress,
TR::RegisterDependencyConditions *regDeps,
TR_RuntimeHelper runtimeHelperIndex,
TR::Instruction *prevInstr,
int32_t reloKind,
int32_t adjustsFramePointerBy,
bool useSymInstruction,
uint8_t *bufferAddress,
bool useCall) :
OMR::FunctionCallData(cg, methodSymRef, callNode, bufferAddress),
targetAddress(targetAddress),
scratchReg(scratchReg),
regDeps(regDeps),
prevInstr(prevInstr),
reloKind(reloKind),
useSymInstruction(useSymInstruction),
runtimeHelperIndex(runtimeHelperIndex),
adjustsFramePointerBy(adjustsFramePointerBy),
useCall(useCall),
out_materializeTargetAddressInstr(NULL),
out_callInstr(NULL) {}
/**
* If a non-zero targetAddress is provided, use that as the address of the function to call
*/
uintptr_t targetAddress;
/**
* If set, an available scratch register to use during the call sequence.
*
* If NULL, no scratch register is available
*/
TR::Register *scratchReg;
/**
* The \c TR::RegisterDependencyConditions to apply at this call site
*/
TR::RegisterDependencyConditions *regDeps;
/**
* The instruction just prior to the sequence to emit a call to some function
*/
TR::Instruction *prevInstr;
/**
* If an intermediate instruction was used to materialize the address of the
* function to call then it may be set in this field.
*/
TR::Instruction *out_materializeTargetAddressInstr;
/**
* The call instruction that was generated to dispatch to the target function.
*/
TR::Instruction *out_callInstr;
/**
* Should a CALL instruction be used? If false then a JMP instruction will
* be emitted instead.
*/
bool useCall;
/**
* For applicable call sites, use an instruction form that has a \c TR::SymbolReference
* rather than one that doesn't.
*/
bool useSymInstruction;
/**
* The relocation kind to apply at this call site
*/
int32_t reloKind;
/**
* Number of bytes to adjust the VFP by at this call site
*/
int32_t adjustsFramePointerBy;
/**
* If calling a helper function, the index of the helper function to call
*/
TR_RuntimeHelper runtimeHelperIndex;
};
}
}
#endif