diff options
author | 2019-06-26 22:00:02 +0000 | |
---|---|---|
committer | 2019-06-26 22:00:38 +0000 | |
commit | 2fef66b294417d447630f9d98de68227eef476d3 (patch) | |
tree | 59fc4ea6cf13217eb92fbdd4e39561b5ad518cf0 /compiler/optimizing/sharpening.cc | |
parent | 21d5994583c679cd5d8573b5d35dbd659bdca2c7 (diff) |
Revert "Make the JIT zygote memory shared."
This reverts commit 05f87217ddc9b4b9186710c0135b918f456c5aef.
Bug: 119800099
Bug: 136110523
Reason for revert: testWebview flaking
Change-Id: I96afa6bc9c56c4aaf5ed72ae370f6f69c096c559
Diffstat (limited to 'compiler/optimizing/sharpening.cc')
-rw-r--r-- | compiler/optimizing/sharpening.cc | 41 |
1 files changed, 8 insertions, 33 deletions
diff --git a/compiler/optimizing/sharpening.cc b/compiler/optimizing/sharpening.cc index 3e22edc773..8637db13ad 100644 --- a/compiler/optimizing/sharpening.cc +++ b/compiler/optimizing/sharpening.cc @@ -19,7 +19,6 @@ #include "art_method-inl.h" #include "base/casts.h" #include "base/enums.h" -#include "base/logging.h" #include "class_linker.h" #include "code_generator.h" #include "driver/compiler_options.h" @@ -27,7 +26,6 @@ #include "gc/heap.h" #include "gc/space/image_space.h" #include "handle_scope-inl.h" -#include "jit/jit.h" #include "mirror/dex_cache.h" #include "mirror/string.h" #include "nodes.h" @@ -100,17 +98,11 @@ HInvokeStaticOrDirect::DispatchInfo HSharpening::SharpenInvokeStaticOrDirect( } code_ptr_location = HInvokeStaticOrDirect::CodePtrLocation::kCallArtMethod; } else if (Runtime::Current()->UseJitCompilation()) { - if (Runtime::Current()->GetJit()->CanEncodeMethod( - callee, - codegen->GetGraph()->IsCompilingForSharedJitCode())) { - method_load_kind = HInvokeStaticOrDirect::MethodLoadKind::kJitDirectAddress; - method_load_data = reinterpret_cast<uintptr_t>(callee); - code_ptr_location = HInvokeStaticOrDirect::CodePtrLocation::kCallArtMethod; - } else { - // Do not sharpen. - method_load_kind = HInvokeStaticOrDirect::MethodLoadKind::kRuntimeCall; - code_ptr_location = HInvokeStaticOrDirect::CodePtrLocation::kCallArtMethod; - } + // JIT or on-device AOT compilation referencing a boot image method. + // Use the method address directly. + method_load_kind = HInvokeStaticOrDirect::MethodLoadKind::kJitDirectAddress; + method_load_data = reinterpret_cast<uintptr_t>(callee); + code_ptr_location = HInvokeStaticOrDirect::CodePtrLocation::kCallArtMethod; } else if (IsInBootImage(callee)) { // Use PC-relative access to the .data.bimg.rel.ro methods array. method_load_kind = HInvokeStaticOrDirect::MethodLoadKind::kBootImageRelRo; @@ -183,16 +175,7 @@ HLoadClass::LoadKind HSharpening::ComputeLoadClassKind( if (is_in_boot_image) { desired_load_kind = HLoadClass::LoadKind::kJitBootImageAddress; } else if (klass != nullptr) { - if (runtime->GetJit()->CanEncodeClass( - klass.Get(), - codegen->GetGraph()->IsCompilingForSharedJitCode())) { - desired_load_kind = HLoadClass::LoadKind::kJitTableAddress; - } else { - // Shared JIT code cannot encode a literal that the GC can move. - VLOG(jit) << "Unable to encode in shared region class literal: " - << klass->PrettyClass(); - desired_load_kind = HLoadClass::LoadKind::kRuntimeCall; - } + desired_load_kind = HLoadClass::LoadKind::kJitTableAddress; } else { // Class not loaded yet. This happens when the dex code requesting // this `HLoadClass` hasn't been executed in the interpreter. @@ -348,18 +331,10 @@ void HSharpening::ProcessLoadString( DCHECK(!codegen->GetCompilerOptions().GetCompilePic()); string = class_linker->LookupString(string_index, dex_cache.Get()); if (string != nullptr) { - gc::Heap* heap = runtime->GetHeap(); - if (heap->ObjectIsInBootImageSpace(string)) { + if (runtime->GetHeap()->ObjectIsInBootImageSpace(string)) { desired_load_kind = HLoadString::LoadKind::kJitBootImageAddress; - } else if (runtime->GetJit()->CanEncodeString( - string, - codegen->GetGraph()->IsCompilingForSharedJitCode())) { - desired_load_kind = HLoadString::LoadKind::kJitTableAddress; } else { - // Shared JIT code cannot encode a literal that the GC can move. - VLOG(jit) << "Unable to encode in shared region string literal: " - << string->ToModifiedUtf8(); - desired_load_kind = HLoadString::LoadKind::kRuntimeCall; + desired_load_kind = HLoadString::LoadKind::kJitTableAddress; } } else { desired_load_kind = HLoadString::LoadKind::kRuntimeCall; |