blob: 1237e7019a915f7185cb71c7617d25b852f780d1 [file] [log] [blame]
Nicolas Geoffrayb34f69a2014-03-07 15:28:39 +00001/*
2 * Copyright (C) 2014 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#include "compilers.h"
18#include "dex/mir_graph.h"
19#include "dex/quick/mir_to_lir.h"
20#include "elf_writer_quick.h"
21#include "mirror/art_method-inl.h"
22
23namespace art {
24
25extern "C" void ArtInitQuickCompilerContext(art::CompilerDriver& driver);
26extern "C" void ArtUnInitQuickCompilerContext(art::CompilerDriver& driver);
27extern "C" art::CompiledMethod* ArtQuickCompileMethod(art::CompilerDriver& driver,
28 const art::DexFile::CodeItem* code_item,
29 uint32_t access_flags,
30 art::InvokeType invoke_type,
31 uint16_t class_def_idx,
32 uint32_t method_idx,
33 jobject class_loader,
34 const art::DexFile& dex_file);
35
36extern "C" art::CompiledMethod* ArtQuickJniCompileMethod(art::CompilerDriver& driver,
37 uint32_t access_flags, uint32_t method_idx,
38 const art::DexFile& dex_file);
39
40// Hack for CFI CIE initialization
41extern std::vector<uint8_t>* X86CFIInitialization();
42
43void QuickCompiler::Init(CompilerDriver& driver) const {
44 ArtInitQuickCompilerContext(driver);
45}
46
47void QuickCompiler::UnInit(CompilerDriver& driver) const {
48 ArtUnInitQuickCompilerContext(driver);
49}
50
51CompiledMethod* QuickCompiler::Compile(CompilerDriver& driver,
52 const DexFile::CodeItem* code_item,
53 uint32_t access_flags,
54 InvokeType invoke_type,
55 uint16_t class_def_idx,
56 uint32_t method_idx,
57 jobject class_loader,
58 const DexFile& dex_file) const {
59 CompiledMethod* method = TryCompileWithSeaIR(driver,
60 code_item,
61 access_flags,
62 invoke_type,
63 class_def_idx,
64 method_idx,
65 class_loader,
66 dex_file);
67 if (method != nullptr) return method;
68
69 return ArtQuickCompileMethod(driver,
70 code_item,
71 access_flags,
72 invoke_type,
73 class_def_idx,
74 method_idx,
75 class_loader,
76 dex_file);
77}
78
79CompiledMethod* QuickCompiler::JniCompile(CompilerDriver& driver,
80 uint32_t access_flags,
81 uint32_t method_idx,
82 const DexFile& dex_file) const {
83 return ArtQuickJniCompileMethod(driver, access_flags, method_idx, dex_file);
84}
85
86uintptr_t QuickCompiler::GetEntryPointOf(mirror::ArtMethod* method) const {
87 return reinterpret_cast<uintptr_t>(method->GetEntryPointFromQuickCompiledCode());
88}
89
90bool QuickCompiler::WriteElf(art::File* file,
91 OatWriter* oat_writer,
92 const std::vector<const art::DexFile*>& dex_files,
93 const std::string& android_root,
Ian Rogers9758f792014-03-13 09:02:55 -070094 bool is_host, const CompilerDriver& driver) const {
Nicolas Geoffrayb34f69a2014-03-07 15:28:39 +000095 return art::ElfWriterQuick::Create(file, oat_writer, dex_files, android_root, is_host, driver);
96}
97
98Backend* QuickCompiler::GetCodeGenerator(CompilationUnit* cu, void* compilation_unit) const {
99 Mir2Lir* mir_to_lir = nullptr;
100 switch (cu->instruction_set) {
101 case kThumb2:
102 mir_to_lir = ArmCodeGenerator(cu, cu->mir_graph.get(), &cu->arena);
103 break;
104 case kMips:
105 mir_to_lir = MipsCodeGenerator(cu, cu->mir_graph.get(), &cu->arena);
106 break;
107 case kX86:
108 mir_to_lir = X86CodeGenerator(cu, cu->mir_graph.get(), &cu->arena);
109 break;
Dmitry Petrochenko6a58cb12014-04-02 17:27:59 +0700110 case kX86_64:
111 mir_to_lir = X86CodeGenerator(cu, cu->mir_graph.get(), &cu->arena);
112 break;
Nicolas Geoffrayb34f69a2014-03-07 15:28:39 +0000113 default:
114 LOG(FATAL) << "Unexpected instruction set: " << cu->instruction_set;
115 }
116
117 /* The number of compiler temporaries depends on backend so set it up now if possible */
118 if (mir_to_lir) {
119 size_t max_temps = mir_to_lir->GetMaxPossibleCompilerTemps();
120 bool set_max = cu->mir_graph->SetMaxAvailableNonSpecialCompilerTemps(max_temps);
121 CHECK(set_max);
122 }
123 return mir_to_lir;
124}
125
126std::vector<uint8_t>* QuickCompiler::GetCallFrameInformationInitialization(
Nicolas Geoffray896362b2014-03-13 09:50:25 +0000127 const CompilerDriver& driver) const {
Nicolas Geoffrayb34f69a2014-03-07 15:28:39 +0000128 if (driver.GetInstructionSet() == kX86) {
129 return X86CFIInitialization();
130 }
Dmitry Petrochenko6a58cb12014-04-02 17:27:59 +0700131 if (driver.GetInstructionSet() == kX86_64) {
132 return X86CFIInitialization();
133 }
Nicolas Geoffrayb34f69a2014-03-07 15:28:39 +0000134 return nullptr;
135}
136
137CompiledMethod* OptimizingCompiler::Compile(CompilerDriver& driver,
138 const DexFile::CodeItem* code_item,
139 uint32_t access_flags,
140 InvokeType invoke_type,
141 uint16_t class_def_idx,
142 uint32_t method_idx,
143 jobject class_loader,
144 const DexFile& dex_file) const {
145 CompiledMethod* method = TryCompile(
146 driver, code_item, access_flags, invoke_type, class_def_idx, method_idx,
147 class_loader, dex_file);
148 if (method != nullptr) return method;
149
150 return QuickCompiler::Compile(
151 driver, code_item, access_flags, invoke_type, class_def_idx, method_idx,
152 class_loader, dex_file);
153}
154
155} // namespace art