blob: 1137db3796ef33bc44b16712cdc794b285688096 [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
32/* Assemble LIR into machine code */
33void oatAssembleLIR(CompilationUnit* cUnit);
buzbeee3acd072012-02-25 17:03:10 -080034AssemblerStatus oatAssembleInstructions(CompilationUnit* cUnit,
35 intptr_t startAddr);
36void oatAssignOffsets(CompilationUnit* cUnit);
37int oatAssignInsnOffsets(CompilationUnit* cUnit);
buzbee67bf8852011-08-17 17:51:35 -070038
39/* Implemented in the codegen/<target>/ArchUtility.c */
40void oatCodegenDump(CompilationUnit* cUnit);
buzbee67bc2362011-10-11 18:08:40 -070041void oatDumpPromotionMap(CompilationUnit* cUnit);
buzbee5de34942012-03-01 14:51:57 -080042std::string buildInsnString(const char* fmt, LIR* lir,
43 unsigned char* baseAddr);
44
buzbee67bf8852011-08-17 17:51:35 -070045
46/* Implemented in codegen/<target>/Ralloc.c */
47void oatSimpleRegAlloc(CompilationUnit* cUnit);
48
49/* Implemented in codegen/<target>/Thumb<version>Util.c */
50void oatInitializeRegAlloc(CompilationUnit* cUnit);
51
52/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
Elliott Hughesb3bd5f02012-03-08 21:05:27 -080053InstructionSet oatInstructionSet();
buzbee67bf8852011-08-17 17:51:35 -070054
55/*
56 * Implemented in codegen/<target>/<target_variant>/ArchVariant.c
57 * Architecture-specific initializations and checks
58 */
59bool oatArchVariantInit(void);
60
61/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
62int oatTargetOptHint(int key);
63
64/* Implemented in codegen/<target>/<target_variant>/ArchVariant.c */
65void oatGenMemBarrier(CompilationUnit* cUnit, int barrierKind);
66
Elliott Hughes11d1b0c2012-01-23 16:57:47 -080067} // namespace art
68
buzbee67bf8852011-08-17 17:51:35 -070069#endif // ART_SRC_COMPILER_COMPILERCODEGEN_H_