blob: 20b2e455748d4f950cb17c527497b8a6d8ecaff1 [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,
Ian Rogersb5d09b22012-03-06 22:14:17 -080025 int op1 = 0, int op2 = 0, int op3 = 0, int op4 = 0, LIR* target = NULL);
buzbeea2ebdd72012-03-04 14:57:06 -080026
buzbeee88dfbf2012-03-05 11:19:57 -080027int oatGetInsnSize(LIR* lir);
28
buzbee84fd6932012-03-29 16:44:16 -070029void genFusedLongCmpBranch(CompilationUnit* cUnit, BasicBlock* bb, MIR* mir);
30void genFusedFPCmpBranch(CompilationUnit* cUnit, BasicBlock* bb, MIR* mir,
31 bool gtBias, bool isDouble);
32
33
buzbee67bf8852011-08-17 17:51:35 -070034/* Lower middle-level IR to low-level IR for the whole method */
35void oatMethodMIR2LIR(CompilationUnit* cUnit);
36
buzbee16da88c2012-03-20 10:38:17 -070037/* Lower middle-level IR to low-level IR for the simple methods */
38void oatSpecialMIR2LIR(CompilationUnit* cUnit, SpecialCaseHandler specialCase );
39
buzbee67bf8852011-08-17 17:51:35 -070040/* Assemble LIR into machine code */
41void oatAssembleLIR(CompilationUnit* cUnit);
buzbeee3acd072012-02-25 17:03:10 -080042AssemblerStatus oatAssembleInstructions(CompilationUnit* cUnit,
43 intptr_t startAddr);
44void oatAssignOffsets(CompilationUnit* cUnit);
45int oatAssignInsnOffsets(CompilationUnit* cUnit);
buzbee67bf8852011-08-17 17:51:35 -070046
47/* Implemented in the codegen/<target>/ArchUtility.c */
48void oatCodegenDump(CompilationUnit* cUnit);
buzbee67bc2362011-10-11 18:08:40 -070049void oatDumpPromotionMap(CompilationUnit* cUnit);
buzbee5de34942012-03-01 14:51:57 -080050std::string buildInsnString(const char* fmt, LIR* lir,
51 unsigned char* baseAddr);
52
buzbee67bf8852011-08-17 17:51:35 -070053
54/* Implemented in codegen/<target>/Ralloc.c */
55void oatSimpleRegAlloc(CompilationUnit* cUnit);
56
57/* Implemented in codegen/<target>/Thumb<version>Util.c */
58void oatInitializeRegAlloc(CompilationUnit* cUnit);
59
60/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
Elliott Hughesb3bd5f02012-03-08 21:05:27 -080061InstructionSet oatInstructionSet();
buzbee67bf8852011-08-17 17:51:35 -070062
63/*
64 * Implemented in codegen/<target>/<target_variant>/ArchVariant.c
65 * Architecture-specific initializations and checks
66 */
67bool oatArchVariantInit(void);
68
69/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
70int oatTargetOptHint(int key);
71
72/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
73void oatGenMemBarrier(CompilationUnit* cUnit, int barrierKind);
74
Elliott Hughes11d1b0c2012-01-23 16:57:47 -080075} // namespace art
76
buzbee67bf8852011-08-17 17:51:35 -070077#endif // ART_SRC_COMPILER_COMPILERCODEGEN_H_