blob: 93817357283143ad9c4ddba94d3b049ac55004ba [file] [log] [blame]
buzbee67bf8852011-08-17 17:51:35 -07001/*
2 * Copyright (C) 2011 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_COMPILERCODEGEN_H_
18#define ART_SRC_COMPILER_COMPILERCODEGEN_H_
19
20#include "../CompilerIR.h"
21
Elliott Hughes11d1b0c2012-01-23 16:57:47 -080022namespace art {
23
buzbeea2ebdd72012-03-04 14:57:06 -080024LIR* rawLIR(CompilationUnit* cUnit, int dalvikOffset, int opcode, int op0 = 0,
Bill Buzbeea114add2012-05-03 15:00:40 -070025 int op1 = 0, int op2 = 0, int op3 = 0, int op4 = 0,
26 LIR* target = NULL);
buzbeea2ebdd72012-03-04 14:57:06 -080027
buzbeee88dfbf2012-03-05 11:19:57 -080028int oatGetInsnSize(LIR* lir);
29
buzbee84fd6932012-03-29 16:44:16 -070030void genFusedLongCmpBranch(CompilationUnit* cUnit, BasicBlock* bb, MIR* mir);
31void genFusedFPCmpBranch(CompilationUnit* cUnit, BasicBlock* bb, MIR* mir,
32 bool gtBias, bool isDouble);
33
34
buzbee67bf8852011-08-17 17:51:35 -070035/* Lower middle-level IR to low-level IR for the whole method */
36void oatMethodMIR2LIR(CompilationUnit* cUnit);
37
buzbee16da88c2012-03-20 10:38:17 -070038/* Lower middle-level IR to low-level IR for the simple methods */
39void oatSpecialMIR2LIR(CompilationUnit* cUnit, SpecialCaseHandler specialCase );
40
buzbee67bf8852011-08-17 17:51:35 -070041/* Assemble LIR into machine code */
42void oatAssembleLIR(CompilationUnit* cUnit);
buzbeee3acd072012-02-25 17:03:10 -080043AssemblerStatus oatAssembleInstructions(CompilationUnit* cUnit,
44 intptr_t startAddr);
45void oatAssignOffsets(CompilationUnit* cUnit);
46int oatAssignInsnOffsets(CompilationUnit* cUnit);
buzbee67bf8852011-08-17 17:51:35 -070047
48/* Implemented in the codegen/<target>/ArchUtility.c */
49void oatCodegenDump(CompilationUnit* cUnit);
buzbee67bc2362011-10-11 18:08:40 -070050void oatDumpPromotionMap(CompilationUnit* cUnit);
buzbee5de34942012-03-01 14:51:57 -080051std::string buildInsnString(const char* fmt, LIR* lir,
52 unsigned char* baseAddr);
53
buzbee67bf8852011-08-17 17:51:35 -070054
55/* Implemented in codegen/<target>/Ralloc.c */
56void oatSimpleRegAlloc(CompilationUnit* cUnit);
57
58/* Implemented in codegen/<target>/Thumb<version>Util.c */
59void oatInitializeRegAlloc(CompilationUnit* cUnit);
60
61/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
Elliott Hughesb3bd5f02012-03-08 21:05:27 -080062InstructionSet oatInstructionSet();
buzbee67bf8852011-08-17 17:51:35 -070063
64/*
65 * Implemented in codegen/<target>/<target_variant>/ArchVariant.c
66 * Architecture-specific initializations and checks
67 */
68bool oatArchVariantInit(void);
69
70/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
71int oatTargetOptHint(int key);
72
73/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
74void oatGenMemBarrier(CompilationUnit* cUnit, int barrierKind);
75
Elliott Hughes11d1b0c2012-01-23 16:57:47 -080076} // namespace art
77
buzbee67bf8852011-08-17 17:51:35 -070078#endif // ART_SRC_COMPILER_COMPILERCODEGEN_H_