blob: 8f854da6e160f0c65c529ece323c7fe468ca9548 [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
buzbee67bf8852011-08-17 17:51:35 -070029/* Lower middle-level IR to low-level IR for the whole method */
30void oatMethodMIR2LIR(CompilationUnit* cUnit);
31
buzbee16da88c2012-03-20 10:38:17 -070032/* Lower middle-level IR to low-level IR for the simple methods */
33void oatSpecialMIR2LIR(CompilationUnit* cUnit, SpecialCaseHandler specialCase );
34
buzbee67bf8852011-08-17 17:51:35 -070035/* Assemble LIR into machine code */
36void oatAssembleLIR(CompilationUnit* cUnit);
buzbeee3acd072012-02-25 17:03:10 -080037AssemblerStatus oatAssembleInstructions(CompilationUnit* cUnit,
38 intptr_t startAddr);
39void oatAssignOffsets(CompilationUnit* cUnit);
40int oatAssignInsnOffsets(CompilationUnit* cUnit);
buzbee67bf8852011-08-17 17:51:35 -070041
42/* Implemented in the codegen/<target>/ArchUtility.c */
43void oatCodegenDump(CompilationUnit* cUnit);
buzbee67bc2362011-10-11 18:08:40 -070044void oatDumpPromotionMap(CompilationUnit* cUnit);
buzbee5de34942012-03-01 14:51:57 -080045std::string buildInsnString(const char* fmt, LIR* lir,
46 unsigned char* baseAddr);
47
buzbee67bf8852011-08-17 17:51:35 -070048
49/* Implemented in codegen/<target>/Ralloc.c */
50void oatSimpleRegAlloc(CompilationUnit* cUnit);
51
52/* Implemented in codegen/<target>/Thumb<version>Util.c */
53void oatInitializeRegAlloc(CompilationUnit* cUnit);
54
55/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
Elliott Hughesb3bd5f02012-03-08 21:05:27 -080056InstructionSet oatInstructionSet();
buzbee67bf8852011-08-17 17:51:35 -070057
58/*
59 * Implemented in codegen/<target>/<target_variant>/ArchVariant.c
60 * Architecture-specific initializations and checks
61 */
62bool oatArchVariantInit(void);
63
64/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
65int oatTargetOptHint(int key);
66
67/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
68void oatGenMemBarrier(CompilationUnit* cUnit, int barrierKind);
69
Elliott Hughes11d1b0c2012-01-23 16:57:47 -080070} // namespace art
71
buzbee67bf8852011-08-17 17:51:35 -070072#endif // ART_SRC_COMPILER_COMPILERCODEGEN_H_