diff options
Diffstat (limited to 'src/compiler_llvm/method_compiler.h')
-rw-r--r-- | src/compiler_llvm/method_compiler.h | 491 |
1 files changed, 0 insertions, 491 deletions
diff --git a/src/compiler_llvm/method_compiler.h b/src/compiler_llvm/method_compiler.h deleted file mode 100644 index 4d759e501a..0000000000 --- a/src/compiler_llvm/method_compiler.h +++ /dev/null @@ -1,491 +0,0 @@ -/* - * Copyright (C) 2012 The Android Open Source Project - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#ifndef ART_SRC_COMPILER_LLVM_METHOD_COMPILER_H_ -#define ART_SRC_COMPILER_LLVM_METHOD_COMPILER_H_ - -#include "backend_types.h" -#include "dex_file.h" -#include "dex_instruction.h" -#include "greenland/backend_types.h" -#include "invoke_type.h" -#include "object_utils.h" -#include "runtime_support_func.h" - -#include <llvm/Support/IRBuilder.h> - -#include <vector> - -#include <stdint.h> - - -namespace art { - class ClassLinker; - class CompiledMethod; - class Compiler; - class OatCompilationUnit; - - namespace mirror { - class ClassLoader; - class DexCache; - class Field; - } // namespace mirror - - namespace greenland { - class InferredRegCategoryMap; - } // namespace greenland -} // namespace art - - -namespace llvm { - class AllocaInst; - class BasicBlock; - class Function; - class FunctionType; - class LLVMContext; - class Module; - class Type; -} // namespace llvm - - -namespace art { -namespace compiler_llvm { - -class LlvmCompilationUnit; -class CompilerLLVM; -class DalvikReg; -class IRBuilder; - -class MethodCompiler { - public: - MethodCompiler(LlvmCompilationUnit* cunit, - Compiler* compiler, - OatCompilationUnit* oat_compilation_unit); - - ~MethodCompiler(); - - CompiledMethod* Compile(); - - - // Code generation helper function - - IRBuilder& GetIRBuilder() const { - return irb_; - } - - - // Register helper function - - llvm::Value* AllocDalvikReg(RegCategory cat, const std::string& name); - - llvm::Value* GetShadowFrameEntry(uint32_t reg_idx); - - llvm::Value* GetVRegEntry(uint32_t reg_idx); - - - private: - void CreateFunction(); - void EmitPrologue(); - void EmitStackOverflowCheck(); - void EmitPrologueLastBranch(); - void EmitPrologueAllocShadowFrame(); - void EmitPrologueAssignArgRegister(); - void EmitInstructions(); - void EmitInstruction(uint32_t dex_pc, const Instruction* insn); - - enum CondBranchKind { - kCondBranch_EQ, - kCondBranch_NE, - kCondBranch_LT, - kCondBranch_GE, - kCondBranch_GT, - kCondBranch_LE, - }; - - enum IntArithmKind { - kIntArithm_Add, - kIntArithm_Sub, - kIntArithm_Mul, - kIntArithm_Div, - kIntArithm_Rem, - kIntArithm_And, - kIntArithm_Or, - kIntArithm_Xor, - }; - - enum IntShiftArithmKind { - kIntArithm_Shl, - kIntArithm_Shr, - kIntArithm_UShr, - }; - - enum FPArithmKind { - kFPArithm_Add, - kFPArithm_Sub, - kFPArithm_Mul, - kFPArithm_Div, - kFPArithm_Rem, - }; - - enum InvokeArgFmt { - kArgReg, - kArgRange, - }; - -#define GEN_INSN_ARGS uint32_t dex_pc, const Instruction* insn - - // NOP, PAYLOAD (unreachable) instructions - void EmitInsn_Nop(GEN_INSN_ARGS); - - // MOVE, MOVE_RESULT instructions - void EmitInsn_Move(GEN_INSN_ARGS, JType jty); - void EmitInsn_MoveResult(GEN_INSN_ARGS, JType jty); - - // MOVE_EXCEPTION, THROW instructions - void EmitInsn_MoveException(GEN_INSN_ARGS); - void EmitInsn_ThrowException(GEN_INSN_ARGS); - - // RETURN instructions - void EmitInsn_ReturnVoid(GEN_INSN_ARGS); - void EmitInsn_Return(GEN_INSN_ARGS); - - // CONST, CONST_CLASS, CONST_STRING instructions - void EmitInsn_LoadConstant(GEN_INSN_ARGS, JType imm_jty); - void EmitInsn_LoadConstantString(GEN_INSN_ARGS); - void EmitInsn_LoadConstantClass(GEN_INSN_ARGS); - - // MONITOR_ENTER, MONITOR_EXIT instructions - void EmitInsn_MonitorEnter(GEN_INSN_ARGS); - void EmitInsn_MonitorExit(GEN_INSN_ARGS); - - // CHECK_CAST, INSTANCE_OF instructions - void EmitInsn_CheckCast(GEN_INSN_ARGS); - void EmitInsn_InstanceOf(GEN_INSN_ARGS); - - // NEW_INSTANCE instructions - void EmitInsn_NewInstance(GEN_INSN_ARGS); - - // ARRAY_LEN, NEW_ARRAY, FILLED_NEW_ARRAY, FILL_ARRAY_DATA instructions - void EmitInsn_ArrayLength(GEN_INSN_ARGS); - void EmitInsn_NewArray(GEN_INSN_ARGS); - void EmitInsn_FilledNewArray(GEN_INSN_ARGS, bool is_range); - void EmitInsn_FillArrayData(GEN_INSN_ARGS); - - // GOTO, IF_TEST, IF_TESTZ instructions - void EmitInsn_UnconditionalBranch(GEN_INSN_ARGS); - void EmitInsn_BinaryConditionalBranch(GEN_INSN_ARGS, CondBranchKind cond); - void EmitInsn_UnaryConditionalBranch(GEN_INSN_ARGS, CondBranchKind cond); - - // PACKED_SWITCH, SPARSE_SWITCH instrutions - void EmitInsn_PackedSwitch(GEN_INSN_ARGS); - void EmitInsn_SparseSwitch(GEN_INSN_ARGS); - - // CMPX_FLOAT, CMPX_DOUBLE, CMP_LONG instructions - void EmitInsn_FPCompare(GEN_INSN_ARGS, JType fp_jty, bool gt_bias); - void EmitInsn_LongCompare(GEN_INSN_ARGS); - - // AGET, APUT instrutions - void EmitInsn_AGet(GEN_INSN_ARGS, JType elem_jty); - void EmitInsn_APut(GEN_INSN_ARGS, JType elem_jty); - - // IGET, IPUT instructions - void EmitInsn_IGet(GEN_INSN_ARGS, JType field_jty); - void EmitInsn_IPut(GEN_INSN_ARGS, JType field_jty); - - // SGET, SPUT instructions - void EmitInsn_SGet(GEN_INSN_ARGS, JType field_jty); - void EmitInsn_SPut(GEN_INSN_ARGS, JType field_jty); - - // INVOKE instructions - void EmitInsn_Invoke(GEN_INSN_ARGS, - InvokeType invoke_type, - InvokeArgFmt arg_fmt); - - llvm::Value* EmitLoadSDCalleeMethodObjectAddr(uint32_t callee_method_idx); - - llvm::Value* EmitLoadVirtualCalleeMethodObjectAddr(int vtable_idx, - llvm::Value* this_addr); - - llvm::Value* EmitCallRuntimeForCalleeMethodObjectAddr(uint32_t callee_method_idx, - InvokeType invoke_type, - llvm::Value* this_addr, - uint32_t dex_pc, - bool is_fast_path); - - // Unary instructions - void EmitInsn_Neg(GEN_INSN_ARGS, JType op_jty); - void EmitInsn_Not(GEN_INSN_ARGS, JType op_jty); - void EmitInsn_SExt(GEN_INSN_ARGS); - void EmitInsn_Trunc(GEN_INSN_ARGS); - void EmitInsn_TruncAndSExt(GEN_INSN_ARGS, unsigned N); - void EmitInsn_TruncAndZExt(GEN_INSN_ARGS, unsigned N); - - void EmitInsn_FNeg(GEN_INSN_ARGS, JType op_jty); - void EmitInsn_IntToFP(GEN_INSN_ARGS, JType src_jty, JType dest_jty); - void EmitInsn_FPToInt(GEN_INSN_ARGS, JType src_jty, JType dest_jty, - runtime_support::RuntimeId runtime_func_id); - void EmitInsn_FExt(GEN_INSN_ARGS); - void EmitInsn_FTrunc(GEN_INSN_ARGS); - - // Integer binary arithmetic instructions - void EmitInsn_IntArithm(GEN_INSN_ARGS, IntArithmKind arithm, - JType op_jty, bool is_2addr); - - void EmitInsn_IntArithmImmediate(GEN_INSN_ARGS, IntArithmKind arithm); - - void EmitInsn_IntShiftArithm(GEN_INSN_ARGS, IntShiftArithmKind arithm, - JType op_jty, bool is_2addr); - - void EmitInsn_IntShiftArithmImmediate(GEN_INSN_ARGS, - IntShiftArithmKind arithm); - - void EmitInsn_RSubImmediate(GEN_INSN_ARGS); - - - // Floating-point binary arithmetic instructions - void EmitInsn_FPArithm(GEN_INSN_ARGS, FPArithmKind arithm, - JType op_jty, bool is_2addr); - -#undef GEN_INSN_ARGS - - // GC card table helper function - void EmitMarkGCCard(llvm::Value* value, llvm::Value* target_addr); - - // Shadow frame helper function - void EmitPushShadowFrame(bool is_inline); - void EmitPopShadowFrame(); - void EmitUpdateDexPC(uint32_t dex_pc); - - - // Dex cache code generation helper function - llvm::Value* EmitLoadDexCacheAddr(MemberOffset dex_cache_offset); - - llvm::Value* EmitLoadDexCacheStaticStorageFieldAddr(uint32_t type_idx); - - llvm::Value* EmitLoadDexCacheResolvedTypeFieldAddr(uint32_t type_idx); - - llvm::Value* EmitLoadDexCacheResolvedMethodFieldAddr(uint32_t method_idx); - - llvm::Value* EmitLoadDexCacheStringFieldAddr(uint32_t string_idx); - - - // Code generation helper function - - llvm::Value* EmitLoadMethodObjectAddr(); - - llvm::FunctionType* GetFunctionType(uint32_t method_idx, bool is_static); - - void EmitGuard_ExceptionLandingPad(uint32_t dex_pc, bool can_skip_unwind); - - void EmitBranchExceptionLandingPad(uint32_t dex_pc); - - void EmitGuard_GarbageCollectionSuspend(uint32_t dex_pc); - - llvm::Value* EmitCompareResultSelection(llvm::Value* cmp_eq, - llvm::Value* cmp_lt); - - llvm::Value* EmitConditionResult(llvm::Value* lhs, - llvm::Value* rhs, - CondBranchKind cond); - - llvm::Value* EmitIntArithmResultComputation(uint32_t dex_pc, - llvm::Value* lhs, - llvm::Value* rhs, - IntArithmKind arithm, - JType op_jty); - - llvm::Value* EmitIntDivRemResultComputation(uint32_t dex_pc, - llvm::Value* dividend, - llvm::Value* divisor, - IntArithmKind arithm, - JType op_jty); - - llvm::Value* EmitIntShiftArithmResultComputation(uint32_t dex_pc, - llvm::Value* lhs, - llvm::Value* rhs, - IntShiftArithmKind arithm, - JType op_jty); - - llvm::Value* EmitFPArithmResultComputation(uint32_t dex_pc, - llvm::Value* lhs, - llvm::Value* rhs, - FPArithmKind arithm); - - llvm::Value* EmitAllocNewArray(uint32_t dex_pc, - int32_t length, - uint32_t type_idx, - bool is_filled_new_array); - - llvm::Value* EmitLoadClassObjectAddr(llvm::Value* this_addr); - - llvm::Value* EmitLoadVTableAddr(llvm::Value* class_object_addr); - - llvm::Value* EmitLoadMethodObjectAddrFromVTable(llvm::Value* vtable_addr, - uint16_t vtable_index); - - llvm::Value* EmitLoadCodeAddr(llvm::Value* method_object_addr, - uint32_t method_idx, - bool is_static); - - llvm::Value* EmitLoadArrayLength(llvm::Value* array); - - llvm::Value* EmitArrayGEP(llvm::Value* array_addr, - llvm::Value* index_value, - JType elem_jty); - - llvm::Value* EmitLoadConstantClass(uint32_t dex_pc, uint32_t type_idx); - - llvm::Value* EmitLoadStaticStorage(uint32_t dex_pc, uint32_t type_idx); - - void EmitLoadActualParameters(std::vector<llvm::Value*>& args, - uint32_t callee_method_idx, - DecodedInstruction const& di, - InvokeArgFmt arg_fmt, - bool is_static); - - void EmitGuard_DivZeroException(uint32_t dex_pc, - llvm::Value* denominator, - JType op_jty); - - void EmitGuard_NullPointerException(uint32_t dex_pc, - llvm::Value* object); - - void EmitGuard_ArrayIndexOutOfBoundsException(uint32_t dex_pc, - llvm::Value* array, - llvm::Value* index); - - void EmitGuard_ArrayException(uint32_t dex_pc, - llvm::Value* array, - llvm::Value* index); - - greenland::RegCategory GetInferredRegCategory(uint32_t dex_pc, uint16_t reg); - - const greenland::InferredRegCategoryMap* GetInferredRegCategoryMap(); - - bool IsRegCanBeObject(uint16_t reg_idx); - - - // Basic block helper functions - llvm::BasicBlock* GetBasicBlock(uint32_t dex_pc); - - llvm::BasicBlock* GetNextBasicBlock(uint32_t dex_pc); - - llvm::BasicBlock* CreateBasicBlockWithDexPC(uint32_t dex_pc, - const char* postfix = NULL); - - int32_t GetTryItemOffset(uint32_t dex_pc); - - llvm::BasicBlock* GetLandingPadBasicBlock(uint32_t dex_pc); - - llvm::BasicBlock* GetUnwindBasicBlock(); - - - // Register helper function - - llvm::Value* EmitLoadDalvikReg(uint32_t reg_idx, JType jty, JTypeSpace space); - - llvm::Value* EmitLoadDalvikReg(uint32_t reg_idx, char shorty, JTypeSpace space); - - void EmitStoreDalvikReg(uint32_t reg_idx, JType jty, - JTypeSpace space, llvm::Value* new_value); - - void EmitStoreDalvikReg(uint32_t reg_idx, char shorty, - JTypeSpace space, llvm::Value* new_value); - - llvm::Value* EmitLoadDalvikRetValReg(JType jty, JTypeSpace space); - - llvm::Value* EmitLoadDalvikRetValReg(char shorty, JTypeSpace space); - - void EmitStoreDalvikRetValReg(JType jty, JTypeSpace space, llvm::Value* new_value); - - void EmitStoreDalvikRetValReg(char shorty, JTypeSpace space, llvm::Value* new_value); - - // TODO: Use high-level IR to do this - bool EmitInlineJavaIntrinsic(const std::string& callee_method_name, - const std::vector<llvm::Value*>& args, - llvm::BasicBlock* after_invoke); - - bool EmitInlinedStringCharAt(const std::vector<llvm::Value*>& args, - llvm::BasicBlock* after_invoke); - - bool EmitInlinedStringLength(const std::vector<llvm::Value*>& args, - llvm::BasicBlock* after_invoke); - - bool EmitInlinedStringIndexOf(const std::vector<llvm::Value*>& args, - llvm::BasicBlock* after_invoke, - bool zero_based); - - bool EmitInlinedStringCompareTo(const std::vector<llvm::Value*>& args, - llvm::BasicBlock* after_invoke); - - bool IsInstructionDirectToReturn(uint32_t dex_pc); - - struct MethodInfo { - int64_t this_reg_idx; - bool this_will_not_be_null; - bool has_invoke; - bool need_shadow_frame_entry; - bool need_shadow_frame; - bool lazy_push_shadow_frame; - std::vector<bool> set_to_another_object; - }; - MethodInfo method_info_; - - void ComputeMethodInfo(); - - private: - LlvmCompilationUnit* cunit_; - Compiler* compiler_; - - const DexFile* dex_file_; - const DexFile::CodeItem* code_item_; - - OatCompilationUnit* oat_compilation_unit_; - - uint32_t method_idx_; - uint32_t access_flags_; - - llvm::Module* module_; - llvm::LLVMContext* context_; - IRBuilder& irb_; - llvm::Function* func_; - - std::vector<DalvikReg*> regs_; - std::vector<llvm::Value*> vregs_; - UniquePtr<DalvikReg> retval_reg_; - - llvm::BasicBlock* basic_block_alloca_; - llvm::BasicBlock* basic_block_shadow_frame_; - llvm::BasicBlock* basic_block_reg_arg_init_; - std::vector<llvm::BasicBlock*> basic_blocks_; - - std::vector<llvm::BasicBlock*> basic_block_landing_pads_; - llvm::BasicBlock* basic_block_unwind_; - - llvm::AllocaInst* shadow_frame_; - llvm::Value* old_shadow_frame_; - - llvm::Value* already_pushed_shadow_frame_; - uint16_t num_shadow_frame_refs_; - - uint16_t elf_func_idx_; -}; - - -} // namespace compiler_llvm -} // namespace art - -#endif // ART_SRC_COMPILER_LLVM_METHOD_COMPILER_H_ |