/* * Copyright (C) 2011 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_COMPILERCODEGEN_H_ #define ART_SRC_COMPILER_COMPILERCODEGEN_H_ #include "../CompilerIR.h" namespace art { LIR* rawLIR(CompilationUnit* cUnit, int dalvikOffset, int opcode, int op0 = 0, int op1 = 0, int op2 = 0, int op3 = 0, int op4 = 0, LIR* target = NULL); int oatGetInsnSize(LIR* lir); void genFusedLongCmpBranch(CompilationUnit* cUnit, BasicBlock* bb, MIR* mir); void genFusedFPCmpBranch(CompilationUnit* cUnit, BasicBlock* bb, MIR* mir, bool gtBias, bool isDouble); CallInfo* oatNewCallInfo(CompilationUnit* cUnit, BasicBlock* bb, MIR* mir, InvokeType type, bool isRange); /* Lower middle-level IR to low-level IR for the whole method */ void oatMethodMIR2LIR(CompilationUnit* cUnit); /* Bitcode conversions */ void oatMethodMIR2Bitcode(CompilationUnit* cUnit); void oatMethodBitcode2LIR(CompilationUnit* cUnit); /* Lower middle-level IR to low-level IR for the simple methods */ void oatSpecialMIR2LIR(CompilationUnit* cUnit, SpecialCaseHandler specialCase ); /* Assemble LIR into machine code */ void oatAssembleLIR(CompilationUnit* cUnit); AssemblerStatus oatAssembleInstructions(CompilationUnit* cUnit, intptr_t startAddr); void oatAssignOffsets(CompilationUnit* cUnit); int oatAssignInsnOffsets(CompilationUnit* cUnit); /* Implemented in the codegen//ArchUtility.c */ void oatCodegenDump(CompilationUnit* cUnit); void oatDumpPromotionMap(CompilationUnit* cUnit); std::string buildInsnString(const char* fmt, LIR* lir, unsigned char* baseAddr); /* Implemented in codegen//Ralloc.c */ void oatSimpleRegAlloc(CompilationUnit* cUnit); /* Implemented in codegen//ThumbUtil.c */ void oatInitializeRegAlloc(CompilationUnit* cUnit); /* Implemented in codegen///ArchVariant.c */ InstructionSet oatInstructionSet(); /* * Implemented in codegen///ArchVariant.c * Architecture-specific initializations and checks */ bool oatArchVariantInit(void); /* Implemented in codegen///ArchVariant.c */ int oatTargetOptHint(int key); /* Implemented in codegen///ArchVariant.c */ void oatGenMemBarrier(CompilationUnit* cUnit, int barrierKind); LIR* genRegMemCheck(CompilationUnit* cUnit, ConditionCode cCode, int reg1, int base, int offset, ThrowKind kind); LIR* opThreadMem(CompilationUnit* cUnit, OpKind op, int threadOffset); LIR* opMem(CompilationUnit* cUnit, OpKind op, int rBase, int disp); LIR* storeBaseIndexedDisp(CompilationUnit *cUnit, int rBase, int rIndex, int scale, int displacement, int rSrc, int rSrcHi, OpSize size, int sReg); LIR* opRegMem(CompilationUnit *cUnit, OpKind op, int rDest, int rBase, int offset); LIR* opCmpBranch(CompilationUnit* cUnit, ConditionCode cond, int src1, int src2, LIR* target); void oatSetupRegMask(CompilationUnit* cUnit, u8* mask, int reg); u8 oatGetRegMaskCommon(CompilationUnit* cUnit, int reg); void setupTargetResourceMasks(CompilationUnit* cUnit, LIR* lir); RegLocation genDivRem(CompilationUnit* cUnit, RegLocation rlDest, int regLo, int regHi, bool isDiv); RegLocation genDivRemLit(CompilationUnit* cUnit, RegLocation rlDest, int regLo, int lit, bool isDiv); void markGCCard(CompilationUnit* cUnit, int valReg, int tgtAddrReg); bool genInlinedMinMaxInt(CompilationUnit *cUnit, CallInfo* info, bool isMin); void opLea(CompilationUnit* cUnit, int rBase, int reg1, int reg2, int scale, int offset); void opTlsCmp(CompilationUnit* cUnit, int offset, int val); bool genInlinedSqrt(CompilationUnit* cUnit, CallInfo* info); bool genInlinedCas32(CompilationUnit* cUnit, CallInfo* info, bool need_write_barrier); LIR* opPcRelLoad(CompilationUnit* cUnit, int reg, LIR* target); LIR* opVldm(CompilationUnit* cUnit, int rBase, int count); LIR* opVstm(CompilationUnit* cUnit, int rBase, int count); void genMultiplyByTwoBitMultiplier(CompilationUnit* cUnit, RegLocation rlSrc, RegLocation rlResult, int lit, int firstBit, int secondBit); RegLocation inlineTarget(CompilationUnit* cUnit, CallInfo* info); RegLocation inlineTargetWide(CompilationUnit* cUnit, CallInfo* info); void genDivZeroCheck(CompilationUnit* cUnit, int regLo, int regHi); LIR* genImmedCheck(CompilationUnit* cUnit, ConditionCode cCode, int reg, int immVal, ThrowKind kind); LIR* opTestSuspend(CompilationUnit* cUnit, LIR* target); LIR* opDecAndBranch(CompilationUnit* cUnit, ConditionCode cCode, int reg, LIR* target); LIR* opIT(CompilationUnit* cUnit, ArmConditionCode cond, const char* guide); } // namespace art #endif // ART_SRC_COMPILER_COMPILERCODEGEN_H_