diff options
| author | 2014-12-20 07:10:32 +0000 | |
|---|---|---|
| committer | 2014-12-20 07:10:32 +0000 | |
| commit | 5e3dd904f86783bf4b835084c51d8d3625f00897 (patch) | |
| tree | 2416a0ac16579a4b1bcc529218df740d0aaf5002 | |
| parent | 634d58a91ed636043feed600ca17c6c945a4fb20 (diff) | |
| parent | 44893692bfb25ceb5c7c5b2e5c606948fbdea298 (diff) | |
Merge "ART: Use interpret-only for vmSafeMode" into lmp-mr1-dev
| -rw-r--r-- | runtime/native/dalvik_system_ZygoteHooks.cc | 10 | ||||
| -rw-r--r-- | runtime/runtime.h | 4 |
2 files changed, 12 insertions, 2 deletions
diff --git a/runtime/native/dalvik_system_ZygoteHooks.cc b/runtime/native/dalvik_system_ZygoteHooks.cc index a4ef839ae0..5b41d5feeb 100644 --- a/runtime/native/dalvik_system_ZygoteHooks.cc +++ b/runtime/native/dalvik_system_ZygoteHooks.cc @@ -83,9 +83,15 @@ static void EnableDebugFeatures(uint32_t debug_flags) { } debug_flags &= ~DEBUG_ENABLE_DEBUGGER; - // These two are for backwards compatibility with Dalvik. + if ((debug_flags & DEBUG_ENABLE_SAFEMODE) != 0) { + // Ensure that any (secondary) oat files will be interpreted. + Runtime* runtime = Runtime::Current(); + runtime->AddCompilerOption("--compiler-filter=interpret-only"); + debug_flags &= ~DEBUG_ENABLE_SAFEMODE; + } + + // This is for backwards compatibility with Dalvik. debug_flags &= ~DEBUG_ENABLE_ASSERT; - debug_flags &= ~DEBUG_ENABLE_SAFEMODE; if (debug_flags != 0) { LOG(ERROR) << StringPrintf("Unknown bits set in debug_flags: %#x", debug_flags); diff --git a/runtime/runtime.h b/runtime/runtime.h index 60cb529542..6980e8d1ba 100644 --- a/runtime/runtime.h +++ b/runtime/runtime.h @@ -133,6 +133,10 @@ class Runtime { return compiler_options_; } + void AddCompilerOption(std::string option) { + compiler_options_.push_back(option); + } + const std::vector<std::string>& GetImageCompilerOptions() const { return image_compiler_options_; } |