diff options
author | Andreas Gampe <agampe@google.com> | 2014-08-12 23:19:23 -0700 |
---|---|---|
committer | Andreas Gampe <agampe@google.com> | 2014-08-22 21:20:08 -0700 |
commit | 53c913bb71b218714823c8c87a1f92830c336f61 (patch) | |
tree | 96aebfc9ae62eb1454b78286236567e2b6f3e5c7 /compiler/llvm/compiler_llvm.cc | |
parent | e18aa4316eb9a15cd6b1051f27a1ce49967c170e (diff) | |
download | android_art-53c913bb71b218714823c8c87a1f92830c336f61.tar.gz android_art-53c913bb71b218714823c8c87a1f92830c336f61.tar.bz2 android_art-53c913bb71b218714823c8c87a1f92830c336f61.zip |
ART: Clean up compiler
Clean up the compiler: less extern functions, dis-entangle
compilers, hide some compiler specifics, lower global includes.
Change-Id: Ibaf88d02505d86994d7845cf0075be5041cc8438
Diffstat (limited to 'compiler/llvm/compiler_llvm.cc')
-rw-r--r-- | compiler/llvm/compiler_llvm.cc | 68 |
1 files changed, 31 insertions, 37 deletions
diff --git a/compiler/llvm/compiler_llvm.cc b/compiler/llvm/compiler_llvm.cc index 5990e8caea..3aeecad78e 100644 --- a/compiler/llvm/compiler_llvm.cc +++ b/compiler/llvm/compiler_llvm.cc @@ -141,7 +141,7 @@ CompileDexMethod(DexCompilationUnit* dex_compilation_unit, InvokeType invoke_typ cunit->SetDexCompilationUnit(dex_compilation_unit); cunit->SetCompilerDriver(compiler_driver_); // TODO: consolidate ArtCompileMethods - CompileOneMethod(*compiler_driver_, + CompileOneMethod(compiler_driver_, compiler_driver_->GetCompiler(), dex_compilation_unit->GetCodeItem(), dex_compilation_unit->GetAccessFlags(), @@ -172,68 +172,62 @@ CompileNativeMethod(DexCompilationUnit* dex_compilation_unit) { } -} // namespace llvm -} // namespace art - -static art::llvm::CompilerLLVM* ContextOf(art::CompilerDriver* driver) { +static CompilerLLVM* ContextOf(art::CompilerDriver* driver) { void *compiler_context = driver->GetCompilerContext(); CHECK(compiler_context != NULL); - return reinterpret_cast<art::llvm::CompilerLLVM*>(compiler_context); + return reinterpret_cast<CompilerLLVM*>(compiler_context); } -static art::llvm::CompilerLLVM* ContextOf(const art::CompilerDriver& driver) { +static CompilerLLVM* ContextOf(const art::CompilerDriver& driver) { void *compiler_context = driver.GetCompilerContext(); CHECK(compiler_context != NULL); - return reinterpret_cast<art::llvm::CompilerLLVM*>(compiler_context); + return reinterpret_cast<CompilerLLVM*>(compiler_context); } -extern "C" void ArtInitCompilerContext(art::CompilerDriver* driver) { +void ArtInitCompilerContext(CompilerDriver* driver) { CHECK(driver->GetCompilerContext() == nullptr); - art::llvm::CompilerLLVM* compiler_llvm = new art::llvm::CompilerLLVM(driver, - driver->GetInstructionSet()); + CompilerLLVM* compiler_llvm = new CompilerLLVM(driver, driver->GetInstructionSet()); driver->SetCompilerContext(compiler_llvm); } -extern "C" void ArtUnInitCompilerContext(art::CompilerDriver* driver) { +void ArtUnInitCompilerContext(CompilerDriver* driver) { delete ContextOf(driver); driver->SetCompilerContext(nullptr); } -extern "C" art::CompiledMethod* ArtCompileMethod(art::CompilerDriver* driver, - const art::DexFile::CodeItem* code_item, - uint32_t access_flags, - art::InvokeType invoke_type, - uint16_t class_def_idx, - uint32_t method_idx, - jobject class_loader, - const art::DexFile& dex_file) { + +CompiledMethod* ArtCompileMethod(CompilerDriver* driver, const DexFile::CodeItem* code_item, + uint32_t access_flags, InvokeType invoke_type, + uint16_t class_def_idx, uint32_t method_idx, jobject class_loader, + const DexFile& dex_file) { UNUSED(class_def_idx); // TODO: this is used with Compiler::RequiresConstructorBarrier. - art::ClassLinker *class_linker = art::Runtime::Current()->GetClassLinker(); + ClassLinker *class_linker = Runtime::Current()->GetClassLinker(); - art::DexCompilationUnit dex_compilation_unit( - NULL, class_loader, class_linker, dex_file, code_item, - class_def_idx, method_idx, access_flags, driver->GetVerifiedMethod(&dex_file, method_idx)); - art::llvm::CompilerLLVM* compiler_llvm = ContextOf(driver); - art::CompiledMethod* result = compiler_llvm->CompileDexMethod(&dex_compilation_unit, invoke_type); + DexCompilationUnit dex_compilation_unit(nullptr, class_loader, class_linker, dex_file, code_item, + class_def_idx, method_idx, access_flags, + driver->GetVerifiedMethod(&dex_file, method_idx)); + CompilerLLVM* compiler_llvm = ContextOf(driver); + CompiledMethod* result = compiler_llvm->CompileDexMethod(&dex_compilation_unit, invoke_type); return result; } -extern "C" art::CompiledMethod* ArtLLVMJniCompileMethod(art::CompilerDriver* driver, - uint32_t access_flags, uint32_t method_idx, - const art::DexFile& dex_file) { - art::ClassLinker *class_linker = art::Runtime::Current()->GetClassLinker(); +CompiledMethod* ArtLLVMJniCompileMethod(CompilerDriver* driver, uint32_t access_flags, + uint32_t method_idx, const DexFile& dex_file) { + ClassLinker *class_linker = Runtime::Current()->GetClassLinker(); - art::DexCompilationUnit dex_compilation_unit( - nullptr, nullptr, class_linker, dex_file, nullptr, - 0, method_idx, access_flags, nullptr); + DexCompilationUnit dex_compilation_unit(nullptr, nullptr, class_linker, dex_file, nullptr, + 0, method_idx, access_flags, nullptr); - art::llvm::CompilerLLVM* compiler_llvm = ContextOf(driver); - art::CompiledMethod* result = compiler_llvm->CompileNativeMethod(&dex_compilation_unit); + CompilerLLVM* compiler_llvm = ContextOf(driver); + CompiledMethod* result = compiler_llvm->CompileNativeMethod(&dex_compilation_unit); return result; } -extern "C" void compilerLLVMSetBitcodeFileName(const art::CompilerDriver& driver, - const std::string& filename) { +void compilerLLVMSetBitcodeFileName(const CompilerDriver& driver, const std::string& filename) { ContextOf(driver)->SetBitcodeFileName(filename); } + +} // namespace llvm +} // namespace art + |