diff options
| author | 2016-02-16 12:50:23 +0000 | |
|---|---|---|
| committer | 2016-02-17 16:38:46 +0000 | |
| commit | 6065402316da2b51eed5fc34cffbd991766bd408 (patch) | |
| tree | cb93e32b978ea03a70baf980c470a03263c084c0 /compiler/driver/compiler_driver.cc | |
| parent | 442643920a6c539e98aad76594e99b932b5631ba (diff) | |
Allow method references across oat files for multi-image.
These were disabled because we didn't have sufficient
information about the multi-image layout when processing
link-time patches in OatWriter. This CL refactors the
ELF file creation so that the information is available.
Change-Id: I6f2e8dc8572d143c72cc2693bb0ba4fd76f889ab
Diffstat (limited to 'compiler/driver/compiler_driver.cc')
| -rw-r--r-- | compiler/driver/compiler_driver.cc | 18 | 
1 files changed, 7 insertions, 11 deletions
| diff --git a/compiler/driver/compiler_driver.cc b/compiler/driver/compiler_driver.cc index 670fe94988..e80730fe11 100644 --- a/compiler/driver/compiler_driver.cc +++ b/compiler/driver/compiler_driver.cc @@ -342,12 +342,15 @@ CompilerDriver::CompilerDriver(      Compiler::Kind compiler_kind,      InstructionSet instruction_set,      const InstructionSetFeatures* instruction_set_features, -    bool boot_image, std::unordered_set<std::string>* image_classes, +    bool boot_image, +    std::unordered_set<std::string>* image_classes,      std::unordered_set<std::string>* compiled_classes,      std::unordered_set<std::string>* compiled_methods, -    size_t thread_count, bool dump_stats, bool dump_passes, -    CumulativeLogger* timer, int swap_fd, -    const std::unordered_map<const DexFile*, const char*>* dex_to_oat_map, +    size_t thread_count, +    bool dump_stats, +    bool dump_passes, +    CumulativeLogger* timer, +    int swap_fd,      const ProfileCompilationInfo* profile_compilation_info)      : compiler_options_(compiler_options),        verification_results_(verification_results), @@ -374,7 +377,6 @@ CompilerDriver::CompilerDriver(        compiler_context_(nullptr),        support_boot_image_fixup_(instruction_set != kMips && instruction_set != kMips64),        dex_files_for_oat_file_(nullptr), -      dex_file_oat_filename_map_(dex_to_oat_map),        compiled_method_storage_(swap_fd),        profile_compilation_info_(profile_compilation_info) {    DCHECK(compiler_options_ != nullptr); @@ -1678,12 +1680,6 @@ void CompilerDriver::GetCodeAndMethodForDirectCall(InvokeType* type, InvokeType        use_dex_cache = true;      }    } -  if (!use_dex_cache && IsBootImage()) { -    if (!AreInSameOatFile(&(const_cast<mirror::Class*>(referrer_class)->GetDexFile()), -                          &declaring_class->GetDexFile())) { -      use_dex_cache = true; -    } -  }    // The method is defined not within this dex file. We need a dex cache slot within the current    // dex file or direct pointers.    bool must_use_direct_pointers = false; |