-
Notifications
You must be signed in to change notification settings - Fork 138
/
Copy pathConstantDataSnippet.hpp
125 lines (100 loc) · 4.22 KB
/
ConstantDataSnippet.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
/*******************************************************************************
* Copyright IBM Corp. and others 2000
*
* 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 https://www.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] https://openjdk.org/legal/assembly-exception.html
*
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0 OR GPL-2.0-only WITH OpenJDK-assembly-exception-1.0
*******************************************************************************/
#ifndef ARMCONSTANTDATASNIPPET_INCL
#define ARMCONSTANTDATASNIPPET_INCL
#include <stddef.h>
#include <stdint.h>
#include "codegen/CodeGenerator.hpp"
#include "codegen/Instruction.hpp"
#include "env/jittypes.h"
#include "env/TRMemory.hpp"
#include "il/DataTypes.hpp"
#include "infra/Array.hpp"
#include "infra/List.hpp"
namespace TR { class Node; }
namespace TR {
template <class T> class ARMConstant
{
TR_Array<TR::Instruction *> _instructionPairs;
int32_t _tocOffset;
T _value;
TR::Node *_node;
bool _isUnloadablePicSite;
public:
TR_ALLOC(TR_Memory::ARMConstant)
ARMConstant(TR::CodeGenerator * cg, T v, TR::Node *n=NULL, bool ps=false) : _instructionPairs(cg->trMemory()), _value(v), _node(n), _isUnloadablePicSite(ps) {};
T getConstantValue() {return _value;}
bool isUnloadablePicSite() {return _isUnloadablePicSite;}
TR_Array<TR::Instruction *> &getRequestors() {return _instructionPairs;}
void addValueRequest(TR::Instruction *n0, TR::Instruction *n1, TR::Instruction *n2, TR::Instruction *n3)
{
if (n0 != NULL)
{
_instructionPairs.add(n0);
_instructionPairs.add(n1);
_instructionPairs.add(n2);
_instructionPairs.add(n3);
n0->setWillBePatched();
n1->setWillBePatched();
n2->setWillBePatched();
n3->setWillBePatched();
}
}
int32_t getTOCOffset() {return _tocOffset;}
void setTOCOffset(int32_t o) {_tocOffset = o;}
TR::Node *getNode() { return _node; }
};
class ARMConstantDataSnippet
{
#if 0
List< TR::ARMConstant<double> > _doubleConstants;
List< TR::ARMConstant<float> > _floatConstants;
#endif
List< TR::ARMConstant<intptr_t> > _addressConstants;
uint8_t *_snippetBinaryStart;
TR::CodeGenerator *_cg;
public:
TR_ALLOC(TR_Memory::ARMConstantDataSnippet)
ARMConstantDataSnippet(TR::CodeGenerator *cg) : _cg(cg), _addressConstants(cg->trMemory())
/* , _doubleConstants(cg->trMemory()), _floatConstants(cg->trMemory()) */
{
};
uint8_t *getSnippetBinaryStart() {return _snippetBinaryStart;}
uint8_t *setSnippetBinaryStart(uint8_t *p) {return _snippetBinaryStart=p;}
int32_t addConstantRequest(void *v,
TR::DataType type,
TR::Instruction *nibble0,
TR::Instruction *nibble1,
TR::Instruction *nibble2,
TR::Instruction *nibble3,
TR::Instruction *nibble4,
TR::Node *node,
bool isUnloadablePicSite);
bool getRequestorsFromNibble(TR::Instruction *nibble, TR::Instruction **q, bool remove);
virtual uint8_t *emitSnippetBody();
virtual uint32_t getLength();
TR::CodeGenerator *cg() {return _cg;}
#ifdef DEBUG
virtual void print(TR::FILE *outFile);
#endif
};
}
#endif