author | mdoerr |
Tue, 05 Nov 2019 11:53:46 +0100 | |
changeset 58932 | 8623f75be895 |
parent 58051 | 505e28fe1769 |
permissions | -rw-r--r-- |
1 | 1 |
/* |
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
47216
diff
changeset
|
2 |
* Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved. |
1 | 3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
* |
|
5 |
* This code is free software; you can redistribute it and/or modify it |
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
|
7 |
* published by the Free Software Foundation. |
|
8 |
* |
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
|
13 |
* accompanied this code). |
|
14 |
* |
|
15 |
* You should have received a copy of the GNU General Public License version |
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
18 |
* |
|
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5353
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5353
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5353
diff
changeset
|
21 |
* questions. |
1 | 22 |
* |
23 |
*/ |
|
24 |
||
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
47216
diff
changeset
|
25 |
#ifndef SHARE_C1_C1_COMPILATION_HPP |
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
47216
diff
changeset
|
26 |
#define SHARE_C1_C1_COMPILATION_HPP |
7397 | 27 |
|
28 |
#include "ci/ciEnv.hpp" |
|
16611 | 29 |
#include "ci/ciMethodData.hpp" |
7397 | 30 |
#include "code/exceptionHandlerTable.hpp" |
35576 | 31 |
#include "compiler/compilerDirectives.hpp" |
7397 | 32 |
#include "memory/resourceArea.hpp" |
16611 | 33 |
#include "runtime/deoptimization.hpp" |
7397 | 34 |
|
1 | 35 |
class CompilationResourceObj; |
36 |
class XHandlers; |
|
37 |
class ExceptionInfo; |
|
38 |
class DebugInformationRecorder; |
|
39 |
class FrameMap; |
|
40 |
class IR; |
|
41 |
class IRScope; |
|
42 |
class Instruction; |
|
43 |
class LinearScan; |
|
44 |
class OopMap; |
|
45 |
class LIR_Emitter; |
|
46 |
class LIR_Assembler; |
|
47 |
class CodeEmitInfo; |
|
48 |
class ciEnv; |
|
49 |
class ciMethod; |
|
50 |
class ValueStack; |
|
51 |
class LIR_OprDesc; |
|
52 |
class C1_MacroAssembler; |
|
53 |
class CFGPrinter; |
|
46526 | 54 |
class CFGPrinterOutput; |
1 | 55 |
typedef LIR_OprDesc* LIR_Opr; |
56 |
||
38031
e0b822facc03
8149374: Replace C1-specific collection classes with universal collection classes
fzhinkin
parents:
35576
diff
changeset
|
57 |
typedef GrowableArray<BasicType> BasicTypeArray; |
e0b822facc03
8149374: Replace C1-specific collection classes with universal collection classes
fzhinkin
parents:
35576
diff
changeset
|
58 |
typedef GrowableArray<BasicType> BasicTypeList; |
e0b822facc03
8149374: Replace C1-specific collection classes with universal collection classes
fzhinkin
parents:
35576
diff
changeset
|
59 |
typedef GrowableArray<ExceptionInfo*> ExceptionInfoList; |
1 | 60 |
|
61 |
class Compilation: public StackObj { |
|
62 |
friend class CompilationResourceObj; |
|
63 |
private: |
|
64 |
// compilation specifics |
|
5707 | 65 |
Arena* _arena; |
66 |
int _next_id; |
|
67 |
int _next_block_id; |
|
1 | 68 |
AbstractCompiler* _compiler; |
33451
0712796e4039
8137167: JEP165: Compiler Control: Implementation task
neliasso
parents:
24442
diff
changeset
|
69 |
DirectiveSet* _directive; |
1 | 70 |
ciEnv* _env; |
13964 | 71 |
CompileLog* _log; |
1 | 72 |
ciMethod* _method; |
73 |
int _osr_bci; |
|
74 |
IR* _hir; |
|
75 |
int _max_spills; |
|
76 |
FrameMap* _frame_map; |
|
77 |
C1_MacroAssembler* _masm; |
|
78 |
bool _has_exception_handlers; |
|
79 |
bool _has_fpu_code; |
|
80 |
bool _has_unsafe_access; |
|
6453 | 81 |
bool _would_profile; |
6186
7eef4cda471c
6975855: don't emit deopt MH handler in C1 if not required
twisti
parents:
6176
diff
changeset
|
82 |
bool _has_method_handle_invokes; // True if this method has MethodHandle invokes. |
35071
a0910b1d3e0d
8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents:
34220
diff
changeset
|
83 |
bool _has_reserved_stack_access; |
1 | 84 |
const char* _bailout_msg; |
85 |
ExceptionInfoList* _exception_info_list; |
|
86 |
ExceptionHandlerTable _exception_handler_table; |
|
87 |
ImplicitExceptionTable _implicit_exception_table; |
|
88 |
LinearScan* _allocator; |
|
89 |
CodeOffsets _offsets; |
|
90 |
CodeBuffer _code; |
|
16611 | 91 |
bool _has_access_indexed; |
24018
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
92 |
int _interpreter_frame_size; // Stack space needed in case of a deoptimization |
1 | 93 |
|
94 |
// compilation helpers |
|
95 |
void initialize(); |
|
96 |
void build_hir(); |
|
97 |
void emit_lir(); |
|
98 |
||
99 |
void emit_code_epilog(LIR_Assembler* assembler); |
|
100 |
int emit_code_body(); |
|
101 |
||
102 |
int compile_java_method(); |
|
103 |
void install_code(int frame_size); |
|
104 |
void compile_method(); |
|
105 |
||
106 |
void generate_exception_handler_table(); |
|
107 |
||
108 |
ExceptionInfoList* exception_info_list() const { return _exception_info_list; } |
|
109 |
ExceptionHandlerTable* exception_handler_table() { return &_exception_handler_table; } |
|
110 |
||
111 |
LinearScan* allocator() { return _allocator; } |
|
112 |
void set_allocator(LinearScan* allocator) { _allocator = allocator; } |
|
113 |
||
114 |
Instruction* _current_instruction; // the instruction currently being processed |
|
115 |
#ifndef PRODUCT |
|
116 |
Instruction* _last_instruction_printed; // the last instruction printed during traversal |
|
46526 | 117 |
CFGPrinterOutput* _cfg_printer_output; |
1 | 118 |
#endif // PRODUCT |
119 |
||
120 |
public: |
|
121 |
// creation |
|
5707 | 122 |
Compilation(AbstractCompiler* compiler, ciEnv* env, ciMethod* method, |
33451
0712796e4039
8137167: JEP165: Compiler Control: Implementation task
neliasso
parents:
24442
diff
changeset
|
123 |
int osr_bci, BufferBlob* buffer_blob, DirectiveSet* directive); |
1 | 124 |
~Compilation(); |
125 |
||
5707 | 126 |
|
127 |
static Compilation* current() { |
|
128 |
return (Compilation*) ciEnv::current()->compiler_data(); |
|
129 |
} |
|
1 | 130 |
|
131 |
// accessors |
|
132 |
ciEnv* env() const { return _env; } |
|
33451
0712796e4039
8137167: JEP165: Compiler Control: Implementation task
neliasso
parents:
24442
diff
changeset
|
133 |
DirectiveSet* directive() const { return _directive; } |
13964 | 134 |
CompileLog* log() const { return _log; } |
1 | 135 |
AbstractCompiler* compiler() const { return _compiler; } |
136 |
bool has_exception_handlers() const { return _has_exception_handlers; } |
|
137 |
bool has_fpu_code() const { return _has_fpu_code; } |
|
138 |
bool has_unsafe_access() const { return _has_unsafe_access; } |
|
13883
6979b9850feb
7196199: java/text/Bidi/Bug6665028.java failed: Bidi run count incorrect
kvn
parents:
8921
diff
changeset
|
139 |
int max_vector_size() const { return 0; } |
1 | 140 |
ciMethod* method() const { return _method; } |
141 |
int osr_bci() const { return _osr_bci; } |
|
142 |
bool is_osr_compile() const { return osr_bci() >= 0; } |
|
143 |
IR* hir() const { return _hir; } |
|
144 |
int max_spills() const { return _max_spills; } |
|
145 |
FrameMap* frame_map() const { return _frame_map; } |
|
146 |
CodeBuffer* code() { return &_code; } |
|
147 |
C1_MacroAssembler* masm() const { return _masm; } |
|
148 |
CodeOffsets* offsets() { return &_offsets; } |
|
5707 | 149 |
Arena* arena() { return _arena; } |
16611 | 150 |
bool has_access_indexed() { return _has_access_indexed; } |
5707 | 151 |
|
152 |
// Instruction ids |
|
153 |
int get_next_id() { return _next_id++; } |
|
154 |
int number_of_instructions() const { return _next_id; } |
|
155 |
||
156 |
// BlockBegin ids |
|
157 |
int get_next_block_id() { return _next_block_id++; } |
|
158 |
int number_of_blocks() const { return _next_block_id; } |
|
1 | 159 |
|
160 |
// setters |
|
161 |
void set_has_exception_handlers(bool f) { _has_exception_handlers = f; } |
|
162 |
void set_has_fpu_code(bool f) { _has_fpu_code = f; } |
|
163 |
void set_has_unsafe_access(bool f) { _has_unsafe_access = f; } |
|
6453 | 164 |
void set_would_profile(bool f) { _would_profile = f; } |
16611 | 165 |
void set_has_access_indexed(bool f) { _has_access_indexed = f; } |
1 | 166 |
// Add a set of exception handlers covering the given PC offset |
167 |
void add_exception_handlers_for_pco(int pco, XHandlers* exception_handlers); |
|
168 |
// Statistics gathering |
|
169 |
void notice_inlined_method(ciMethod* method); |
|
170 |
||
6186
7eef4cda471c
6975855: don't emit deopt MH handler in C1 if not required
twisti
parents:
6176
diff
changeset
|
171 |
// JSR 292 |
7eef4cda471c
6975855: don't emit deopt MH handler in C1 if not required
twisti
parents:
6176
diff
changeset
|
172 |
bool has_method_handle_invokes() const { return _has_method_handle_invokes; } |
7eef4cda471c
6975855: don't emit deopt MH handler in C1 if not required
twisti
parents:
6176
diff
changeset
|
173 |
void set_has_method_handle_invokes(bool z) { _has_method_handle_invokes = z; } |
7eef4cda471c
6975855: don't emit deopt MH handler in C1 if not required
twisti
parents:
6176
diff
changeset
|
174 |
|
35071
a0910b1d3e0d
8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents:
34220
diff
changeset
|
175 |
bool has_reserved_stack_access() const { return _has_reserved_stack_access; } |
a0910b1d3e0d
8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents:
34220
diff
changeset
|
176 |
void set_has_reserved_stack_access(bool z) { _has_reserved_stack_access = z; } |
a0910b1d3e0d
8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents:
34220
diff
changeset
|
177 |
|
1 | 178 |
DebugInformationRecorder* debug_info_recorder() const; // = _env->debug_info(); |
179 |
Dependencies* dependency_recorder() const; // = _env->dependencies() |
|
180 |
ImplicitExceptionTable* implicit_exception_table() { return &_implicit_exception_table; } |
|
181 |
||
182 |
Instruction* current_instruction() const { return _current_instruction; } |
|
183 |
Instruction* set_current_instruction(Instruction* instr) { |
|
184 |
Instruction* previous = _current_instruction; |
|
185 |
_current_instruction = instr; |
|
186 |
return previous; |
|
187 |
} |
|
188 |
||
189 |
#ifndef PRODUCT |
|
190 |
void maybe_print_current_instruction(); |
|
46526 | 191 |
CFGPrinterOutput* cfg_printer_output() { |
192 |
guarantee(_cfg_printer_output != NULL, "CFG printer output not initialized"); |
|
193 |
return _cfg_printer_output; |
|
194 |
} |
|
1 | 195 |
#endif // PRODUCT |
196 |
||
197 |
// error handling |
|
198 |
void bailout(const char* msg); |
|
199 |
bool bailed_out() const { return _bailout_msg != NULL; } |
|
200 |
const char* bailout_msg() const { return _bailout_msg; } |
|
201 |
||
5707 | 202 |
static int desired_max_code_buffer_size() { |
40071
53e12df44b7b
8160245: C1: Clean up platform #defines in c1_LIR.hpp.
goetz
parents:
38031
diff
changeset
|
203 |
return (int)NMethodSizeLimit; // default 64K |
5707 | 204 |
} |
205 |
static int desired_max_constant_size() { |
|
7100 | 206 |
return desired_max_code_buffer_size() / 10; |
5707 | 207 |
} |
208 |
||
7722
f0bd3dd3192f
7009268: guarantee(middle - slop > start) failed: need enough space to divide up
bobv
parents:
7397
diff
changeset
|
209 |
static bool setup_code_buffer(CodeBuffer* cb, int call_stub_estimate); |
5707 | 210 |
|
1 | 211 |
// timers |
212 |
static void print_timers(); |
|
213 |
||
214 |
#ifndef PRODUCT |
|
215 |
// debugging support. |
|
216 |
// produces a file named c1compileonly in the current directory with |
|
217 |
// directives to compile only the current method and it's inlines. |
|
218 |
// The file can be passed to the command line option -XX:Flags=<filename> |
|
219 |
void compile_only_this_method(); |
|
220 |
void compile_only_this_scope(outputStream* st, IRScope* scope); |
|
221 |
void exclude_this_method(); |
|
222 |
#endif // PRODUCT |
|
6453 | 223 |
|
224 |
bool is_profiling() { |
|
225 |
return env()->comp_level() == CompLevel_full_profile || |
|
226 |
env()->comp_level() == CompLevel_limited_profile; |
|
227 |
} |
|
228 |
bool count_invocations() { return is_profiling(); } |
|
229 |
bool count_backedges() { return is_profiling(); } |
|
230 |
||
231 |
// Helpers for generation of profile information |
|
232 |
bool profile_branches() { |
|
233 |
return env()->comp_level() == CompLevel_full_profile && |
|
234 |
C1UpdateMethodData && C1ProfileBranches; |
|
235 |
} |
|
236 |
bool profile_calls() { |
|
237 |
return env()->comp_level() == CompLevel_full_profile && |
|
238 |
C1UpdateMethodData && C1ProfileCalls; |
|
239 |
} |
|
240 |
bool profile_inlined_calls() { |
|
241 |
return profile_calls() && C1ProfileInlinedCalls; |
|
242 |
} |
|
243 |
bool profile_checkcasts() { |
|
244 |
return env()->comp_level() == CompLevel_full_profile && |
|
245 |
C1UpdateMethodData && C1ProfileCheckcasts; |
|
246 |
} |
|
21095
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
247 |
bool profile_parameters() { |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
248 |
return env()->comp_level() == CompLevel_full_profile && |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
249 |
C1UpdateMethodData && MethodData::profile_parameters(); |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
250 |
} |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
251 |
bool profile_arguments() { |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
252 |
return env()->comp_level() == CompLevel_full_profile && |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
253 |
C1UpdateMethodData && MethodData::profile_arguments(); |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
254 |
} |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
255 |
bool profile_return() { |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
256 |
return env()->comp_level() == CompLevel_full_profile && |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
257 |
C1UpdateMethodData && MethodData::profile_return(); |
1a04f7b3946e
8026251: New type profiling points: parameters to methods
roland
parents:
20702
diff
changeset
|
258 |
} |
24442
4d4ae31dea26
8032463: VirtualDispatch test timeout with DeoptimizeALot
iveresov
parents:
24018
diff
changeset
|
259 |
bool age_code() const { |
4d4ae31dea26
8032463: VirtualDispatch test timeout with DeoptimizeALot
iveresov
parents:
24018
diff
changeset
|
260 |
return _method->profile_aging(); |
4d4ae31dea26
8032463: VirtualDispatch test timeout with DeoptimizeALot
iveresov
parents:
24018
diff
changeset
|
261 |
} |
4d4ae31dea26
8032463: VirtualDispatch test timeout with DeoptimizeALot
iveresov
parents:
24018
diff
changeset
|
262 |
|
16611 | 263 |
// will compilation make optimistic assumptions that might lead to |
264 |
// deoptimization and that the runtime will account for? |
|
265 |
bool is_optimistic() const { |
|
266 |
return !TieredCompilation && |
|
267 |
(RangeCheckElimination || UseLoopInvariantCodeMotion) && |
|
268 |
method()->method_data()->trap_count(Deoptimization::Reason_none) == 0; |
|
269 |
} |
|
20702
bbe0fcde6e13
8023657: New type profiling points: arguments to call
roland
parents:
19696
diff
changeset
|
270 |
|
bbe0fcde6e13
8023657: New type profiling points: arguments to call
roland
parents:
19696
diff
changeset
|
271 |
ciKlass* cha_exact_type(ciType* type); |
22243 | 272 |
|
273 |
// Dump inlining replay data to the stream. |
|
274 |
void dump_inline_data(outputStream* out) { /* do nothing now */ } |
|
24018
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
275 |
|
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
276 |
// How much stack space would the interpreter need in case of a |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
277 |
// deoptimization (worst case) |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
278 |
void update_interpreter_frame_size(int size) { |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
279 |
if (_interpreter_frame_size < size) { |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
280 |
_interpreter_frame_size = size; |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
281 |
} |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
282 |
} |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
283 |
|
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
284 |
int interpreter_frame_size() const { |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
285 |
return _interpreter_frame_size; |
77b156916bab
8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents:
22243
diff
changeset
|
286 |
} |
1 | 287 |
}; |
288 |
||
289 |
||
290 |
// Macro definitions for unified bailout-support |
|
291 |
// The methods bailout() and bailed_out() are present in all classes |
|
292 |
// that might bailout, but forward all calls to Compilation |
|
293 |
#define BAILOUT(msg) { bailout(msg); return; } |
|
294 |
#define BAILOUT_(msg, res) { bailout(msg); return res; } |
|
295 |
||
296 |
#define CHECK_BAILOUT() { if (bailed_out()) return; } |
|
297 |
#define CHECK_BAILOUT_(res) { if (bailed_out()) return res; } |
|
298 |
||
58051
505e28fe1769
8230669: [s390] C1: assert(is_bound() || is_unused()) failed: Label was never bound to a location, but it was used as a jmp target
mdoerr
parents:
53244
diff
changeset
|
299 |
// BAILOUT check with reset of bound labels |
505e28fe1769
8230669: [s390] C1: assert(is_bound() || is_unused()) failed: Label was never bound to a location, but it was used as a jmp target
mdoerr
parents:
53244
diff
changeset
|
300 |
#define CHECK_BAILOUT1(l1) { if (bailed_out()) { l1.reset(); return; } } |
505e28fe1769
8230669: [s390] C1: assert(is_bound() || is_unused()) failed: Label was never bound to a location, but it was used as a jmp target
mdoerr
parents:
53244
diff
changeset
|
301 |
#define CHECK_BAILOUT2(l1, l2) { if (bailed_out()) { l1.reset(); l2.reset(); return; } } |
505e28fe1769
8230669: [s390] C1: assert(is_bound() || is_unused()) failed: Label was never bound to a location, but it was used as a jmp target
mdoerr
parents:
53244
diff
changeset
|
302 |
#define CHECK_BAILOUT3(l1, l2, l3) { if (bailed_out()) { l1.reset(); l2.reset(); l3.reset(); return; } } |
505e28fe1769
8230669: [s390] C1: assert(is_bound() || is_unused()) failed: Label was never bound to a location, but it was used as a jmp target
mdoerr
parents:
53244
diff
changeset
|
303 |
|
1 | 304 |
|
305 |
class InstructionMark: public StackObj { |
|
306 |
private: |
|
307 |
Compilation* _compilation; |
|
308 |
Instruction* _previous; |
|
309 |
||
310 |
public: |
|
311 |
InstructionMark(Compilation* compilation, Instruction* instr) { |
|
312 |
_compilation = compilation; |
|
313 |
_previous = _compilation->set_current_instruction(instr); |
|
314 |
} |
|
315 |
~InstructionMark() { |
|
316 |
_compilation->set_current_instruction(_previous); |
|
317 |
} |
|
318 |
}; |
|
319 |
||
320 |
||
321 |
//---------------------------------------------------------------------- |
|
322 |
// Base class for objects allocated by the compiler in the compilation arena |
|
323 |
class CompilationResourceObj ALLOCATION_SUPER_CLASS_SPEC { |
|
324 |
public: |
|
19696
bd5a0131bde1
8021954: VM SIGSEGV during classloading on MacOS; hs_err_pid file produced
coleenp
parents:
16611
diff
changeset
|
325 |
void* operator new(size_t size) throw() { return Compilation::current()->arena()->Amalloc(size); } |
bd5a0131bde1
8021954: VM SIGSEGV during classloading on MacOS; hs_err_pid file produced
coleenp
parents:
16611
diff
changeset
|
326 |
void* operator new(size_t size, Arena* arena) throw() { |
5707 | 327 |
return arena->Amalloc(size); |
328 |
} |
|
1 | 329 |
void operator delete(void* p) {} // nothing to do |
330 |
}; |
|
331 |
||
332 |
||
333 |
//---------------------------------------------------------------------- |
|
334 |
// Class for aggregating exception handler information. |
|
335 |
||
336 |
// Effectively extends XHandlers class with PC offset of |
|
337 |
// potentially exception-throwing instruction. |
|
338 |
// This class is used at the end of the compilation to build the |
|
339 |
// ExceptionHandlerTable. |
|
340 |
class ExceptionInfo: public CompilationResourceObj { |
|
341 |
private: |
|
342 |
int _pco; // PC of potentially exception-throwing instruction |
|
343 |
XHandlers* _exception_handlers; // flat list of exception handlers covering this PC |
|
344 |
||
345 |
public: |
|
346 |
ExceptionInfo(int pco, XHandlers* exception_handlers) |
|
347 |
: _pco(pco) |
|
348 |
, _exception_handlers(exception_handlers) |
|
349 |
{ } |
|
350 |
||
351 |
int pco() { return _pco; } |
|
352 |
XHandlers* exception_handlers() { return _exception_handlers; } |
|
353 |
}; |
|
7397 | 354 |
|
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
47216
diff
changeset
|
355 |
#endif // SHARE_C1_C1_COMPILATION_HPP |