blob: 02c3d6a47658fa67b4a205d78a1e8d52fc057748 [file] [log] [blame]
Shih-wei Liaod1fec812012-02-13 09:51:10 -08001/*
2 * Copyright (C) 2012 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ART_SRC_COMPILER_LLVM_METHOD_COMPILER_H_
18#define ART_SRC_COMPILER_LLVM_METHOD_COMPILER_H_
19
Logan Chienfca7e872011-12-20 20:08:22 +080020#include "backend_types.h"
Shih-wei Liaod1fec812012-02-13 09:51:10 -080021#include "dex_file.h"
22#include "dex_instruction.h"
TDYa12789f96052012-07-12 20:49:53 -070023#include "greenland/backend_types.h"
Elliott Hughes0f3c5532012-03-30 14:51:51 -070024#include "invoke_type.h"
Shih-wei Liaod1fec812012-02-13 09:51:10 -080025#include "object_utils.h"
TDYa127a4746872012-04-11 23:48:55 -070026#include "runtime_support_func.h"
Shih-wei Liaod1fec812012-02-13 09:51:10 -080027
28#include <llvm/Support/IRBuilder.h>
29
30#include <vector>
31
32#include <stdint.h>
33
34
35namespace art {
36 class ClassLinker;
37 class ClassLoader;
38 class CompiledMethod;
39 class Compiler;
40 class DexCache;
Logan Chien438c4b62012-01-17 16:06:00 +080041 class Field;
Logan Chien4dd96f52012-02-29 01:26:58 +080042 class OatCompilationUnit;
TDYa12789f96052012-07-12 20:49:53 -070043
44 namespace greenland {
45 class InferredRegCategoryMap;
46 }
Shih-wei Liaod1fec812012-02-13 09:51:10 -080047}
48
49
50namespace llvm {
51 class AllocaInst;
52 class BasicBlock;
53 class Function;
54 class FunctionType;
55 class LLVMContext;
56 class Module;
57 class Type;
58}
59
60
61namespace art {
62namespace compiler_llvm {
63
Logan Chien8b977d32012-02-21 19:14:55 +080064class CompilationUnit;
Shih-wei Liaod1fec812012-02-13 09:51:10 -080065class CompilerLLVM;
TDYa127e2102142012-05-26 10:27:38 -070066class DalvikReg;
Shih-wei Liaod1fec812012-02-13 09:51:10 -080067class IRBuilder;
68
69class MethodCompiler {
Shih-wei Liaod1fec812012-02-13 09:51:10 -080070 public:
Logan Chien8b977d32012-02-21 19:14:55 +080071 MethodCompiler(CompilationUnit* cunit,
Logan Chien83426162011-12-09 09:29:50 +080072 Compiler* compiler,
Logan Chien4dd96f52012-02-29 01:26:58 +080073 OatCompilationUnit* oat_compilation_unit);
Shih-wei Liaod1fec812012-02-13 09:51:10 -080074
75 ~MethodCompiler();
76
Logan Chien83426162011-12-09 09:29:50 +080077 CompiledMethod* Compile();
Shih-wei Liaod1fec812012-02-13 09:51:10 -080078
Logan Chienc670a8d2011-12-20 21:25:56 +080079
80 // Code generation helper function
81
82 IRBuilder& GetIRBuilder() const {
83 return irb_;
84 }
85
86
87 // Register helper function
88
TDYa127e2102142012-05-26 10:27:38 -070089 llvm::Value* AllocDalvikReg(RegCategory cat, const std::string& name);
Logan Chienc670a8d2011-12-20 21:25:56 +080090
TDYa127e2102142012-05-26 10:27:38 -070091 llvm::Value* GetShadowFrameEntry(uint32_t reg_idx);
Logan Chienc670a8d2011-12-20 21:25:56 +080092
TDYa1278e950c12012-11-02 09:58:19 -070093 llvm::Value* GetVRegEntry(uint32_t reg_idx);
94
Logan Chienc670a8d2011-12-20 21:25:56 +080095
Shih-wei Liaod1fec812012-02-13 09:51:10 -080096 private:
97 void CreateFunction();
Shih-wei Liaod1fec812012-02-13 09:51:10 -080098 void EmitPrologue();
TDYa1274165a832012-04-03 17:47:16 -070099 void EmitStackOverflowCheck();
Logan Chienc670a8d2011-12-20 21:25:56 +0800100 void EmitPrologueLastBranch();
Logan Chien8dfcbea2012-02-17 18:50:32 +0800101 void EmitPrologueAllocShadowFrame();
Logan Chiend6ececa2011-12-27 16:20:15 +0800102 void EmitPrologueAssignArgRegister();
Shih-wei Liaod1fec812012-02-13 09:51:10 -0800103 void EmitInstructions();
Logan Chien12584172012-07-10 04:07:28 -0700104 void EmitInstruction(uint32_t dex_pc, const Instruction* insn);
Shih-wei Liaod1fec812012-02-13 09:51:10 -0800105
Logan Chien70f94b42011-12-27 17:49:11 +0800106 enum CondBranchKind {
107 kCondBranch_EQ,
108 kCondBranch_NE,
109 kCondBranch_LT,
110 kCondBranch_GE,
111 kCondBranch_GT,
112 kCondBranch_LE,
113 };
114
115 enum IntArithmKind {
116 kIntArithm_Add,
117 kIntArithm_Sub,
118 kIntArithm_Mul,
119 kIntArithm_Div,
120 kIntArithm_Rem,
121 kIntArithm_And,
122 kIntArithm_Or,
123 kIntArithm_Xor,
Logan Chien5539ad02012-04-02 14:36:55 +0800124 };
125
126 enum IntShiftArithmKind {
Logan Chien70f94b42011-12-27 17:49:11 +0800127 kIntArithm_Shl,
128 kIntArithm_Shr,
129 kIntArithm_UShr,
130 };
131
132 enum FPArithmKind {
133 kFPArithm_Add,
134 kFPArithm_Sub,
135 kFPArithm_Mul,
136 kFPArithm_Div,
137 kFPArithm_Rem,
138 };
139
Logan Chien7e7fabc2012-04-10 18:59:11 +0800140 enum InvokeArgFmt {
141 kArgReg,
142 kArgRange,
143 };
144
Logan Chien12584172012-07-10 04:07:28 -0700145#define GEN_INSN_ARGS uint32_t dex_pc, const Instruction* insn
Logan Chien70f94b42011-12-27 17:49:11 +0800146
147 // NOP, PAYLOAD (unreachable) instructions
148 void EmitInsn_Nop(GEN_INSN_ARGS);
149
150 // MOVE, MOVE_RESULT instructions
151 void EmitInsn_Move(GEN_INSN_ARGS, JType jty);
152 void EmitInsn_MoveResult(GEN_INSN_ARGS, JType jty);
153
154 // MOVE_EXCEPTION, THROW instructions
155 void EmitInsn_MoveException(GEN_INSN_ARGS);
156 void EmitInsn_ThrowException(GEN_INSN_ARGS);
157
158 // RETURN instructions
159 void EmitInsn_ReturnVoid(GEN_INSN_ARGS);
160 void EmitInsn_Return(GEN_INSN_ARGS);
161
162 // CONST, CONST_CLASS, CONST_STRING instructions
163 void EmitInsn_LoadConstant(GEN_INSN_ARGS, JType imm_jty);
164 void EmitInsn_LoadConstantString(GEN_INSN_ARGS);
165 void EmitInsn_LoadConstantClass(GEN_INSN_ARGS);
166
167 // MONITOR_ENTER, MONITOR_EXIT instructions
168 void EmitInsn_MonitorEnter(GEN_INSN_ARGS);
169 void EmitInsn_MonitorExit(GEN_INSN_ARGS);
170
171 // CHECK_CAST, INSTANCE_OF instructions
172 void EmitInsn_CheckCast(GEN_INSN_ARGS);
173 void EmitInsn_InstanceOf(GEN_INSN_ARGS);
174
175 // NEW_INSTANCE instructions
176 void EmitInsn_NewInstance(GEN_INSN_ARGS);
177
178 // ARRAY_LEN, NEW_ARRAY, FILLED_NEW_ARRAY, FILL_ARRAY_DATA instructions
179 void EmitInsn_ArrayLength(GEN_INSN_ARGS);
180 void EmitInsn_NewArray(GEN_INSN_ARGS);
181 void EmitInsn_FilledNewArray(GEN_INSN_ARGS, bool is_range);
182 void EmitInsn_FillArrayData(GEN_INSN_ARGS);
183
184 // GOTO, IF_TEST, IF_TESTZ instructions
185 void EmitInsn_UnconditionalBranch(GEN_INSN_ARGS);
186 void EmitInsn_BinaryConditionalBranch(GEN_INSN_ARGS, CondBranchKind cond);
187 void EmitInsn_UnaryConditionalBranch(GEN_INSN_ARGS, CondBranchKind cond);
188
189 // PACKED_SWITCH, SPARSE_SWITCH instrutions
190 void EmitInsn_PackedSwitch(GEN_INSN_ARGS);
191 void EmitInsn_SparseSwitch(GEN_INSN_ARGS);
192
193 // CMPX_FLOAT, CMPX_DOUBLE, CMP_LONG instructions
194 void EmitInsn_FPCompare(GEN_INSN_ARGS, JType fp_jty, bool gt_bias);
195 void EmitInsn_LongCompare(GEN_INSN_ARGS);
196
197 // AGET, APUT instrutions
198 void EmitInsn_AGet(GEN_INSN_ARGS, JType elem_jty);
199 void EmitInsn_APut(GEN_INSN_ARGS, JType elem_jty);
200
201 // IGET, IPUT instructions
202 void EmitInsn_IGet(GEN_INSN_ARGS, JType field_jty);
203 void EmitInsn_IPut(GEN_INSN_ARGS, JType field_jty);
204
205 // SGET, SPUT instructions
206 void EmitInsn_SGet(GEN_INSN_ARGS, JType field_jty);
207 void EmitInsn_SPut(GEN_INSN_ARGS, JType field_jty);
208
209 // INVOKE instructions
Logan Chien7e7fabc2012-04-10 18:59:11 +0800210 void EmitInsn_Invoke(GEN_INSN_ARGS,
211 InvokeType invoke_type,
212 InvokeArgFmt arg_fmt);
213
214 llvm::Value* EmitLoadSDCalleeMethodObjectAddr(uint32_t callee_method_idx);
215
216 llvm::Value* EmitLoadVirtualCalleeMethodObjectAddr(int vtable_idx,
217 llvm::Value* this_addr);
218
219 llvm::Value* EmitCallRuntimeForCalleeMethodObjectAddr(uint32_t callee_method_idx,
220 InvokeType invoke_type,
221 llvm::Value* this_addr,
222 uint32_t dex_pc,
223 bool is_fast_path);
Logan Chien70f94b42011-12-27 17:49:11 +0800224
225 // Unary instructions
226 void EmitInsn_Neg(GEN_INSN_ARGS, JType op_jty);
227 void EmitInsn_Not(GEN_INSN_ARGS, JType op_jty);
228 void EmitInsn_SExt(GEN_INSN_ARGS);
229 void EmitInsn_Trunc(GEN_INSN_ARGS);
230 void EmitInsn_TruncAndSExt(GEN_INSN_ARGS, unsigned N);
231 void EmitInsn_TruncAndZExt(GEN_INSN_ARGS, unsigned N);
232
233 void EmitInsn_FNeg(GEN_INSN_ARGS, JType op_jty);
234 void EmitInsn_IntToFP(GEN_INSN_ARGS, JType src_jty, JType dest_jty);
TDYa127a4746872012-04-11 23:48:55 -0700235 void EmitInsn_FPToInt(GEN_INSN_ARGS, JType src_jty, JType dest_jty,
236 runtime_support::RuntimeId runtime_func_id);
Logan Chien70f94b42011-12-27 17:49:11 +0800237 void EmitInsn_FExt(GEN_INSN_ARGS);
238 void EmitInsn_FTrunc(GEN_INSN_ARGS);
239
240 // Integer binary arithmetic instructions
241 void EmitInsn_IntArithm(GEN_INSN_ARGS, IntArithmKind arithm,
242 JType op_jty, bool is_2addr);
243
244 void EmitInsn_IntArithmImmediate(GEN_INSN_ARGS, IntArithmKind arithm);
245
Logan Chien5539ad02012-04-02 14:36:55 +0800246 void EmitInsn_IntShiftArithm(GEN_INSN_ARGS, IntShiftArithmKind arithm,
247 JType op_jty, bool is_2addr);
248
249 void EmitInsn_IntShiftArithmImmediate(GEN_INSN_ARGS,
250 IntShiftArithmKind arithm);
251
Logan Chien70f94b42011-12-27 17:49:11 +0800252 void EmitInsn_RSubImmediate(GEN_INSN_ARGS);
253
254
255 // Floating-point binary arithmetic instructions
256 void EmitInsn_FPArithm(GEN_INSN_ARGS, FPArithmKind arithm,
257 JType op_jty, bool is_2addr);
258
259#undef GEN_INSN_ARGS
260
TDYa12783bb6622012-04-17 02:20:34 -0700261 // GC card table helper function
262 void EmitMarkGCCard(llvm::Value* value, llvm::Value* target_addr);
Logan Chien0b827102011-12-20 19:46:14 +0800263
Logan Chien8dfcbea2012-02-17 18:50:32 +0800264 // Shadow frame helper function
TDYa127af543472012-05-28 21:49:23 -0700265 void EmitPushShadowFrame(bool is_inline);
Logan Chien8dfcbea2012-02-17 18:50:32 +0800266 void EmitPopShadowFrame();
TDYa127c8dc1012012-04-19 07:03:33 -0700267 void EmitUpdateDexPC(uint32_t dex_pc);
Logan Chien8dfcbea2012-02-17 18:50:32 +0800268
269
Logan Chienbb4d12a2012-02-17 14:10:01 +0800270 // Dex cache code generation helper function
271 llvm::Value* EmitLoadDexCacheAddr(MemberOffset dex_cache_offset);
272
Logan Chienbb4d12a2012-02-17 14:10:01 +0800273 llvm::Value* EmitLoadDexCacheStaticStorageFieldAddr(uint32_t type_idx);
274
275 llvm::Value* EmitLoadDexCacheResolvedTypeFieldAddr(uint32_t type_idx);
276
Logan Chien61c65dc2012-02-29 03:22:30 +0800277 llvm::Value* EmitLoadDexCacheResolvedMethodFieldAddr(uint32_t method_idx);
278
Logan Chienbb4d12a2012-02-17 14:10:01 +0800279 llvm::Value* EmitLoadDexCacheStringFieldAddr(uint32_t string_idx);
280
281
Logan Chien0b827102011-12-20 19:46:14 +0800282 // Code generation helper function
283
284 llvm::Value* EmitLoadMethodObjectAddr();
285
286 llvm::FunctionType* GetFunctionType(uint32_t method_idx, bool is_static);
287
TDYa127526643e2012-05-26 01:01:48 -0700288 void EmitGuard_ExceptionLandingPad(uint32_t dex_pc, bool can_skip_unwind);
Logan Chien5bcc04e2012-01-30 14:15:12 +0800289
290 void EmitBranchExceptionLandingPad(uint32_t dex_pc);
291
TDYa127526643e2012-05-26 01:01:48 -0700292 void EmitGuard_GarbageCollectionSuspend();
Logan Chien924072f2012-01-30 15:07:24 +0800293
Logan Chien2c37e8e2011-12-27 17:58:46 +0800294 llvm::Value* EmitCompareResultSelection(llvm::Value* cmp_eq,
295 llvm::Value* cmp_lt);
296
Logan Chiena78e3c82011-12-27 17:59:35 +0800297 llvm::Value* EmitConditionResult(llvm::Value* lhs,
298 llvm::Value* rhs,
299 CondBranchKind cond);
300
Logan Chienc3f7d962011-12-27 18:13:18 +0800301 llvm::Value* EmitIntArithmResultComputation(uint32_t dex_pc,
302 llvm::Value* lhs,
303 llvm::Value* rhs,
304 IntArithmKind arithm,
305 JType op_jty);
306
TDYa127f8641ce2012-04-02 06:40:40 -0700307 llvm::Value* EmitIntDivRemResultComputation(uint32_t dex_pc,
308 llvm::Value* dividend,
309 llvm::Value* divisor,
310 IntArithmKind arithm,
311 JType op_jty);
312
Logan Chien5539ad02012-04-02 14:36:55 +0800313 llvm::Value* EmitIntShiftArithmResultComputation(uint32_t dex_pc,
314 llvm::Value* lhs,
315 llvm::Value* rhs,
316 IntShiftArithmKind arithm,
317 JType op_jty);
318
Logan Chien76e1c792011-12-27 18:15:01 +0800319 llvm::Value* EmitFPArithmResultComputation(uint32_t dex_pc,
320 llvm::Value* lhs,
321 llvm::Value* rhs,
322 FPArithmKind arithm);
323
Logan Chiena2cc6a32012-01-16 10:38:41 +0800324 llvm::Value* EmitAllocNewArray(uint32_t dex_pc,
325 int32_t length,
326 uint32_t type_idx,
327 bool is_filled_new_array);
328
Logan Chien46fbb412012-02-15 22:29:08 +0800329 llvm::Value* EmitLoadClassObjectAddr(llvm::Value* this_addr);
330
331 llvm::Value* EmitLoadVTableAddr(llvm::Value* class_object_addr);
332
333 llvm::Value* EmitLoadMethodObjectAddrFromVTable(llvm::Value* vtable_addr,
334 uint16_t vtable_index);
335
336 llvm::Value* EmitLoadCodeAddr(llvm::Value* method_object_addr,
337 uint32_t method_idx,
338 bool is_static);
339
Logan Chien61bb6142012-02-03 15:34:53 +0800340 llvm::Value* EmitLoadArrayLength(llvm::Value* array);
341
Logan Chiene27fdbb2012-01-02 23:27:26 +0800342 llvm::Value* EmitArrayGEP(llvm::Value* array_addr,
343 llvm::Value* index_value,
Ian Rogers04ec04e2012-02-28 16:15:33 -0800344 JType elem_jty);
Logan Chiene27fdbb2012-01-02 23:27:26 +0800345
Logan Chien27b30252012-01-14 03:43:35 +0800346 llvm::Value* EmitLoadConstantClass(uint32_t dex_pc, uint32_t type_idx);
347
Logan Chien438c4b62012-01-17 16:06:00 +0800348 llvm::Value* EmitLoadStaticStorage(uint32_t dex_pc, uint32_t type_idx);
349
Logan Chien1a121b92012-02-15 22:23:42 +0800350 void EmitLoadActualParameters(std::vector<llvm::Value*>& args,
351 uint32_t callee_method_idx,
Elliott Hughesadb8c672012-03-06 16:49:32 -0800352 DecodedInstruction const& di,
Logan Chien7e7fabc2012-04-10 18:59:11 +0800353 InvokeArgFmt arg_fmt,
Logan Chien1a121b92012-02-15 22:23:42 +0800354 bool is_static);
355
Logan Chienc3f7d962011-12-27 18:13:18 +0800356 void EmitGuard_DivZeroException(uint32_t dex_pc,
357 llvm::Value* denominator,
358 JType op_jty);
359
Logan Chien61bb6142012-02-03 15:34:53 +0800360 void EmitGuard_NullPointerException(uint32_t dex_pc,
361 llvm::Value* object);
362
Logan Chiene27fdbb2012-01-02 23:27:26 +0800363 void EmitGuard_ArrayIndexOutOfBoundsException(uint32_t dex_pc,
364 llvm::Value* array,
365 llvm::Value* index);
366
367 void EmitGuard_ArrayException(uint32_t dex_pc,
368 llvm::Value* array,
369 llvm::Value* index);
370
TDYa12789f96052012-07-12 20:49:53 -0700371 greenland::RegCategory GetInferredRegCategory(uint32_t dex_pc, uint16_t reg);
Logan Chiena78e3c82011-12-27 17:59:35 +0800372
TDYa12789f96052012-07-12 20:49:53 -0700373 const greenland::InferredRegCategoryMap* GetInferredRegCategoryMap();
TDYa1271d7e5102012-05-13 09:27:05 -0700374
375 bool IsRegCanBeObject(uint16_t reg_idx);
376
Logan Chien48f1d2a2012-01-02 22:49:53 +0800377
Logan Chiend6c239a2011-12-23 15:11:45 +0800378 // Basic block helper functions
379 llvm::BasicBlock* GetBasicBlock(uint32_t dex_pc);
380
381 llvm::BasicBlock* GetNextBasicBlock(uint32_t dex_pc);
382
383 llvm::BasicBlock* CreateBasicBlockWithDexPC(uint32_t dex_pc,
Logan Chien12584172012-07-10 04:07:28 -0700384 const char* postfix = NULL);
Logan Chiend6c239a2011-12-23 15:11:45 +0800385
Logan Chien5bcc04e2012-01-30 14:15:12 +0800386 int32_t GetTryItemOffset(uint32_t dex_pc);
387
388 llvm::BasicBlock* GetLandingPadBasicBlock(uint32_t dex_pc);
389
390 llvm::BasicBlock* GetUnwindBasicBlock();
391
Logan Chienc670a8d2011-12-20 21:25:56 +0800392
393 // Register helper function
394
TDYa127e2102142012-05-26 10:27:38 -0700395 llvm::Value* EmitLoadDalvikReg(uint32_t reg_idx, JType jty, JTypeSpace space);
Logan Chienc670a8d2011-12-20 21:25:56 +0800396
TDYa127e2102142012-05-26 10:27:38 -0700397 llvm::Value* EmitLoadDalvikReg(uint32_t reg_idx, char shorty, JTypeSpace space);
Logan Chienc670a8d2011-12-20 21:25:56 +0800398
399 void EmitStoreDalvikReg(uint32_t reg_idx, JType jty,
TDYa127e2102142012-05-26 10:27:38 -0700400 JTypeSpace space, llvm::Value* new_value);
Logan Chienc670a8d2011-12-20 21:25:56 +0800401
402 void EmitStoreDalvikReg(uint32_t reg_idx, char shorty,
TDYa127e2102142012-05-26 10:27:38 -0700403 JTypeSpace space, llvm::Value* new_value);
Logan Chienc670a8d2011-12-20 21:25:56 +0800404
TDYa127e2102142012-05-26 10:27:38 -0700405 llvm::Value* EmitLoadDalvikRetValReg(JType jty, JTypeSpace space);
Logan Chienc670a8d2011-12-20 21:25:56 +0800406
TDYa127e2102142012-05-26 10:27:38 -0700407 llvm::Value* EmitLoadDalvikRetValReg(char shorty, JTypeSpace space);
Logan Chienc670a8d2011-12-20 21:25:56 +0800408
TDYa127e2102142012-05-26 10:27:38 -0700409 void EmitStoreDalvikRetValReg(JType jty, JTypeSpace space, llvm::Value* new_value);
Logan Chienc670a8d2011-12-20 21:25:56 +0800410
TDYa127e2102142012-05-26 10:27:38 -0700411 void EmitStoreDalvikRetValReg(char shorty, JTypeSpace space, llvm::Value* new_value);
Logan Chien50aaf812012-03-01 21:03:24 +0800412
TDYa127cc1b4c32012-05-15 07:31:37 -0700413 // TODO: Use high-level IR to do this
TDYa12729c0cd12012-05-17 04:51:08 -0700414 bool EmitInlineJavaIntrinsic(const std::string& callee_method_name,
415 const std::vector<llvm::Value*>& args,
416 llvm::BasicBlock* after_invoke);
417
418 bool EmitInlinedStringCharAt(const std::vector<llvm::Value*>& args,
419 llvm::BasicBlock* after_invoke);
420
421 bool EmitInlinedStringLength(const std::vector<llvm::Value*>& args,
422 llvm::BasicBlock* after_invoke);
TDYa127cc1b4c32012-05-15 07:31:37 -0700423
TDYa127d4f82b62012-06-02 21:48:09 -0700424 bool EmitInlinedStringIndexOf(const std::vector<llvm::Value*>& args,
425 llvm::BasicBlock* after_invoke,
426 bool zero_based);
427
428 bool EmitInlinedStringCompareTo(const std::vector<llvm::Value*>& args,
429 llvm::BasicBlock* after_invoke);
430
TDYa127526643e2012-05-26 01:01:48 -0700431 bool IsInstructionDirectToReturn(uint32_t dex_pc);
432
TDYa127cc1b4c32012-05-15 07:31:37 -0700433 struct MethodInfo {
434 int64_t this_reg_idx;
435 bool this_will_not_be_null;
436 bool has_invoke;
437 bool need_shadow_frame_entry;
438 bool need_shadow_frame;
TDYa127af543472012-05-28 21:49:23 -0700439 bool lazy_push_shadow_frame;
TDYa1279eb5f032012-06-10 11:12:28 -0700440 std::vector<bool> set_to_another_object;
TDYa127cc1b4c32012-05-15 07:31:37 -0700441 };
442 MethodInfo method_info_;
443
444 void ComputeMethodInfo();
Logan Chien50aaf812012-03-01 21:03:24 +0800445
446 private:
447 CompilationUnit* cunit_;
448 Compiler* compiler_;
449
Logan Chien12584172012-07-10 04:07:28 -0700450 const DexFile* dex_file_;
Logan Chien12584172012-07-10 04:07:28 -0700451 const DexFile::CodeItem* code_item_;
Logan Chien50aaf812012-03-01 21:03:24 +0800452
453 OatCompilationUnit* oat_compilation_unit_;
Logan Chien50aaf812012-03-01 21:03:24 +0800454
455 uint32_t method_idx_;
456 uint32_t access_flags_;
457
458 llvm::Module* module_;
459 llvm::LLVMContext* context_;
460 IRBuilder& irb_;
461 llvm::Function* func_;
462
463 std::vector<DalvikReg*> regs_;
TDYa127e2102142012-05-26 10:27:38 -0700464 std::vector<llvm::Value*> shadow_frame_entries_;
TDYa1278e950c12012-11-02 09:58:19 -0700465 std::vector<llvm::Value*> vregs_;
TDYa1271d7e5102012-05-13 09:27:05 -0700466 std::vector<int32_t> reg_to_shadow_frame_index_;
Logan Chien50aaf812012-03-01 21:03:24 +0800467 UniquePtr<DalvikReg> retval_reg_;
468
TDYa127b9ff6b12012-05-17 11:14:29 -0700469 llvm::BasicBlock* basic_block_alloca_;
470 llvm::BasicBlock* basic_block_shadow_frame_;
Logan Chien50aaf812012-03-01 21:03:24 +0800471 llvm::BasicBlock* basic_block_reg_arg_init_;
472 std::vector<llvm::BasicBlock*> basic_blocks_;
473
474 std::vector<llvm::BasicBlock*> basic_block_landing_pads_;
475 llvm::BasicBlock* basic_block_unwind_;
Logan Chien50aaf812012-03-01 21:03:24 +0800476
477 llvm::AllocaInst* shadow_frame_;
TDYa1270de52be2012-05-27 20:49:31 -0700478 llvm::Value* old_shadow_frame_;
Logan Chien937105a2012-04-02 02:37:37 +0800479
TDYa127af543472012-05-28 21:49:23 -0700480 llvm::Value* already_pushed_shadow_frame_;
Ian Rogers5438ad82012-10-15 17:22:44 -0700481 uint16_t num_shadow_frame_refs_;
TDYa127af543472012-05-28 21:49:23 -0700482
Logan Chien937105a2012-04-02 02:37:37 +0800483 uint16_t elf_func_idx_;
Shih-wei Liaod1fec812012-02-13 09:51:10 -0800484};
485
486
487} // namespace compiler_llvm
488} // namespace art
489
490#endif // ART_SRC_COMPILER_LLVM_METHOD_COMPILER_H_