diff options
author | Sebastien Hertz <shertz@google.com> | 2015-05-13 12:14:05 +0200 |
---|---|---|
committer | Sebastien Hertz <shertz@google.com> | 2015-05-19 19:39:18 +0200 |
commit | 094ff2c0c1f736521c634d5f606e274cb6c55345 (patch) | |
tree | 9e126be21844e24645120e84e511cbe8f9c33091 /runtime/class_linker.cc | |
parent | ce70082da8a4e63c280c2f049a67b38acc82ee1a (diff) | |
download | android_art-094ff2c0c1f736521c634d5f606e274cb6c55345.tar.gz android_art-094ff2c0c1f736521c634d5f606e274cb6c55345.tar.bz2 android_art-094ff2c0c1f736521c634d5f606e274cb6c55345.zip |
Fix debuggable compiler flag detection for secondary dex files
Compiles secondary dex files like the primary dex file: if it has
been compiled with the --debuggable flag, compile secondary dex files
with the --debuggable flag too.
Therefore, dex files loaded at runtime are compiled the same way as
dex files compiled at install time on the classpath (excluding the
boot image that is not compiled debuggable).
Also adds debuggable key in the oat header and bump the oat version.
Bug: 20944228
(cherry picked from commit 0de1133ba600f299b3d67938f650720d9f859eb2)
Change-Id: If6b2236e7fe547cc421f57b573043748018d3ae0
Diffstat (limited to 'runtime/class_linker.cc')
-rw-r--r-- | runtime/class_linker.cc | 41 |
1 files changed, 29 insertions, 12 deletions
diff --git a/runtime/class_linker.cc b/runtime/class_linker.cc index b099088e4d..292f830764 100644 --- a/runtime/class_linker.cc +++ b/runtime/class_linker.cc @@ -819,6 +819,34 @@ static void FreeDexFilesInHeap(std::priority_queue<DexFileAndClassPair>* heap) { } } +const OatFile* ClassLinker::GetBootOatFile() { + // To grab the boot oat, look at the dex files in the boot classpath. Any of those is fine, as + // they were all compiled into the same oat file. So grab the first one, which is guaranteed to + // exist if the boot class-path isn't empty. + if (boot_class_path_.empty()) { + return nullptr; + } + const DexFile* boot_dex_file = boot_class_path_[0]; + // Is it from an oat file? + if (boot_dex_file->GetOatDexFile() != nullptr) { + return boot_dex_file->GetOatDexFile()->GetOatFile(); + } + return nullptr; +} + +const OatFile* ClassLinker::GetPrimaryOatFile() { + ReaderMutexLock mu(Thread::Current(), dex_lock_); + const OatFile* boot_oat_file = GetBootOatFile(); + if (boot_oat_file != nullptr) { + for (const OatFile* oat_file : oat_files_) { + if (oat_file != boot_oat_file) { + return oat_file; + } + } + } + return nullptr; +} + // Check for class-def collisions in dex files. // // This works by maintaining a heap with one class from each dex file, sorted by the class @@ -835,18 +863,7 @@ bool ClassLinker::HasCollisions(const OatFile* oat_file, std::string* error_msg) // Add dex files from already loaded oat files, but skip boot. { - // To grab the boot oat, look at the dex files in the boot classpath. Any of those is fine, as - // they were all compiled into the same oat file. So grab the first one, which is guaranteed to - // exist if the boot class-path isn't empty. - const OatFile* boot_oat = nullptr; - if (!boot_class_path_.empty()) { - const DexFile* boot_dex_file = boot_class_path_[0]; - // Is it from an oat file? - if (boot_dex_file->GetOatDexFile() != nullptr) { - boot_oat = boot_dex_file->GetOatDexFile()->GetOatFile(); - } - } - + const OatFile* boot_oat = GetBootOatFile(); for (const OatFile* loaded_oat_file : oat_files_) { if (loaded_oat_file == boot_oat) { continue; |