summaryrefslogtreecommitdiff
path: root/compiler/image_writer.cc
diff options
context:
space:
mode:
author Igor Murashkin <iam@google.com> 2016-02-19 16:41:44 -0800
committer Igor Murashkin <iam@google.com> 2016-02-23 14:04:34 -0800
commit6e2237d6615c8f7b09c99d196e5effcfd087943b (patch)
treeea75bf62feca0fd85d2c5de236a2dfb262832693 /compiler/image_writer.cc
parent812e118043357c83800aa07a1133a32c3597c7c0 (diff)
image: Allow methods with code in another oat file to work correctly
This fixes an issue when classes with default methods are in the boot image and are used by an app image. Bug: 27315287 Change-Id: Iaa66848fc07a0c779bc6e047bd154e2a4b87e1c8
Diffstat (limited to 'compiler/image_writer.cc')
-rw-r--r--compiler/image_writer.cc16
1 files changed, 13 insertions, 3 deletions
diff --git a/compiler/image_writer.cc b/compiler/image_writer.cc
index d50528edee..a4feff690c 100644
--- a/compiler/image_writer.cc
+++ b/compiler/image_writer.cc
@@ -2044,9 +2044,19 @@ const uint8_t* ImageWriter::GetQuickCode(ArtMethod* method,
// trampoline.
// Quick entrypoint:
- uint32_t quick_oat_code_offset = PointerToLowMemUInt32(
- method->GetEntryPointFromQuickCompiledCodePtrSize(target_ptr_size_));
- const uint8_t* quick_code = GetOatAddressForOffset(quick_oat_code_offset, image_info);
+ const void* quick_oat_entry_point =
+ method->GetEntryPointFromQuickCompiledCodePtrSize(target_ptr_size_);
+ const uint8_t* quick_code;
+
+ if (UNLIKELY(IsInBootImage(method->GetDeclaringClass()))) {
+ DCHECK(method->MightBeCopied());
+ // If the code is not in the oat file corresponding to this image (e.g. default methods)
+ quick_code = reinterpret_cast<const uint8_t*>(quick_oat_entry_point);
+ } else {
+ uint32_t quick_oat_code_offset = PointerToLowMemUInt32(quick_oat_entry_point);
+ quick_code = GetOatAddressForOffset(quick_oat_code_offset, image_info);
+ }
+
*quick_is_interpreted = false;
if (quick_code != nullptr && (!method->IsStatic() || method->IsConstructor() ||
method->GetDeclaringClass()->IsInitialized())) {