blob: c30ba3d24d9c192e8f48a74858462d3e0f57f5da [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"
Elliott Hughes0f3c5532012-03-30 14:51:51 -070023#include "invoke_type.h"
Shih-wei Liaod1fec812012-02-13 09:51:10 -080024#include "object_utils.h"
TDYa127a4746872012-04-11 23:48:55 -070025#include "runtime_support_func.h"
Shih-wei Liaod1fec812012-02-13 09:51:10 -080026
27#include <llvm/Support/IRBuilder.h>
28
29#include <vector>
30
31#include <stdint.h>
32
33
34namespace art {
35 class ClassLinker;
36 class ClassLoader;
37 class CompiledMethod;
38 class Compiler;
39 class DexCache;
Logan Chien438c4b62012-01-17 16:06:00 +080040 class Field;
Logan Chien4dd96f52012-02-29 01:26:58 +080041 class OatCompilationUnit;
Shih-wei Liaod1fec812012-02-13 09:51:10 -080042}
43
44
45namespace llvm {
46 class AllocaInst;
47 class BasicBlock;
48 class Function;
49 class FunctionType;
50 class LLVMContext;
51 class Module;
52 class Type;
53}
54
55
56namespace art {
57namespace compiler_llvm {
58
Logan Chien8b977d32012-02-21 19:14:55 +080059class CompilationUnit;
Shih-wei Liaod1fec812012-02-13 09:51:10 -080060class CompilerLLVM;
TDYa127e2102142012-05-26 10:27:38 -070061class DalvikReg;
Shih-wei Liaod1fec812012-02-13 09:51:10 -080062class IRBuilder;
63
64class MethodCompiler {
Shih-wei Liaod1fec812012-02-13 09:51:10 -080065 public:
Logan Chien8b977d32012-02-21 19:14:55 +080066 MethodCompiler(CompilationUnit* cunit,
Logan Chien83426162011-12-09 09:29:50 +080067 Compiler* compiler,
Logan Chien4dd96f52012-02-29 01:26:58 +080068 OatCompilationUnit* oat_compilation_unit);
Shih-wei Liaod1fec812012-02-13 09:51:10 -080069
70 ~MethodCompiler();
71
Logan Chien83426162011-12-09 09:29:50 +080072 CompiledMethod* Compile();
Shih-wei Liaod1fec812012-02-13 09:51:10 -080073
Logan Chienc670a8d2011-12-20 21:25:56 +080074
75 // Code generation helper function
76
77 IRBuilder& GetIRBuilder() const {
78 return irb_;
79 }
80
81
82 // Register helper function
83
TDYa127e2102142012-05-26 10:27:38 -070084 llvm::Value* AllocDalvikReg(RegCategory cat, const std::string& name);
Logan Chienc670a8d2011-12-20 21:25:56 +080085
TDYa127e2102142012-05-26 10:27:38 -070086 llvm::Value* GetShadowFrameEntry(uint32_t reg_idx);
Logan Chienc670a8d2011-12-20 21:25:56 +080087
88
Shih-wei Liaod1fec812012-02-13 09:51:10 -080089 private:
90 void CreateFunction();
Shih-wei Liaod1fec812012-02-13 09:51:10 -080091 void EmitPrologue();
TDYa1274165a832012-04-03 17:47:16 -070092 void EmitStackOverflowCheck();
Logan Chienc670a8d2011-12-20 21:25:56 +080093 void EmitPrologueLastBranch();
Logan Chien8dfcbea2012-02-17 18:50:32 +080094 void EmitPrologueAllocShadowFrame();
Logan Chiend6ececa2011-12-27 16:20:15 +080095 void EmitPrologueAssignArgRegister();
Shih-wei Liaod1fec812012-02-13 09:51:10 -080096 void EmitInstructions();
Logan Chien83426162011-12-09 09:29:50 +080097 void EmitInstruction(uint32_t dex_pc, Instruction const* insn);
Shih-wei Liaod1fec812012-02-13 09:51:10 -080098
Logan Chien70f94b42011-12-27 17:49:11 +080099 enum CondBranchKind {
100 kCondBranch_EQ,
101 kCondBranch_NE,
102 kCondBranch_LT,
103 kCondBranch_GE,
104 kCondBranch_GT,
105 kCondBranch_LE,
106 };
107
108 enum IntArithmKind {
109 kIntArithm_Add,
110 kIntArithm_Sub,
111 kIntArithm_Mul,
112 kIntArithm_Div,
113 kIntArithm_Rem,
114 kIntArithm_And,
115 kIntArithm_Or,
116 kIntArithm_Xor,
Logan Chien5539ad02012-04-02 14:36:55 +0800117 };
118
119 enum IntShiftArithmKind {
Logan Chien70f94b42011-12-27 17:49:11 +0800120 kIntArithm_Shl,
121 kIntArithm_Shr,
122 kIntArithm_UShr,
123 };
124
125 enum FPArithmKind {
126 kFPArithm_Add,
127 kFPArithm_Sub,
128 kFPArithm_Mul,
129 kFPArithm_Div,
130 kFPArithm_Rem,
131 };
132
Logan Chien7e7fabc2012-04-10 18:59:11 +0800133 enum InvokeArgFmt {
134 kArgReg,
135 kArgRange,
136 };
137
Logan Chien70f94b42011-12-27 17:49:11 +0800138#define GEN_INSN_ARGS uint32_t dex_pc, Instruction const* insn
139
140 // NOP, PAYLOAD (unreachable) instructions
141 void EmitInsn_Nop(GEN_INSN_ARGS);
142
143 // MOVE, MOVE_RESULT instructions
144 void EmitInsn_Move(GEN_INSN_ARGS, JType jty);
145 void EmitInsn_MoveResult(GEN_INSN_ARGS, JType jty);
146
147 // MOVE_EXCEPTION, THROW instructions
148 void EmitInsn_MoveException(GEN_INSN_ARGS);
149 void EmitInsn_ThrowException(GEN_INSN_ARGS);
Logan Chien9e5f5c12012-04-10 13:51:45 +0800150 void EmitInsn_ThrowVerificationError(GEN_INSN_ARGS);
Logan Chien70f94b42011-12-27 17:49:11 +0800151
152 // RETURN instructions
153 void EmitInsn_ReturnVoid(GEN_INSN_ARGS);
154 void EmitInsn_Return(GEN_INSN_ARGS);
155
156 // CONST, CONST_CLASS, CONST_STRING instructions
157 void EmitInsn_LoadConstant(GEN_INSN_ARGS, JType imm_jty);
158 void EmitInsn_LoadConstantString(GEN_INSN_ARGS);
159 void EmitInsn_LoadConstantClass(GEN_INSN_ARGS);
160
161 // MONITOR_ENTER, MONITOR_EXIT instructions
162 void EmitInsn_MonitorEnter(GEN_INSN_ARGS);
163 void EmitInsn_MonitorExit(GEN_INSN_ARGS);
164
165 // CHECK_CAST, INSTANCE_OF instructions
166 void EmitInsn_CheckCast(GEN_INSN_ARGS);
167 void EmitInsn_InstanceOf(GEN_INSN_ARGS);
168
169 // NEW_INSTANCE instructions
170 void EmitInsn_NewInstance(GEN_INSN_ARGS);
171
172 // ARRAY_LEN, NEW_ARRAY, FILLED_NEW_ARRAY, FILL_ARRAY_DATA instructions
173 void EmitInsn_ArrayLength(GEN_INSN_ARGS);
174 void EmitInsn_NewArray(GEN_INSN_ARGS);
175 void EmitInsn_FilledNewArray(GEN_INSN_ARGS, bool is_range);
176 void EmitInsn_FillArrayData(GEN_INSN_ARGS);
177
178 // GOTO, IF_TEST, IF_TESTZ instructions
179 void EmitInsn_UnconditionalBranch(GEN_INSN_ARGS);
180 void EmitInsn_BinaryConditionalBranch(GEN_INSN_ARGS, CondBranchKind cond);
181 void EmitInsn_UnaryConditionalBranch(GEN_INSN_ARGS, CondBranchKind cond);
182
183 // PACKED_SWITCH, SPARSE_SWITCH instrutions
184 void EmitInsn_PackedSwitch(GEN_INSN_ARGS);
185 void EmitInsn_SparseSwitch(GEN_INSN_ARGS);
186
187 // CMPX_FLOAT, CMPX_DOUBLE, CMP_LONG instructions
188 void EmitInsn_FPCompare(GEN_INSN_ARGS, JType fp_jty, bool gt_bias);
189 void EmitInsn_LongCompare(GEN_INSN_ARGS);
190
191 // AGET, APUT instrutions
192 void EmitInsn_AGet(GEN_INSN_ARGS, JType elem_jty);
193 void EmitInsn_APut(GEN_INSN_ARGS, JType elem_jty);
194
195 // IGET, IPUT instructions
196 void EmitInsn_IGet(GEN_INSN_ARGS, JType field_jty);
197 void EmitInsn_IPut(GEN_INSN_ARGS, JType field_jty);
198
199 // SGET, SPUT instructions
200 void EmitInsn_SGet(GEN_INSN_ARGS, JType field_jty);
201 void EmitInsn_SPut(GEN_INSN_ARGS, JType field_jty);
202
203 // INVOKE instructions
TDYa1270b686e52012-04-09 22:43:35 -0700204 llvm::Value* EmitFixStub(llvm::Value* callee_method_object_addr,
205 uint32_t method_idx,
206 bool is_static);
TDYa12785321912012-04-01 15:24:56 -0700207 llvm::Value* EmitEnsureResolved(llvm::Value* callee,
208 llvm::Value* caller,
209 uint32_t dex_method_idx,
TDYa1270b686e52012-04-09 22:43:35 -0700210 bool is_virtual);
TDYa12785321912012-04-01 15:24:56 -0700211
Logan Chien7e7fabc2012-04-10 18:59:11 +0800212 void EmitInsn_Invoke(GEN_INSN_ARGS,
213 InvokeType invoke_type,
214 InvokeArgFmt arg_fmt);
215
216 llvm::Value* EmitLoadSDCalleeMethodObjectAddr(uint32_t callee_method_idx);
217
218 llvm::Value* EmitLoadVirtualCalleeMethodObjectAddr(int vtable_idx,
219 llvm::Value* this_addr);
220
221 llvm::Value* EmitCallRuntimeForCalleeMethodObjectAddr(uint32_t callee_method_idx,
222 InvokeType invoke_type,
223 llvm::Value* this_addr,
224 uint32_t dex_pc,
225 bool is_fast_path);
Logan Chien70f94b42011-12-27 17:49:11 +0800226
227 // Unary instructions
228 void EmitInsn_Neg(GEN_INSN_ARGS, JType op_jty);
229 void EmitInsn_Not(GEN_INSN_ARGS, JType op_jty);
230 void EmitInsn_SExt(GEN_INSN_ARGS);
231 void EmitInsn_Trunc(GEN_INSN_ARGS);
232 void EmitInsn_TruncAndSExt(GEN_INSN_ARGS, unsigned N);
233 void EmitInsn_TruncAndZExt(GEN_INSN_ARGS, unsigned N);
234
235 void EmitInsn_FNeg(GEN_INSN_ARGS, JType op_jty);
236 void EmitInsn_IntToFP(GEN_INSN_ARGS, JType src_jty, JType dest_jty);
TDYa127a4746872012-04-11 23:48:55 -0700237 void EmitInsn_FPToInt(GEN_INSN_ARGS, JType src_jty, JType dest_jty,
238 runtime_support::RuntimeId runtime_func_id);
Logan Chien70f94b42011-12-27 17:49:11 +0800239 void EmitInsn_FExt(GEN_INSN_ARGS);
240 void EmitInsn_FTrunc(GEN_INSN_ARGS);
241
242 // Integer binary arithmetic instructions
243 void EmitInsn_IntArithm(GEN_INSN_ARGS, IntArithmKind arithm,
244 JType op_jty, bool is_2addr);
245
246 void EmitInsn_IntArithmImmediate(GEN_INSN_ARGS, IntArithmKind arithm);
247
Logan Chien5539ad02012-04-02 14:36:55 +0800248 void EmitInsn_IntShiftArithm(GEN_INSN_ARGS, IntShiftArithmKind arithm,
249 JType op_jty, bool is_2addr);
250
251 void EmitInsn_IntShiftArithmImmediate(GEN_INSN_ARGS,
252 IntShiftArithmKind arithm);
253
Logan Chien70f94b42011-12-27 17:49:11 +0800254 void EmitInsn_RSubImmediate(GEN_INSN_ARGS);
255
256
257 // Floating-point binary arithmetic instructions
258 void EmitInsn_FPArithm(GEN_INSN_ARGS, FPArithmKind arithm,
259 JType op_jty, bool is_2addr);
260
261#undef GEN_INSN_ARGS
262
TDYa12783bb6622012-04-17 02:20:34 -0700263 // GC card table helper function
264 void EmitMarkGCCard(llvm::Value* value, llvm::Value* target_addr);
Logan Chien0b827102011-12-20 19:46:14 +0800265
Logan Chien8dfcbea2012-02-17 18:50:32 +0800266 // Shadow frame helper function
TDYa127af543472012-05-28 21:49:23 -0700267 void EmitPushShadowFrame(bool is_inline);
Logan Chien8dfcbea2012-02-17 18:50:32 +0800268 void EmitPopShadowFrame();
TDYa127c8dc1012012-04-19 07:03:33 -0700269 void EmitUpdateDexPC(uint32_t dex_pc);
Logan Chien8dfcbea2012-02-17 18:50:32 +0800270
271
Logan Chienbb4d12a2012-02-17 14:10:01 +0800272 // Dex cache code generation helper function
273 llvm::Value* EmitLoadDexCacheAddr(MemberOffset dex_cache_offset);
274
Logan Chienbb4d12a2012-02-17 14:10:01 +0800275 llvm::Value* EmitLoadDexCacheStaticStorageFieldAddr(uint32_t type_idx);
276
277 llvm::Value* EmitLoadDexCacheResolvedTypeFieldAddr(uint32_t type_idx);
278
Logan Chien61c65dc2012-02-29 03:22:30 +0800279 llvm::Value* EmitLoadDexCacheResolvedMethodFieldAddr(uint32_t method_idx);
280
Logan Chienbb4d12a2012-02-17 14:10:01 +0800281 llvm::Value* EmitLoadDexCacheStringFieldAddr(uint32_t string_idx);
282
283
Logan Chien0b827102011-12-20 19:46:14 +0800284 // Code generation helper function
285
286 llvm::Value* EmitLoadMethodObjectAddr();
287
288 llvm::FunctionType* GetFunctionType(uint32_t method_idx, bool is_static);
289
TDYa127526643e2012-05-26 01:01:48 -0700290 void EmitGuard_ExceptionLandingPad(uint32_t dex_pc, bool can_skip_unwind);
Logan Chien5bcc04e2012-01-30 14:15:12 +0800291
292 void EmitBranchExceptionLandingPad(uint32_t dex_pc);
293
TDYa127526643e2012-05-26 01:01:48 -0700294 void EmitGuard_GarbageCollectionSuspend();
Logan Chien924072f2012-01-30 15:07:24 +0800295
Logan Chien2c37e8e2011-12-27 17:58:46 +0800296 llvm::Value* EmitCompareResultSelection(llvm::Value* cmp_eq,
297 llvm::Value* cmp_lt);
298
Logan Chiena78e3c82011-12-27 17:59:35 +0800299 llvm::Value* EmitConditionResult(llvm::Value* lhs,
300 llvm::Value* rhs,
301 CondBranchKind cond);
302
Logan Chienc3f7d962011-12-27 18:13:18 +0800303 llvm::Value* EmitIntArithmResultComputation(uint32_t dex_pc,
304 llvm::Value* lhs,
305 llvm::Value* rhs,
306 IntArithmKind arithm,
307 JType op_jty);
308
TDYa127f8641ce2012-04-02 06:40:40 -0700309 llvm::Value* EmitIntDivRemResultComputation(uint32_t dex_pc,
310 llvm::Value* dividend,
311 llvm::Value* divisor,
312 IntArithmKind arithm,
313 JType op_jty);
314
Logan Chien5539ad02012-04-02 14:36:55 +0800315 llvm::Value* EmitIntShiftArithmResultComputation(uint32_t dex_pc,
316 llvm::Value* lhs,
317 llvm::Value* rhs,
318 IntShiftArithmKind arithm,
319 JType op_jty);
320
Logan Chien76e1c792011-12-27 18:15:01 +0800321 llvm::Value* EmitFPArithmResultComputation(uint32_t dex_pc,
322 llvm::Value* lhs,
323 llvm::Value* rhs,
324 FPArithmKind arithm);
325
Logan Chiena2cc6a32012-01-16 10:38:41 +0800326 llvm::Value* EmitAllocNewArray(uint32_t dex_pc,
327 int32_t length,
328 uint32_t type_idx,
329 bool is_filled_new_array);
330
Logan Chien46fbb412012-02-15 22:29:08 +0800331 llvm::Value* EmitLoadClassObjectAddr(llvm::Value* this_addr);
332
333 llvm::Value* EmitLoadVTableAddr(llvm::Value* class_object_addr);
334
335 llvm::Value* EmitLoadMethodObjectAddrFromVTable(llvm::Value* vtable_addr,
336 uint16_t vtable_index);
337
338 llvm::Value* EmitLoadCodeAddr(llvm::Value* method_object_addr,
339 uint32_t method_idx,
340 bool is_static);
341
Logan Chien61bb6142012-02-03 15:34:53 +0800342 llvm::Value* EmitLoadArrayLength(llvm::Value* array);
343
Logan Chiene27fdbb2012-01-02 23:27:26 +0800344 llvm::Value* EmitArrayGEP(llvm::Value* array_addr,
345 llvm::Value* index_value,
Ian Rogers04ec04e2012-02-28 16:15:33 -0800346 JType elem_jty);
Logan Chiene27fdbb2012-01-02 23:27:26 +0800347
Logan Chien27b30252012-01-14 03:43:35 +0800348 llvm::Value* EmitLoadConstantClass(uint32_t dex_pc, uint32_t type_idx);
349
Logan Chien438c4b62012-01-17 16:06:00 +0800350 llvm::Value* EmitLoadStaticStorage(uint32_t dex_pc, uint32_t type_idx);
351
Logan Chien1a121b92012-02-15 22:23:42 +0800352 void EmitLoadActualParameters(std::vector<llvm::Value*>& args,
353 uint32_t callee_method_idx,
Elliott Hughesadb8c672012-03-06 16:49:32 -0800354 DecodedInstruction const& di,
Logan Chien7e7fabc2012-04-10 18:59:11 +0800355 InvokeArgFmt arg_fmt,
Logan Chien1a121b92012-02-15 22:23:42 +0800356 bool is_static);
357
Logan Chienc3f7d962011-12-27 18:13:18 +0800358 void EmitGuard_DivZeroException(uint32_t dex_pc,
359 llvm::Value* denominator,
360 JType op_jty);
361
Logan Chien61bb6142012-02-03 15:34:53 +0800362 void EmitGuard_NullPointerException(uint32_t dex_pc,
363 llvm::Value* object);
364
Logan Chiene27fdbb2012-01-02 23:27:26 +0800365 void EmitGuard_ArrayIndexOutOfBoundsException(uint32_t dex_pc,
366 llvm::Value* array,
367 llvm::Value* index);
368
369 void EmitGuard_ArrayException(uint32_t dex_pc,
370 llvm::Value* array,
371 llvm::Value* index);
372
Logan Chiena78e3c82011-12-27 17:59:35 +0800373 RegCategory GetInferredRegCategory(uint32_t dex_pc, uint16_t reg);
374
TDYa1271d7e5102012-05-13 09:27:05 -0700375 InferredRegCategoryMap const* GetInferredRegCategoryMap();
376
377 bool IsRegCanBeObject(uint16_t reg_idx);
378
Logan Chien48f1d2a2012-01-02 22:49:53 +0800379
Logan Chiend6c239a2011-12-23 15:11:45 +0800380 // Basic block helper functions
381 llvm::BasicBlock* GetBasicBlock(uint32_t dex_pc);
382
383 llvm::BasicBlock* GetNextBasicBlock(uint32_t dex_pc);
384
385 llvm::BasicBlock* CreateBasicBlockWithDexPC(uint32_t dex_pc,
386 char const* postfix = NULL);
387
Logan Chien5bcc04e2012-01-30 14:15:12 +0800388 int32_t GetTryItemOffset(uint32_t dex_pc);
389
390 llvm::BasicBlock* GetLandingPadBasicBlock(uint32_t dex_pc);
391
392 llvm::BasicBlock* GetUnwindBasicBlock();
393
Logan Chienc670a8d2011-12-20 21:25:56 +0800394
395 // Register helper function
396
TDYa127e2102142012-05-26 10:27:38 -0700397 llvm::Value* EmitLoadDalvikReg(uint32_t reg_idx, JType jty, JTypeSpace space);
Logan Chienc670a8d2011-12-20 21:25:56 +0800398
TDYa127e2102142012-05-26 10:27:38 -0700399 llvm::Value* EmitLoadDalvikReg(uint32_t reg_idx, char shorty, JTypeSpace space);
Logan Chienc670a8d2011-12-20 21:25:56 +0800400
401 void EmitStoreDalvikReg(uint32_t reg_idx, JType jty,
TDYa127e2102142012-05-26 10:27:38 -0700402 JTypeSpace space, llvm::Value* new_value);
Logan Chienc670a8d2011-12-20 21:25:56 +0800403
404 void EmitStoreDalvikReg(uint32_t reg_idx, char shorty,
TDYa127e2102142012-05-26 10:27:38 -0700405 JTypeSpace space, llvm::Value* new_value);
Logan Chienc670a8d2011-12-20 21:25:56 +0800406
TDYa127e2102142012-05-26 10:27:38 -0700407 llvm::Value* EmitLoadDalvikRetValReg(JType jty, JTypeSpace space);
Logan Chienc670a8d2011-12-20 21:25:56 +0800408
TDYa127e2102142012-05-26 10:27:38 -0700409 llvm::Value* EmitLoadDalvikRetValReg(char shorty, JTypeSpace space);
Logan Chienc670a8d2011-12-20 21:25:56 +0800410
TDYa127e2102142012-05-26 10:27:38 -0700411 void EmitStoreDalvikRetValReg(JType jty, JTypeSpace space, llvm::Value* new_value);
Logan Chienc670a8d2011-12-20 21:25:56 +0800412
TDYa127e2102142012-05-26 10:27:38 -0700413 void EmitStoreDalvikRetValReg(char shorty, JTypeSpace space, llvm::Value* new_value);
Logan Chien50aaf812012-03-01 21:03:24 +0800414
TDYa127cc1b4c32012-05-15 07:31:37 -0700415 // TODO: Use high-level IR to do this
TDYa12729c0cd12012-05-17 04:51:08 -0700416 bool EmitInlineJavaIntrinsic(const std::string& callee_method_name,
417 const std::vector<llvm::Value*>& args,
418 llvm::BasicBlock* after_invoke);
419
420 bool EmitInlinedStringCharAt(const std::vector<llvm::Value*>& args,
421 llvm::BasicBlock* after_invoke);
422
423 bool EmitInlinedStringLength(const std::vector<llvm::Value*>& args,
424 llvm::BasicBlock* after_invoke);
TDYa127cc1b4c32012-05-15 07:31:37 -0700425
TDYa127d4f82b62012-06-02 21:48:09 -0700426 bool EmitInlinedStringIndexOf(const std::vector<llvm::Value*>& args,
427 llvm::BasicBlock* after_invoke,
428 bool zero_based);
429
430 bool EmitInlinedStringCompareTo(const std::vector<llvm::Value*>& args,
431 llvm::BasicBlock* after_invoke);
432
TDYa127526643e2012-05-26 01:01:48 -0700433 bool IsInstructionDirectToReturn(uint32_t dex_pc);
434
TDYa127cc1b4c32012-05-15 07:31:37 -0700435 struct MethodInfo {
436 int64_t this_reg_idx;
437 bool this_will_not_be_null;
438 bool has_invoke;
439 bool need_shadow_frame_entry;
440 bool need_shadow_frame;
TDYa127af543472012-05-28 21:49:23 -0700441 bool lazy_push_shadow_frame;
TDYa127cc1b4c32012-05-15 07:31:37 -0700442 };
443 MethodInfo method_info_;
444
445 void ComputeMethodInfo();
Logan Chien50aaf812012-03-01 21:03:24 +0800446
447 private:
448 CompilationUnit* cunit_;
449 Compiler* compiler_;
450
451 ClassLinker* class_linker_;
452 ClassLoader const* class_loader_;
453
454 DexFile const* dex_file_;
455 DexCache* dex_cache_;
456 DexFile::CodeItem const* code_item_;
457
458 OatCompilationUnit* oat_compilation_unit_;
Logan Chien50aaf812012-03-01 21:03:24 +0800459
460 uint32_t method_idx_;
461 uint32_t access_flags_;
462
463 llvm::Module* module_;
464 llvm::LLVMContext* context_;
465 IRBuilder& irb_;
466 llvm::Function* func_;
467
468 std::vector<DalvikReg*> regs_;
TDYa127e2102142012-05-26 10:27:38 -0700469 std::vector<llvm::Value*> shadow_frame_entries_;
TDYa1271d7e5102012-05-13 09:27:05 -0700470 std::vector<int32_t> reg_to_shadow_frame_index_;
Logan Chien50aaf812012-03-01 21:03:24 +0800471 UniquePtr<DalvikReg> retval_reg_;
472
TDYa127b9ff6b12012-05-17 11:14:29 -0700473 llvm::BasicBlock* basic_block_alloca_;
474 llvm::BasicBlock* basic_block_shadow_frame_;
Logan Chien50aaf812012-03-01 21:03:24 +0800475 llvm::BasicBlock* basic_block_reg_arg_init_;
476 std::vector<llvm::BasicBlock*> basic_blocks_;
477
478 std::vector<llvm::BasicBlock*> basic_block_landing_pads_;
479 llvm::BasicBlock* basic_block_unwind_;
480 llvm::BasicBlock* basic_block_unreachable_;
481
482 llvm::AllocaInst* shadow_frame_;
TDYa1270de52be2012-05-27 20:49:31 -0700483 llvm::Value* old_shadow_frame_;
Logan Chien937105a2012-04-02 02:37:37 +0800484
TDYa127af543472012-05-28 21:49:23 -0700485 llvm::Value* already_pushed_shadow_frame_;
486 uint32_t shadow_frame_size_;
487
Logan Chien937105a2012-04-02 02:37:37 +0800488 uint16_t elf_func_idx_;
Shih-wei Liaod1fec812012-02-13 09:51:10 -0800489};
490
491
492} // namespace compiler_llvm
493} // namespace art
494
495#endif // ART_SRC_COMPILER_LLVM_METHOD_COMPILER_H_