blob: e7b71e29f555bc6074c6dbe6fdc0ae38c6e8485a [file] [log] [blame]
Elliott Hughes2faa5f12012-01-30 14:42:07 -08001/*
2 * Copyright (C) 2011 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Carl Shapiro1fb86202011-06-27 17:43:13 -070016
Brian Carlstromfc0e3212013-07-17 14:40:12 -070017#ifndef ART_RUNTIME_RUNTIME_H_
18#define ART_RUNTIME_RUNTIME_H_
Carl Shapiro1fb86202011-06-27 17:43:13 -070019
Elliott Hughesa0e18062012-04-13 15:59:59 -070020#include <jni.h>
Elliott Hughesc5f7c912011-08-18 14:00:42 -070021#include <stdio.h>
22
Vladimir Markob6e67922021-07-06 15:53:07 +010023#include <forward_list>
Elliott Hughese27955c2011-08-26 15:21:24 -070024#include <iosfwd>
Eric Holka79872b2020-10-01 13:09:53 -070025#include <memory>
Hiroshi Yamauchi799eb3a2014-07-18 15:38:17 -070026#include <set>
Brian Carlstrom6ea095a2011-08-16 15:26:54 -070027#include <string>
Carl Shapirofc322c72011-07-27 00:20:01 -070028#include <utility>
Brian Carlstrom6ea095a2011-08-16 15:26:54 -070029#include <vector>
Brian Carlstrom578bbdc2011-07-21 14:07:47 -070030
Calin Juravlec2753e62021-06-25 15:34:09 -070031#include "app_info.h"
Andreas Gampe44f67602018-11-28 08:27:27 -080032#include "base/locks.h"
Andreas Gampe794ad762015-02-23 08:12:24 -080033#include "base/macros.h"
Vladimir Markoc34bebf2018-08-16 16:12:49 +010034#include "base/mem_map.h"
Eric Holk480d9812021-01-27 23:41:45 +000035#include "base/metrics/metrics.h"
Nicolas Geoffray4cbb51a2020-02-07 11:25:54 +000036#include "base/string_view_cpp20.h"
Andrei Onea037d2822020-11-19 00:20:04 +000037#include "compat_framework.h"
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +010038#include "deoptimization_kind.h"
David Sehr9e734c72018-01-04 17:56:19 -080039#include "dex/dex_file_types.h"
Alex Lighteb7c1442015-08-31 13:17:42 -070040#include "experimental_flags.h"
Hiroshi Yamauchi94f7b492014-07-22 18:08:23 -070041#include "gc_root.h"
Ian Rogers62d6c772013-02-27 08:32:07 -080042#include "instrumentation.h"
Alex Light40320712017-12-14 11:52:04 -080043#include "jdwp_provider.h"
Alex Light79d6c802019-06-27 15:50:11 +000044#include "jni/jni_id_manager.h"
45#include "jni_id_type.h"
Eric Holk39d529f2021-02-17 12:48:53 -080046#include "metrics/reporter.h"
Mathieu Chartier8778c522016-10-04 19:06:30 -070047#include "obj_ptr.h"
Ian Rogers576ca0c2014-06-06 15:58:22 -070048#include "offsets.h"
Mathieu Chartierf8cb1782016-03-18 18:45:41 -070049#include "process_state.h"
Vladimir Marko7624d252014-05-02 14:40:15 +010050#include "quick/quick_method_frame_info.h"
Alex Lightc18eba32019-09-24 14:36:27 -070051#include "reflective_value_visitor.h"
Elliott Hughes9d5ccec2011-09-19 13:19:50 -070052#include "runtime_stats.h"
Carl Shapirob5573532011-07-12 18:22:59 -070053
Carl Shapiro1fb86202011-06-27 17:43:13 -070054namespace art {
55
Ian Rogers1d54e732013-05-02 21:10:01 -070056namespace gc {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080057class AbstractSystemWeakHolder;
58class Heap;
Ian Rogers576ca0c2014-06-06 15:58:22 -070059} // namespace gc
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080060
Mathew Inwooda5dc52c2018-02-19 15:30:51 +000061namespace hiddenapi {
62enum class EnforcementPolicy;
63} // namespace hiddenapi
64
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080065namespace jit {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080066class Jit;
Orion Hodsonad28f5e2018-10-17 09:08:17 +010067class JitCodeCache;
Igor Murashkin2ffb7032017-11-08 13:35:21 -080068class JitOptions;
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080069} // namespace jit
70
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080071namespace mirror {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080072class Array;
73class ClassLoader;
74class DexCache;
75template<class T> class ObjectArray;
76template<class T> class PrimitiveArray;
Vladimir Marko4f990712021-07-14 12:45:13 +010077using ByteArray = PrimitiveArray<int8_t>;
Igor Murashkin2ffb7032017-11-08 13:35:21 -080078class String;
79class Throwable;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080080} // namespace mirror
Alex Light7233c7e2016-07-28 10:07:45 -070081namespace ti {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080082class Agent;
Andreas Gampeaadcbc62017-12-28 14:05:42 -080083class AgentSpec;
Alex Light7233c7e2016-07-28 10:07:45 -070084} // namespace ti
Mathieu Chartierc528dba2013-11-26 12:00:11 -080085namespace verifier {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080086class MethodVerifier;
87enum class VerifyMode : int8_t;
Ian Rogers6a3c1fc2014-10-31 00:33:20 -070088} // namespace verifier
Mathieu Chartiere401d142015-04-22 13:56:20 -070089class ArenaPool;
90class ArtMethod;
Andreas Gampe8228cdf2017-05-30 15:03:54 -070091enum class CalleeSaveType: uint32_t;
Carl Shapiro61e019d2011-07-14 16:53:09 -070092class ClassLinker;
Mathieu Chartiere401d142015-04-22 13:56:20 -070093class CompilerCallbacks;
Vladimir Markoc0e0e5e2020-01-23 17:43:05 +000094class Dex2oatImageTest;
Carl Shapirofc322c72011-07-27 00:20:01 -070095class DexFile;
Andreas Gampe639b2b12019-01-08 10:32:50 -080096enum class InstructionSet;
Elliott Hughescf4c6c42011-09-01 15:16:42 -070097class InternTable;
Andreas Gamped482e732017-04-24 17:59:09 -070098class IsMarkedVisitor;
Ian Rogersb48b9eb2014-02-28 16:20:21 -080099class JavaVMExt;
Mathieu Chartiere401d142015-04-22 13:56:20 -0700100class LinearAlloc;
Elliott Hughesc33a32b2011-10-11 18:18:07 -0700101class MonitorList;
Ian Rogersef7d42f2014-01-06 12:55:46 -0800102class MonitorPool;
Ian Rogers576ca0c2014-06-06 15:58:22 -0700103class NullPointerHandler;
Vladimir Markof3d88a82018-12-21 16:38:47 +0000104class OatFileAssistantTest;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -0700105class OatFileManager;
Alex Light185d1342016-08-11 10:48:03 -0700106class Plugin;
Vladimir Marko88b2b802015-12-04 14:19:04 +0000107struct RuntimeArgumentMap;
Andreas Gampeac30fa22017-01-18 21:02:36 -0800108class RuntimeCallbacks;
Elliott Hughese27955c2011-08-26 15:21:24 -0700109class SignalCatcher;
Hans Boehm4dcac362021-09-23 12:26:04 -0700110class SmallIrtAllocator;
Ian Rogers576ca0c2014-06-06 15:58:22 -0700111class StackOverflowHandler;
112class SuspensionHandler;
Carl Shapiro61e019d2011-07-14 16:53:09 -0700113class ThreadList;
Mathieu Chartierc6068c72018-11-13 16:00:58 -0800114class ThreadPool;
jeffhao2692b572011-12-16 15:42:28 -0800115class Trace;
Andreas Gampef6a780a2015-04-02 18:51:05 -0700116struct TraceConfig;
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100117class Transaction;
Carl Shapiro61e019d2011-07-14 16:53:09 -0700118
Vladimir Marko4f990712021-07-14 12:45:13 +0100119using RuntimeOptions = std::vector<std::pair<std::string, const void*>>;
Ian Rogerse63db272014-07-15 15:36:11 -0700120
Carl Shapiro1fb86202011-06-27 17:43:13 -0700121class Runtime {
122 public:
Vladimir Marko88b2b802015-12-04 14:19:04 +0000123 // Parse raw runtime options.
124 static bool ParseOptions(const RuntimeOptions& raw_options,
125 bool ignore_unrecognized,
126 RuntimeArgumentMap* runtime_options);
127
Carl Shapiro61e019d2011-07-14 16:53:09 -0700128 // Creates and initializes a new runtime.
Vladimir Marko88b2b802015-12-04 14:19:04 +0000129 static bool Create(RuntimeArgumentMap&& runtime_options)
130 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
131
132 // Creates and initializes a new runtime.
133 static bool Create(const RuntimeOptions& raw_options, bool ignore_unrecognized)
Ian Rogersb726dcb2012-09-05 08:57:23 -0700134 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
Brian Carlstrom69b15fb2011-09-03 12:25:21 -0700135
Florian Mayer07710c52019-09-16 15:53:38 +0000136 bool EnsurePluginLoaded(const char* plugin_name, std::string* error_msg);
137 bool EnsurePerfettoPlugin(std::string* error_msg);
138
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800139 // IsAotCompiler for compilers that don't have a running runtime. Only dex2oat currently.
140 bool IsAotCompiler() const {
Calin Juravleffc87072016-04-20 14:22:09 +0100141 return !UseJitCompilation() && IsCompiler();
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800142 }
143
144 // IsCompiler is any runtime which has a running compiler, either dex2oat or JIT.
Elliott Hughesd9c67be2012-02-02 19:54:06 -0800145 bool IsCompiler() const {
Vladimir Marko2b5eaa22013-12-13 13:59:30 +0000146 return compiler_callbacks_ != nullptr;
147 }
148
Andreas Gampe4585f872015-03-27 23:45:15 -0700149 // If a compiler, are we compiling a boot image?
150 bool IsCompilingBootImage() const;
151
152 bool CanRelocate() const;
Alex Lighta59dd802014-07-02 16:28:08 -0700153
154 bool ShouldRelocate() const {
155 return must_relocate_ && CanRelocate();
156 }
157
158 bool MustRelocateIfPossible() const {
159 return must_relocate_;
160 }
161
Alex Light64ad14d2014-08-19 14:23:13 -0700162 bool IsImageDex2OatEnabled() const {
163 return image_dex2oat_enabled_;
Nicolas Geoffray4fcdc942014-07-22 10:48:00 +0100164 }
165
Vladimir Marko2b5eaa22013-12-13 13:59:30 +0000166 CompilerCallbacks* GetCompilerCallbacks() {
167 return compiler_callbacks_;
Elliott Hughesd9c67be2012-02-02 19:54:06 -0800168 }
169
Mathieu Chartier07ddb6f2015-11-05 11:16:34 -0800170 void SetCompilerCallbacks(CompilerCallbacks* callbacks) {
171 CHECK(callbacks != nullptr);
172 compiler_callbacks_ = callbacks;
173 }
174
Brian Carlstromcaabb1b2011-10-11 18:09:13 -0700175 bool IsZygote() const {
176 return is_zygote_;
177 }
178
Nicolas Geoffray4444f1b2019-06-10 14:09:19 +0100179 bool IsPrimaryZygote() const {
180 return is_primary_zygote_;
181 }
182
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +0100183 bool IsSystemServer() const {
184 return is_system_server_;
185 }
186
Nicolas Geoffraya67daeb2019-08-12 10:41:25 +0100187 void SetAsSystemServer() {
188 is_system_server_ = true;
189 is_zygote_ = false;
190 is_primary_zygote_ = false;
191 }
192
193 void SetAsZygoteChild(bool is_system_server, bool is_zygote) {
194 // System server should have been set earlier in SetAsSystemServer.
195 CHECK_EQ(is_system_server_, is_system_server);
196 is_zygote_ = is_zygote;
197 is_primary_zygote_ = false;
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +0100198 }
199
Anwar Ghuloum87183592013-08-14 12:12:19 -0700200 bool IsExplicitGcDisabled() const {
201 return is_explicit_gc_disabled_;
202 }
203
Tsu Chiang Chuang12e6d742014-05-22 10:22:25 -0700204 std::string GetCompilerExecutable() const;
205
Brian Carlstrom6449c622014-02-10 23:48:36 -0800206 const std::vector<std::string>& GetCompilerOptions() const {
207 return compiler_options_;
Dragos Sbirlea7467ee02013-06-21 09:20:34 -0700208 }
209
Vladimir Marko5c657fe2016-11-03 15:12:29 +0000210 void AddCompilerOption(const std::string& option) {
Andreas Gamped2abbc92014-12-19 09:53:27 -0800211 compiler_options_.push_back(option);
212 }
213
Brian Carlstrom6449c622014-02-10 23:48:36 -0800214 const std::vector<std::string>& GetImageCompilerOptions() const {
215 return image_compiler_options_;
Anwar Ghuloum8447d842013-04-30 17:27:40 -0700216 }
217
Victor Hsieh61ffd042021-05-20 15:14:25 -0700218 const std::vector<std::string>& GetImageLocations() const {
219 return image_locations_;
Brian Carlstrom31d8f522014-09-29 11:22:54 -0700220 }
221
Brian Carlstrom69b15fb2011-09-03 12:25:21 -0700222 // Starts a runtime, which may cause threads to be started and code to run.
Brian Carlstrombd86bcc2013-03-10 20:26:16 -0700223 bool Start() UNLOCK_FUNCTION(Locks::mutator_lock_);
Carl Shapiro2ed144c2011-07-26 16:52:08 -0700224
Mathieu Chartier590fee92013-09-13 13:46:47 -0700225 bool IsShuttingDown(Thread* self);
Mathieu Chartier90443472015-07-16 20:32:27 -0700226 bool IsShuttingDownLocked() const REQUIRES(Locks::runtime_shutdown_lock_) {
Hans Boehm70aa29e2021-08-11 12:11:19 -0700227 return shutting_down_.load(std::memory_order_relaxed);
228 }
229 bool IsShuttingDownUnsafe() const {
230 return shutting_down_.load(std::memory_order_relaxed);
231 }
232 void SetShuttingDown() REQUIRES(Locks::runtime_shutdown_lock_) {
233 shutting_down_.store(true, std::memory_order_relaxed);
Ian Rogers9af209c2012-06-03 20:50:30 -0700234 }
235
Mathieu Chartier90443472015-07-16 20:32:27 -0700236 size_t NumberOfThreadsBeingBorn() const REQUIRES(Locks::runtime_shutdown_lock_) {
Ian Rogers120f1c72012-09-28 17:17:10 -0700237 return threads_being_born_;
238 }
239
Mathieu Chartier90443472015-07-16 20:32:27 -0700240 void StartThreadBirth() REQUIRES(Locks::runtime_shutdown_lock_) {
Ian Rogers120f1c72012-09-28 17:17:10 -0700241 threads_being_born_++;
242 }
243
Mathieu Chartier90443472015-07-16 20:32:27 -0700244 void EndThreadBirth() REQUIRES(Locks::runtime_shutdown_lock_);
Ian Rogers120f1c72012-09-28 17:17:10 -0700245
Ian Rogers9af209c2012-06-03 20:50:30 -0700246 bool IsStarted() const {
247 return started_;
248 }
Elliott Hughesdcc24742011-09-07 14:02:44 -0700249
Mathieu Chartier7664f5c2012-06-08 18:15:32 -0700250 bool IsFinishedStarting() const {
251 return finished_starting_;
252 }
253
Vladimir Markodcfcce42018-06-27 10:00:28 +0000254 void RunRootClinits(Thread* self) REQUIRES_SHARED(Locks::mutator_lock_);
255
Carl Shapiro2ed144c2011-07-26 16:52:08 -0700256 static Runtime* Current() {
257 return instance_;
258 }
Carl Shapiro1fb86202011-06-27 17:43:13 -0700259
Nicolas Geoffraydb978712014-12-09 13:33:38 +0000260 // Aborts semi-cleanly. Used in the implementation of LOG(FATAL), which most
261 // callers should prefer.
Andreas Gampe90a32b12016-10-03 19:47:08 -0700262 NO_RETURN static void Abort(const char* msg) REQUIRES(!Locks::abort_lock_);
Elliott Hughesffe67362011-07-17 12:09:27 -0700263
Ian Rogers365c1022012-06-22 15:05:28 -0700264 // Returns the "main" ThreadGroup, used when attaching user threads.
Brian Carlstrom034f76b2012-08-01 15:51:58 -0700265 jobject GetMainThreadGroup() const;
Ian Rogers365c1022012-06-22 15:05:28 -0700266
267 // Returns the "system" ThreadGroup, used when attaching our internal threads.
Brian Carlstrom034f76b2012-08-01 15:51:58 -0700268 jobject GetSystemThreadGroup() const;
Ian Rogers365c1022012-06-22 15:05:28 -0700269
Brian Carlstromce888532013-10-10 00:32:58 -0700270 // Returns the system ClassLoader which represents the CLASSPATH.
271 jobject GetSystemClassLoader() const;
272
Elliott Hughes462c9442012-03-23 18:47:50 -0700273 // Attaches the calling native thread to the runtime.
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700274 bool AttachCurrentThread(const char* thread_name, bool as_daemon, jobject thread_group,
Mathieu Chartier664bebf2012-11-12 16:54:11 -0800275 bool create_peer);
Carl Shapiro61e019d2011-07-14 16:53:09 -0700276
Elliott Hughesbf86d042011-08-31 17:53:14 -0700277 void CallExitHook(jint status);
278
Carl Shapiro61e019d2011-07-14 16:53:09 -0700279 // Detaches the current native thread from the runtime.
Mathieu Chartier90443472015-07-16 20:32:27 -0700280 void DetachCurrentThread() REQUIRES(!Locks::mutator_lock_);
Carl Shapiro61e019d2011-07-14 16:53:09 -0700281
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +0100282 void DumpDeoptimizations(std::ostream& os);
Ian Rogers7b078e82014-09-10 14:44:24 -0700283 void DumpForSigQuit(std::ostream& os);
Elliott Hughes21a5bf22011-12-07 14:35:20 -0800284 void DumpLockHolders(std::ostream& os);
Elliott Hughese27955c2011-08-26 15:21:24 -0700285
Carl Shapiro61e019d2011-07-14 16:53:09 -0700286 ~Runtime();
Carl Shapirob5573532011-07-12 18:22:59 -0700287
Vladimir Markod1908512018-11-22 14:57:28 +0000288 const std::vector<std::string>& GetBootClassPath() const {
289 return boot_class_path_;
290 }
291
292 const std::vector<std::string>& GetBootClassPathLocations() const {
293 DCHECK(boot_class_path_locations_.empty() ||
294 boot_class_path_locations_.size() == boot_class_path_.size());
295 return boot_class_path_locations_.empty() ? boot_class_path_ : boot_class_path_locations_;
Brian Carlstroma004aa92012-02-08 18:05:09 -0800296 }
297
Victor Hsieha09d8b72021-05-24 14:21:55 -0700298 const std::vector<int>& GetBootClassPathFds() const {
299 return boot_class_path_fds_;
300 }
301
Victor Hsiehce9b9022021-07-21 10:44:06 -0700302 const std::vector<int>& GetBootClassPathImageFds() const {
303 return boot_class_path_image_fds_;
304 }
305
306 const std::vector<int>& GetBootClassPathVdexFds() const {
307 return boot_class_path_vdex_fds_;
308 }
309
310 const std::vector<int>& GetBootClassPathOatFds() const {
311 return boot_class_path_oat_fds_;
312 }
313
Nicolas Geoffraybbdb1ed2021-06-29 14:12:05 +0100314 // Returns the checksums for the boot image, extensions and extra boot class path dex files,
315 // based on the image spaces and boot class path dex files loaded in memory.
316 const std::string& GetBootClassPathChecksums() const {
317 return boot_class_path_checksums_;
318 }
319
Brian Carlstroma004aa92012-02-08 18:05:09 -0800320 const std::string& GetClassPathString() const {
321 return class_path_string_;
Brian Carlstromb765be02011-08-17 23:54:10 -0700322 }
323
324 ClassLinker* GetClassLinker() const {
Carl Shapiro7a909592011-07-24 19:21:59 -0700325 return class_linker_;
326 }
327
Hans Boehm4dcac362021-09-23 12:26:04 -0700328 SmallIrtAllocator* GetSmallIrtAllocator() const {
329 return small_irt_allocator_;
330 }
331
Alex Light79d6c802019-06-27 15:50:11 +0000332 jni::JniIdManager* GetJniIdManager() const {
333 return jni_id_manager_.get();
334 }
335
Elliott Hughes7ede61e2011-09-14 18:18:06 -0700336 size_t GetDefaultStackSize() const {
337 return default_stack_size_;
338 }
339
Hans Boehmb2155572019-03-27 14:25:53 -0700340 unsigned int GetFinalizerTimeoutMs() const {
341 return finalizer_timeout_ms_;
342 }
343
Ian Rogers1d54e732013-05-02 21:10:01 -0700344 gc::Heap* GetHeap() const {
Elliott Hughesb3bd5f02012-03-08 21:05:27 -0800345 return heap_;
346 }
347
Elliott Hughescf4c6c42011-09-01 15:16:42 -0700348 InternTable* GetInternTable() const {
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700349 DCHECK(intern_table_ != nullptr);
Elliott Hughescf4c6c42011-09-01 15:16:42 -0700350 return intern_table_;
351 }
352
Elliott Hughes0af55432011-08-17 18:37:28 -0700353 JavaVMExt* GetJavaVM() const {
Richard Uhlerda0a69e2016-10-11 15:06:38 +0100354 return java_vm_.get();
Elliott Hughesf2682d52011-08-15 16:37:04 -0700355 }
356
Hans Boehmb3da36c2016-12-15 13:12:59 -0800357 size_t GetMaxSpinsBeforeThinLockInflation() const {
Ian Rogersd9c4fc92013-10-01 19:45:43 -0700358 return max_spins_before_thin_lock_inflation_;
359 }
360
Elliott Hughesc33a32b2011-10-11 18:18:07 -0700361 MonitorList* GetMonitorList() const {
362 return monitor_list_;
363 }
364
Ian Rogersef7d42f2014-01-06 12:55:46 -0800365 MonitorPool* GetMonitorPool() const {
366 return monitor_pool_;
367 }
368
Ian Rogersc0542af2014-09-03 16:16:56 -0700369 // Is the given object the special object used to mark a cleared JNI weak global?
Mathieu Chartier8778c522016-10-04 19:06:30 -0700370 bool IsClearedJniWeakGlobal(ObjPtr<mirror::Object> obj) REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogersc0542af2014-09-03 16:16:56 -0700371
372 // Get the special object used to mark a cleared JNI weak global.
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700373 mirror::Object* GetClearedJniWeakGlobal() REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogersc0542af2014-09-03 16:16:56 -0700374
Roland Levillain7b0e8442018-04-11 18:27:47 +0100375 mirror::Throwable* GetPreAllocatedOutOfMemoryErrorWhenThrowingException()
376 REQUIRES_SHARED(Locks::mutator_lock_);
377 mirror::Throwable* GetPreAllocatedOutOfMemoryErrorWhenThrowingOOME()
378 REQUIRES_SHARED(Locks::mutator_lock_);
379 mirror::Throwable* GetPreAllocatedOutOfMemoryErrorWhenHandlingStackOverflow()
380 REQUIRES_SHARED(Locks::mutator_lock_);
Elliott Hughes225f5a12012-06-11 11:23:48 -0700381
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700382 mirror::Throwable* GetPreAllocatedNoClassDefFoundError()
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700383 REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogers63557452014-06-04 16:57:15 -0700384
Elliott Hughes225f5a12012-06-11 11:23:48 -0700385 const std::vector<std::string>& GetProperties() const {
386 return properties_;
387 }
388
Elliott Hughesd92bec42011-09-02 17:04:36 -0700389 ThreadList* GetThreadList() const {
390 return thread_list_;
391 }
392
Brian Carlstrom491ca9e2014-03-02 18:24:38 -0800393 static const char* GetVersion() {
Andreas Gampe2153f932014-06-26 08:09:17 -0700394 return "2.1.0";
Elliott Hughes7ede61e2011-09-14 18:18:06 -0700395 }
396
Narayan Kamath25352fc2016-08-03 12:46:58 +0100397 bool IsMethodHandlesEnabled() const {
Narayan Kamath93206752017-01-17 13:20:55 +0000398 return true;
Narayan Kamath25352fc2016-08-03 12:46:58 +0100399 }
400
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700401 void DisallowNewSystemWeaks() REQUIRES_SHARED(Locks::mutator_lock_);
402 void AllowNewSystemWeaks() REQUIRES_SHARED(Locks::mutator_lock_);
Hiroshi Yamauchi30493242016-11-03 13:06:52 -0700403 // broadcast_for_checkpoint is true when we broadcast for making blocking threads to respond to
404 // checkpoint requests. It's false when we broadcast to unblock blocking threads after system weak
405 // access is reenabled.
406 void BroadcastForNewSystemWeaks(bool broadcast_for_checkpoint = false);
Mathieu Chartierc11d9b82013-09-19 10:01:59 -0700407
Ian Rogers1d54e732013-05-02 21:10:01 -0700408 // Visit all the roots. If only_dirty is true then non-dirty roots won't be visited. If
409 // clean_dirty is true then dirty roots will be marked as non-dirty after visiting.
Mathieu Chartierbb87e0f2015-04-03 11:21:55 -0700410 void VisitRoots(RootVisitor* visitor, VisitRootFlags flags = kVisitRootFlagAllRoots)
Andreas Gamped98b4ed2016-11-04 20:27:24 -0700411 REQUIRES(!Locks::classlinker_classes_lock_, !Locks::trace_lock_)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700412 REQUIRES_SHARED(Locks::mutator_lock_);
Brian Carlstrom1f870082011-08-23 16:02:11 -0700413
Mathieu Chartier461687d2015-03-31 12:05:24 -0700414 // Visit image roots, only used for hprof since the GC uses the image space mod union table
415 // instead.
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700416 void VisitImageRoots(RootVisitor* visitor) REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier461687d2015-03-31 12:05:24 -0700417
Roland Levillainef012222017-06-21 16:28:06 +0100418 // Visit all of the roots we can safely visit concurrently.
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700419 void VisitConcurrentRoots(RootVisitor* visitor,
420 VisitRootFlags flags = kVisitRootFlagAllRoots)
Andreas Gamped98b4ed2016-11-04 20:27:24 -0700421 REQUIRES(!Locks::classlinker_classes_lock_, !Locks::trace_lock_)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700422 REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier9ebae1f2012-10-15 17:38:16 -0700423
Mathieu Chartier858f1c52012-10-17 17:45:55 -0700424 // Visit all of the non thread roots, we can do this with mutators unpaused.
Mathieu Chartierbb87e0f2015-04-03 11:21:55 -0700425 void VisitNonThreadRoots(RootVisitor* visitor)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700426 REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier858f1c52012-10-17 17:45:55 -0700427
Mathieu Chartierbb87e0f2015-04-03 11:21:55 -0700428 void VisitTransactionRoots(RootVisitor* visitor)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700429 REQUIRES_SHARED(Locks::mutator_lock_);
Hiroshi Yamauchi2cd334a2015-01-09 14:03:35 -0800430
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700431 // Sweep system weaks, the system weak is deleted if the visitor return null. Otherwise, the
Mathieu Chartier6aa3df92013-09-17 15:17:28 -0700432 // system weak is updated to be the visitor's returned value.
Mathieu Chartier97509952015-07-13 14:35:43 -0700433 void SweepSystemWeaks(IsMarkedVisitor* visitor)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700434 REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier6aa3df92013-09-17 15:17:28 -0700435
Alex Lightc18eba32019-09-24 14:36:27 -0700436 // Walk all reflective objects and visit their targets as well as any method/fields held by the
437 // runtime threads that are marked as being reflective.
438 void VisitReflectiveTargets(ReflectiveValueVisitor* visitor) REQUIRES(Locks::mutator_lock_);
439 // Helper for visiting reflective targets with lambdas for both field and method reflective
440 // targets.
441 template <typename FieldVis, typename MethodVis>
442 void VisitReflectiveTargets(FieldVis&& fv, MethodVis&& mv) REQUIRES(Locks::mutator_lock_) {
443 FunctionReflectiveValueVisitor frvv(fv, mv);
444 VisitReflectiveTargets(&frvv);
445 }
446
Ian Rogers9af209c2012-06-03 20:50:30 -0700447 // Returns a special method that calls into a trampoline for runtime method resolution
Mathieu Chartierfbc31082016-01-24 11:59:56 -0800448 ArtMethod* GetResolutionMethod();
Ian Rogers9af209c2012-06-03 20:50:30 -0700449
450 bool HasResolutionMethod() const {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700451 return resolution_method_ != nullptr;
Ian Rogers9af209c2012-06-03 20:50:30 -0700452 }
453
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700454 void SetResolutionMethod(ArtMethod* method) REQUIRES_SHARED(Locks::mutator_lock_);
Igor Murashkin8275fba2017-05-02 15:58:02 -0700455 void ClearResolutionMethod() {
456 resolution_method_ = nullptr;
457 }
Ian Rogers9af209c2012-06-03 20:50:30 -0700458
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700459 ArtMethod* CreateResolutionMethod() REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogers19846512012-02-24 11:42:47 -0800460
Ian Rogerse63db272014-07-15 15:36:11 -0700461 // Returns a special method that calls into a trampoline for runtime imt conflicts.
Mathieu Chartierfbc31082016-01-24 11:59:56 -0800462 ArtMethod* GetImtConflictMethod();
463 ArtMethod* GetImtUnimplementedMethod();
Jeff Hao88474b42013-10-23 16:24:40 -0700464
465 bool HasImtConflictMethod() const {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700466 return imt_conflict_method_ != nullptr;
Jeff Hao88474b42013-10-23 16:24:40 -0700467 }
468
Igor Murashkin8275fba2017-05-02 15:58:02 -0700469 void ClearImtConflictMethod() {
470 imt_conflict_method_ = nullptr;
471 }
472
Nicolas Geoffrayf05f04b2019-10-31 11:50:41 +0000473 void FixupConflictTables() REQUIRES_SHARED(Locks::mutator_lock_);
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700474 void SetImtConflictMethod(ArtMethod* method) REQUIRES_SHARED(Locks::mutator_lock_);
475 void SetImtUnimplementedMethod(ArtMethod* method) REQUIRES_SHARED(Locks::mutator_lock_);
Jeff Hao88474b42013-10-23 16:24:40 -0700476
Nicolas Geoffray796d6302016-03-13 22:22:31 +0000477 ArtMethod* CreateImtConflictMethod(LinearAlloc* linear_alloc)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700478 REQUIRES_SHARED(Locks::mutator_lock_);
Jeff Hao88474b42013-10-23 16:24:40 -0700479
Igor Murashkin8275fba2017-05-02 15:58:02 -0700480 void ClearImtUnimplementedMethod() {
481 imt_unimplemented_method_ = nullptr;
482 }
483
Ian Rogers9af209c2012-06-03 20:50:30 -0700484 bool HasCalleeSaveMethod(CalleeSaveType type) const {
Andreas Gampe8228cdf2017-05-30 15:03:54 -0700485 return callee_save_methods_[static_cast<size_t>(type)] != 0u;
Ian Rogers9af209c2012-06-03 20:50:30 -0700486 }
487
Mathieu Chartiere401d142015-04-22 13:56:20 -0700488 ArtMethod* GetCalleeSaveMethod(CalleeSaveType type)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700489 REQUIRES_SHARED(Locks::mutator_lock_);
Hiroshi Yamauchiab088112014-07-14 13:00:14 -0700490
Mathieu Chartiere401d142015-04-22 13:56:20 -0700491 ArtMethod* GetCalleeSaveMethodUnchecked(CalleeSaveType type)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700492 REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogers9af209c2012-06-03 20:50:30 -0700493
Mathieu Chartiere401d142015-04-22 13:56:20 -0700494 QuickMethodFrameInfo GetRuntimeMethodFrameInfo(ArtMethod* method)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700495 REQUIRES_SHARED(Locks::mutator_lock_);
Vladimir Marko7624d252014-05-02 14:40:15 +0100496
David Srbecky56de89a2018-10-01 15:32:20 +0100497 static constexpr size_t GetCalleeSaveMethodOffset(CalleeSaveType type) {
Andreas Gampe8228cdf2017-05-30 15:03:54 -0700498 return OFFSETOF_MEMBER(Runtime, callee_save_methods_[static_cast<size_t>(type)]);
Ian Rogers936b37f2014-02-14 00:52:24 -0800499 }
500
Vladimir Marko7624d252014-05-02 14:40:15 +0100501 InstructionSet GetInstructionSet() const {
502 return instruction_set_;
503 }
504
505 void SetInstructionSet(InstructionSet instruction_set);
Igor Murashkin8275fba2017-05-02 15:58:02 -0700506 void ClearInstructionSet();
Vladimir Marko7624d252014-05-02 14:40:15 +0100507
Mathieu Chartiere401d142015-04-22 13:56:20 -0700508 void SetCalleeSaveMethod(ArtMethod* method, CalleeSaveType type);
Igor Murashkin8275fba2017-05-02 15:58:02 -0700509 void ClearCalleeSaveMethods();
Ian Rogers4f0d07c2011-10-06 23:38:47 -0700510
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700511 ArtMethod* CreateCalleeSaveMethod() REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogersff1ed472011-09-20 13:46:24 -0700512
Andreas Gampe7ee607e2019-07-23 12:22:04 -0700513 uint64_t GetStat(int kind);
Elliott Hughes9d5ccec2011-09-19 13:19:50 -0700514
Ian Rogers9af209c2012-06-03 20:50:30 -0700515 RuntimeStats* GetStats() {
516 return &stats_;
517 }
Elliott Hughes9d5ccec2011-09-19 13:19:50 -0700518
519 bool HasStatsEnabled() const {
520 return stats_enabled_;
521 }
522
523 void ResetStats(int kinds);
524
Mathieu Chartier90443472015-07-16 20:32:27 -0700525 void SetStatsEnabled(bool new_state)
526 REQUIRES(!Locks::instrument_entrypoints_lock_, !Locks::mutator_lock_);
Elliott Hughes9d5ccec2011-09-19 13:19:50 -0700527
Andreas Gampe6be67ee2014-09-02 21:22:18 -0700528 enum class NativeBridgeAction { // private
529 kUnload,
530 kInitialize
531 };
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800532
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000533 jit::Jit* GetJit() const {
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800534 return jit_.get();
535 }
Calin Juravleffc87072016-04-20 14:22:09 +0100536
David Srbecky9ac8e432019-08-13 13:16:13 +0100537 jit::JitCodeCache* GetJitCodeCache() const {
538 return jit_code_cache_.get();
539 }
540
Calin Juravleffc87072016-04-20 14:22:09 +0100541 // Returns true if JIT compilations are enabled. GetJit() will be not null in this case.
542 bool UseJitCompilation() const;
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800543
Narayan Kamath3de95a72014-04-02 12:54:23 +0100544 void PreZygoteFork();
Nicolas Geoffrayce9ed362018-11-29 03:19:28 +0000545 void PostZygoteFork();
Nicolas Geoffrayd66c8622015-12-11 14:59:16 +0000546 void InitNonZygoteOrPostFork(
Calin Juravle016fcbe22018-05-03 19:47:35 -0700547 JNIEnv* env,
548 bool is_system_server,
Lev Rumyantsev87f36302019-12-13 15:49:37 -0800549 bool is_child_zygote,
Calin Juravle016fcbe22018-05-03 19:47:35 -0700550 NativeBridgeAction action,
551 const char* isa,
552 bool profile_system_server = false);
Brian Carlstromcaabb1b2011-10-11 18:09:13 -0700553
Ian Rogers9bc54402014-04-17 16:40:01 -0700554 const instrumentation::Instrumentation* GetInstrumentation() const {
555 return &instrumentation_;
556 }
557
Ian Rogers62d6c772013-02-27 08:32:07 -0800558 instrumentation::Instrumentation* GetInstrumentation() {
559 return &instrumentation_;
560 }
jeffhao2692b572011-12-16 15:42:28 -0800561
Calin Juravlec2753e62021-06-25 15:34:09 -0700562 void RegisterAppInfo(const std::string& package_name,
563 const std::vector<std::string>& code_paths,
Calin Juravlebeb9f202021-06-02 14:42:03 -0700564 const std::string& profile_output_filename,
Calin Juravlec2753e62021-06-25 15:34:09 -0700565 const std::string& ref_profile_filename,
566 int32_t code_type);
Dave Allison0aded082013-11-07 13:15:11 -0800567
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100568 // Transaction support.
Chang Xing605fe242017-07-20 15:57:21 -0700569 bool IsActiveTransaction() const;
Chang Xing5a906fc2017-07-26 15:01:16 -0700570 void EnterTransactionMode(bool strict, mirror::Class* root);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100571 void ExitTransactionMode();
Chang Xing605fe242017-07-20 15:57:21 -0700572 void RollbackAllTransactions() REQUIRES_SHARED(Locks::mutator_lock_);
Chang Xing16d1dd82017-07-20 17:56:26 -0700573 // Transaction rollback and exit transaction are always done together, it's convenience to
574 // do them in one function.
575 void RollbackAndExitTransactionMode() REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100576 bool IsTransactionAborted() const;
Vladimir Markob6e67922021-07-06 15:53:07 +0100577 const Transaction* GetTransaction() const;
578 Transaction* GetTransaction();
Chang Xing5a906fc2017-07-26 15:01:16 -0700579 bool IsActiveStrictTransactionMode() const;
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100580
Sebastien Hertz2fd7e692015-04-02 11:11:19 +0200581 void AbortTransactionAndThrowAbortError(Thread* self, const std::string& abort_message)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700582 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz2fd7e692015-04-02 11:11:19 +0200583 void ThrowTransactionAbortError(Thread* self)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700584 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100585
Vladimir Markob6e67922021-07-06 15:53:07 +0100586 void RecordWriteFieldBoolean(mirror::Object* obj,
587 MemberOffset field_offset,
588 uint8_t value,
589 bool is_volatile);
590 void RecordWriteFieldByte(mirror::Object* obj,
591 MemberOffset field_offset,
592 int8_t value,
593 bool is_volatile);
594 void RecordWriteFieldChar(mirror::Object* obj,
595 MemberOffset field_offset,
596 uint16_t value,
597 bool is_volatile);
598 void RecordWriteFieldShort(mirror::Object* obj,
599 MemberOffset field_offset,
600 int16_t value,
601 bool is_volatile);
602 void RecordWriteField32(mirror::Object* obj,
603 MemberOffset field_offset,
604 uint32_t value,
605 bool is_volatile);
606 void RecordWriteField64(mirror::Object* obj,
607 MemberOffset field_offset,
608 uint64_t value,
609 bool is_volatile);
Mathieu Chartiera058fdf2016-10-06 15:13:58 -0700610 void RecordWriteFieldReference(mirror::Object* obj,
611 MemberOffset field_offset,
612 ObjPtr<mirror::Object> value,
Vladimir Markob6e67922021-07-06 15:53:07 +0100613 bool is_volatile)
Mathieu Chartiera058fdf2016-10-06 15:13:58 -0700614 REQUIRES_SHARED(Locks::mutator_lock_);
Vladimir Markob6e67922021-07-06 15:53:07 +0100615 void RecordWriteArray(mirror::Array* array, size_t index, uint64_t value)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700616 REQUIRES_SHARED(Locks::mutator_lock_);
Vladimir Markob6e67922021-07-06 15:53:07 +0100617 void RecordStrongStringInsertion(ObjPtr<mirror::String> s)
Mathieu Chartier90443472015-07-16 20:32:27 -0700618 REQUIRES(Locks::intern_table_lock_);
Vladimir Markob6e67922021-07-06 15:53:07 +0100619 void RecordWeakStringInsertion(ObjPtr<mirror::String> s)
Mathieu Chartier90443472015-07-16 20:32:27 -0700620 REQUIRES(Locks::intern_table_lock_);
Vladimir Markob6e67922021-07-06 15:53:07 +0100621 void RecordStrongStringRemoval(ObjPtr<mirror::String> s)
Mathieu Chartier90443472015-07-16 20:32:27 -0700622 REQUIRES(Locks::intern_table_lock_);
Vladimir Markob6e67922021-07-06 15:53:07 +0100623 void RecordWeakStringRemoval(ObjPtr<mirror::String> s)
Mathieu Chartier90443472015-07-16 20:32:27 -0700624 REQUIRES(Locks::intern_table_lock_);
Vladimir Markob6e67922021-07-06 15:53:07 +0100625 void RecordResolveString(ObjPtr<mirror::DexCache> dex_cache, dex::StringIndex string_idx)
Mathieu Chartierbb816d62016-09-07 10:17:46 -0700626 REQUIRES_SHARED(Locks::mutator_lock_);
Vladimir Markob6e67922021-07-06 15:53:07 +0100627 void RecordResolveMethodType(ObjPtr<mirror::DexCache> dex_cache, dex::ProtoIndex proto_idx)
Vladimir Markoe9a4a602021-06-22 16:33:34 +0100628 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100629
Andreas Gampe44f67602018-11-28 08:27:27 -0800630 void SetFaultMessage(const std::string& message);
Mathieu Chartier15d34022014-02-26 17:16:38 -0800631
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700632 void AddCurrentRuntimeFeaturesAsDex2OatArguments(std::vector<std::string>* arg_vector) const;
Ian Rogers8afeb852014-04-02 14:55:49 -0700633
Nicolas Geoffray541ca322022-01-20 09:03:04 +0000634 bool GetImplicitStackOverflowChecks() const {
635 return implicit_so_checks_;
636 }
637
638 bool GetImplicitSuspendChecks() const {
639 return implicit_suspend_checks_;
640 }
641
642 bool GetImplicitNullChecks() const {
643 return implicit_null_checks_;
Dave Allisonb373e092014-02-20 16:06:36 -0800644 }
645
Nicolas Geoffray68bf3902017-09-07 14:40:48 +0100646 void DisableVerifier();
Igor Murashkin7617abd2015-07-10 18:27:47 -0700647 bool IsVerificationEnabled() const;
648 bool IsVerificationSoftFail() const;
Jeff Hao4a200f52014-04-01 14:58:49 -0700649
Mathew Inwooda5dc52c2018-02-19 15:30:51 +0000650 void SetHiddenApiEnforcementPolicy(hiddenapi::EnforcementPolicy policy) {
651 hidden_api_policy_ = policy;
David Brazdil3e0fa0a2018-01-15 18:41:44 +0000652 }
653
Mathew Inwooda5dc52c2018-02-19 15:30:51 +0000654 hiddenapi::EnforcementPolicy GetHiddenApiEnforcementPolicy() const {
655 return hidden_api_policy_;
David Brazdil3e0fa0a2018-01-15 18:41:44 +0000656 }
657
David Brazdile7681822018-12-14 16:25:33 +0000658 void SetCorePlatformApiEnforcementPolicy(hiddenapi::EnforcementPolicy policy) {
659 core_platform_api_policy_ = policy;
660 }
661
662 hiddenapi::EnforcementPolicy GetCorePlatformApiEnforcementPolicy() const {
663 return core_platform_api_policy_;
664 }
665
satayev09efc162021-02-22 17:24:57 +0000666 void SetTestApiEnforcementPolicy(hiddenapi::EnforcementPolicy policy) {
667 test_api_policy_ = policy;
668 }
669
670 hiddenapi::EnforcementPolicy GetTestApiEnforcementPolicy() const {
671 return test_api_policy_;
672 }
673
Mathew Inwood3383aa52018-03-16 14:18:33 +0000674 void SetHiddenApiExemptions(const std::vector<std::string>& exemptions) {
675 hidden_api_exemptions_ = exemptions;
676 }
677
678 const std::vector<std::string>& GetHiddenApiExemptions() {
679 return hidden_api_exemptions_;
680 }
681
David Brazdilee7d2fd2018-01-20 17:25:23 +0000682 void SetDedupeHiddenApiWarnings(bool value) {
683 dedupe_hidden_api_warnings_ = value;
684 }
685
686 bool ShouldDedupeHiddenApiWarnings() {
687 return dedupe_hidden_api_warnings_;
688 }
689
Mathew Inwood73ddda42018-04-03 15:32:32 +0100690 void SetHiddenApiEventLogSampleRate(uint32_t rate) {
691 hidden_api_access_event_log_rate_ = rate;
692 }
693
694 uint32_t GetHiddenApiEventLogSampleRate() const {
695 return hidden_api_access_event_log_rate_;
696 }
697
Mathew Inwood5bcef172018-05-01 14:40:12 +0100698 const std::string& GetProcessPackageName() const {
699 return process_package_name_;
700 }
701
702 void SetProcessPackageName(const char* package_name) {
703 if (package_name == nullptr) {
704 process_package_name_.clear();
705 } else {
706 process_package_name_ = package_name;
707 }
708 }
709
David Brazdil35a3f6a2019-03-04 15:59:06 +0000710 const std::string& GetProcessDataDirectory() const {
711 return process_data_directory_;
712 }
713
714 void SetProcessDataDirectory(const char* data_dir) {
715 if (data_dir == nullptr) {
716 process_data_directory_.clear();
717 } else {
718 process_data_directory_ = data_dir;
719 }
720 }
721
Dmitriy Ivanov785049f2014-07-18 10:08:57 -0700722 const std::vector<std::string>& GetCpuAbilist() const {
723 return cpu_abilist_;
724 }
725
Evgenii Stepanov1e133742015-05-20 12:30:59 -0700726 bool IsRunningOnMemoryTool() const {
727 return is_running_on_memory_tool_;
Mathieu Chartierda44d772014-04-01 15:01:46 -0700728 }
729
David Brazdil2bb2fbd2018-11-13 18:24:26 +0000730 void SetTargetSdkVersion(uint32_t version) {
Jeff Haof00571c2014-05-29 17:29:47 -0700731 target_sdk_version_ = version;
732 }
733
David Brazdil2bb2fbd2018-11-13 18:24:26 +0000734 uint32_t GetTargetSdkVersion() const {
Jeff Haof00571c2014-05-29 17:29:47 -0700735 return target_sdk_version_;
736 }
737
Andrei Onea037d2822020-11-19 00:20:04 +0000738 CompatFramework& GetCompatFramework() {
739 return compat_framework_;
atrostfab72082019-12-06 13:37:36 +0000740 }
741
Narayan Kamath5a2be3f2015-02-16 13:51:51 +0000742 uint32_t GetZygoteMaxFailedBoots() const {
743 return zygote_max_failed_boots_;
744 }
745
Alex Lighteb7c1442015-08-31 13:17:42 -0700746 bool AreExperimentalFlagsEnabled(ExperimentalFlags flags) {
747 return (experimental_flags_ & flags) != ExperimentalFlags::kNone;
Igor Murashkin158f35c2015-06-10 15:55:30 -0700748 }
749
Orion Hodsonad28f5e2018-10-17 09:08:17 +0100750 void CreateJitCodeCache(bool rwx_memory_allowed);
751
Mathieu Chartier455f67c2015-03-17 13:48:29 -0700752 // Create the JIT and instrumentation and code cache.
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800753 void CreateJit();
754
Mathieu Chartier9b34b242015-03-09 11:30:17 -0700755 ArenaPool* GetArenaPool() {
756 return arena_pool_.get();
757 }
758 const ArenaPool* GetArenaPool() const {
759 return arena_pool_.get();
760 }
Vladimir Markob6e67922021-07-06 15:53:07 +0100761 ArenaPool* GetJitArenaPool() {
762 return jit_arena_pool_.get();
763 }
Jean-Philippe Halimica76a1a2016-02-02 19:48:52 +0100764
765 void ReclaimArenaPoolMemory();
766
Mathieu Chartierc7853442015-03-27 14:35:38 -0700767 LinearAlloc* GetLinearAlloc() {
768 return linear_alloc_.get();
769 }
Mathieu Chartier9b34b242015-03-09 11:30:17 -0700770
Mathieu Chartier455f67c2015-03-17 13:48:29 -0700771 jit::JitOptions* GetJITOptions() {
772 return jit_options_.get();
773 }
774
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000775 bool IsJavaDebuggable() const {
776 return is_java_debuggable_;
Alex Light6b16d892016-11-11 11:21:04 -0800777 }
778
Florian Mayer07710c52019-09-16 15:53:38 +0000779 void SetProfileableFromShell(bool value) {
780 is_profileable_from_shell_ = value;
781 }
782
783 bool IsProfileableFromShell() const {
784 return is_profileable_from_shell_;
785 }
786
Florian Mayer0bc9bef2021-04-28 15:52:33 +0100787 void SetProfileable(bool value) {
788 is_profileable_ = value;
789 }
790
791 bool IsProfileable() const {
792 return is_profileable_;
793 }
794
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000795 void SetJavaDebuggable(bool value);
796
797 // Deoptimize the boot image, called for Java debuggable apps.
Nicolas Geoffray226805d2018-12-14 10:59:02 +0000798 void DeoptimizeBootImage() REQUIRES(Locks::mutator_lock_);
Alex Light6b16d892016-11-11 11:21:04 -0800799
David Srbeckyf4480162016-03-16 00:06:24 +0000800 bool IsNativeDebuggable() const {
801 return is_native_debuggable_;
802 }
803
804 void SetNativeDebuggable(bool value) {
805 is_native_debuggable_ = value;
806 }
807
randy.jeong5bef0222019-05-27 10:29:09 +0900808 void SetSignalHookDebuggable(bool value);
809
Alex Light0aa7a5a2018-10-10 15:58:14 +0000810 bool AreNonStandardExitsEnabled() const {
811 return non_standard_exits_enabled_;
812 }
813
814 void SetNonStandardExitsEnabled() {
Nicolas Geoffraye4f983c2021-07-12 15:53:27 +0100815 non_standard_exits_enabled_ = true;
Alex Light0aa7a5a2018-10-10 15:58:14 +0000816 }
817
Alex Light7919db92017-11-29 09:00:55 -0800818 bool AreAsyncExceptionsThrown() const {
819 return async_exceptions_thrown_;
820 }
821
822 void SetAsyncExceptionsThrown() {
Nicolas Geoffraye4f983c2021-07-12 15:53:27 +0100823 async_exceptions_thrown_ = true;
Alex Light7919db92017-11-29 09:00:55 -0800824 }
825
Andreas Gampedd671252015-07-23 14:37:18 -0700826 // Returns the build fingerprint, if set. Otherwise an empty string is returned.
827 std::string GetFingerprint() {
828 return fingerprint_;
829 }
830
Mathieu Chartier673ed3d2015-08-28 14:56:43 -0700831 // Called from class linker.
Vladimir Marko024d69f2019-06-13 10:52:32 +0100832 void SetSentinel(ObjPtr<mirror::Object> sentinel) REQUIRES_SHARED(Locks::mutator_lock_);
Roland Levillain0e155592018-11-05 18:31:49 +0000833 // For testing purpose only.
834 // TODO: Remove this when this is no longer needed (b/116087961).
835 GcRoot<mirror::Object> GetSentinel() REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier673ed3d2015-08-28 14:56:43 -0700836
Nicolas Geoffraye3f775b2019-12-04 14:41:52 +0000837
838 // Use a sentinel for marking entries in a table that have been cleared.
839 // This helps diagnosing in case code tries to wrongly access such
840 // entries.
841 static mirror::Class* GetWeakClassSentinel() {
842 return reinterpret_cast<mirror::Class*>(0xebadbeef);
843 }
844
845 // Helper for the GC to process a weak class in a table.
846 static void ProcessWeakClass(GcRoot<mirror::Class>* root_ptr,
847 IsMarkedVisitor* visitor,
848 mirror::Class* update)
849 REQUIRES_SHARED(Locks::mutator_lock_);
850
Mathieu Chartier951ec2c2015-09-22 08:50:05 -0700851 // Create a normal LinearAlloc or low 4gb version if we are 64 bit AOT compiler.
852 LinearAlloc* CreateLinearAlloc();
853
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -0700854 OatFileManager& GetOatFileManager() const {
855 DCHECK(oat_file_manager_ != nullptr);
Mathieu Chartiere58991b2015-10-13 07:59:34 -0700856 return *oat_file_manager_;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -0700857 }
858
Mathieu Chartier32cc9ee2015-10-15 09:19:15 -0700859 double GetHashTableMinLoadFactor() const;
860 double GetHashTableMaxLoadFactor() const;
861
Andreas Gampe83e20492018-11-07 11:12:26 -0800862 bool IsSafeMode() const {
Andreas Gampe83e20492018-11-07 11:12:26 -0800863 return safe_mode_;
864 }
865
Nicolas Geoffray787ae8e2015-11-05 11:32:24 +0000866 void SetSafeMode(bool mode) {
867 safe_mode_ = mode;
868 }
869
Nicolas Geoffraya73280d2016-02-15 13:05:16 +0000870 bool GetDumpNativeStackOnSigQuit() const {
871 return dump_native_stack_on_sig_quit_;
872 }
873
Mathieu Chartierf8cb1782016-03-18 18:45:41 -0700874 void UpdateProcessState(ProcessState process_state);
875
876 // Returns true if we currently care about long mutator pause.
877 bool InJankPerceptibleProcessState() const {
878 return process_state_ == kProcessStateJankPerceptible;
879 }
880
Calin Juravle97cbc922016-04-15 16:16:35 +0100881 void RegisterSensitiveThread() const;
882
Andreas Gampef38a6612016-04-11 08:42:26 -0700883 void SetZygoteNoThreadSection(bool val) {
884 zygote_no_threads_ = val;
885 }
886
887 bool IsZygoteNoThreadSection() const {
888 return zygote_no_threads_;
889 }
890
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000891 // Returns if the code can be deoptimized asynchronously. Code may be compiled with some
Mingyao Yangf711f2c2016-05-23 12:29:39 -0700892 // optimization that makes it impossible to deoptimize.
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000893 bool IsAsyncDeoptimizeable(uintptr_t code) const REQUIRES_SHARED(Locks::mutator_lock_);
Mingyao Yangf711f2c2016-05-23 12:29:39 -0700894
David Sehrd106d9f2016-08-16 19:22:57 -0700895 // Returns a saved copy of the environment (getenv/setenv values).
896 // Used by Fork to protect against overwriting LD_LIBRARY_PATH, etc.
897 char** GetEnvSnapshot() const {
898 return env_snapshot_.GetSnapshot();
899 }
900
Andreas Gampefda57142016-09-08 20:29:18 -0700901 void AddSystemWeakHolder(gc::AbstractSystemWeakHolder* holder);
902 void RemoveSystemWeakHolder(gc::AbstractSystemWeakHolder* holder);
903
Alex Lightf889c702018-02-23 15:25:45 -0800904 void AttachAgent(JNIEnv* env, const std::string& agent_arg, jobject class_loader);
Leonard Mosescueb842212016-10-06 17:26:36 -0700905
Andreas Gampeaadcbc62017-12-28 14:05:42 -0800906 const std::list<std::unique_ptr<ti::Agent>>& GetAgents() const {
Alex Light65af20b2017-04-20 09:15:08 -0700907 return agents_;
908 }
909
Andreas Gampeac30fa22017-01-18 21:02:36 -0800910 RuntimeCallbacks* GetRuntimeCallbacks();
Andreas Gampe04bbb5b2017-01-19 17:49:03 +0000911
Alex Light77fee872017-09-05 14:51:49 -0700912 bool HasLoadedPlugins() const {
913 return !plugins_.empty();
914 }
915
Andreas Gampebad529d2017-02-13 18:52:10 -0800916 void InitThreadGroups(Thread* self);
917
Mathieu Chartier1d495012017-04-11 17:50:00 -0700918 void SetDumpGCPerformanceOnShutdown(bool value) {
919 dump_gc_performance_on_shutdown_ = value;
920 }
921
Lokesh Gidra10d0c962019-03-07 22:40:36 +0000922 bool GetDumpGCPerformanceOnShutdown() const {
923 return dump_gc_performance_on_shutdown_;
924 }
925
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +0100926 void IncrementDeoptimizationCount(DeoptimizationKind kind) {
927 DCHECK_LE(kind, DeoptimizationKind::kLast);
928 deoptimization_counts_[static_cast<size_t>(kind)]++;
929 }
930
Nicolas Geoffrayb9bec2e2017-05-24 15:59:18 +0100931 uint32_t GetNumberOfDeoptimizations() const {
932 uint32_t result = 0;
933 for (size_t i = 0; i <= static_cast<size_t>(DeoptimizationKind::kLast); ++i) {
934 result += deoptimization_counts_[i];
935 }
936 return result;
937 }
938
Orion Hodson971068d2021-06-30 21:17:53 +0100939 bool DenyArtApexDataFiles() const {
940 return deny_art_apex_data_files_;
941 }
942
Mathieu Chartierc42cb0e2017-10-13 11:35:00 -0700943 // Whether or not we use MADV_RANDOM on files that are thought to have random access patterns.
944 // This is beneficial for low RAM devices since it reduces page cache thrashing.
945 bool MAdviseRandomAccess() const {
946 return madvise_random_access_;
947 }
948
Jagadeesh Pakaravoor06541532021-02-22 21:19:09 -0800949 size_t GetMadviseWillNeedSizeVdex() const {
950 return madvise_willneed_vdex_filesize_;
951 }
952
953 size_t GetMadviseWillNeedSizeOdex() const {
954 return madvise_willneed_odex_filesize_;
955 }
956
957 size_t GetMadviseWillNeedSizeArt() const {
958 return madvise_willneed_art_filesize_;
959 }
960
Alex Light40320712017-12-14 11:52:04 -0800961 const std::string& GetJdwpOptions() {
962 return jdwp_options_;
963 }
964
965 JdwpProvider GetJdwpProvider() const {
966 return jdwp_provider_;
967 }
968
Alex Lightf3677472019-06-26 16:31:53 -0700969 JniIdType GetJniIdType() const {
970 return jni_ids_indirection_;
Alex Light79d6c802019-06-27 15:50:11 +0000971 }
972
Alex Lightf3677472019-06-26 16:31:53 -0700973 bool CanSetJniIdType() const {
974 return GetJniIdType() == JniIdType::kSwapablePointer;
975 }
976
977 // Changes the JniIdType to the given type. Only allowed if CanSetJniIdType(). All threads must be
978 // suspended to call this function.
979 void SetJniIdType(JniIdType t);
980
Andreas Gampe0b0ffc12018-08-01 14:41:27 -0700981 uint32_t GetVerifierLoggingThresholdMs() const {
982 return verifier_logging_threshold_ms_;
983 }
984
Mathieu Chartierada33d72018-12-17 13:17:30 -0800985 // Atomically delete the thread pool if the reference count is 0.
986 bool DeleteThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
987
988 // Wait for all the thread workers to be attached.
989 void WaitForThreadPoolWorkersToStart() REQUIRES(!Locks::runtime_thread_pool_lock_);
990
991 // Scoped usage of the runtime thread pool. Prevents the pool from being
992 // deleted. Note that the thread pool is only for startup and gets deleted after.
993 class ScopedThreadPoolUsage {
994 public:
995 ScopedThreadPoolUsage();
996 ~ScopedThreadPoolUsage();
997
998 // Return the thread pool.
999 ThreadPool* GetThreadPool() const {
1000 return thread_pool_;
1001 }
1002
1003 private:
1004 ThreadPool* const thread_pool_;
1005 };
1006
Mathieu Chartiera88abfa2019-02-04 11:08:29 -08001007 bool LoadAppImageStartupCache() const {
1008 return load_app_image_startup_cache_;
1009 }
1010
1011 void SetLoadAppImageStartupCacheEnabled(bool enabled) {
1012 load_app_image_startup_cache_ = enabled;
1013 }
1014
Mathieu Chartier03625442019-06-24 17:29:23 -07001015 // Reset the startup completed status so that we can call NotifyStartupCompleted again. Should
1016 // only be used for testing.
1017 void ResetStartupCompleted();
1018
Mathieu Chartier175ce3d2019-03-06 16:54:24 -08001019 // Notify the runtime that application startup is considered completed. Only has effect for the
1020 // first call.
1021 void NotifyStartupCompleted();
1022
Calin Juravlec2753e62021-06-25 15:34:09 -07001023 // Notify the runtime that the application finished loading some dex/odex files. This is
1024 // called everytime we load a set of dex files in a class loader.
1025 void NotifyDexFileLoaded();
1026
Mathieu Chartier175ce3d2019-03-06 16:54:24 -08001027 // Return true if startup is already completed.
1028 bool GetStartupCompleted() const;
1029
Andreas Gamped84794d2019-07-18 13:40:03 -07001030 bool IsVerifierMissingKThrowFatal() const {
1031 return verifier_missing_kthrow_fatal_;
1032 }
1033
Hans Boehm1792c6f2021-06-24 17:35:50 -07001034 bool IsJavaZygoteForkLoopRequired() const {
1035 return force_java_zygote_fork_loop_;
1036 }
1037
Florian Mayer0972d082020-05-15 14:07:31 +02001038 bool IsPerfettoHprofEnabled() const {
1039 return perfetto_hprof_enabled_;
1040 }
1041
Wessam Hassaneinb5a10be2020-11-11 16:42:52 -08001042 bool IsPerfettoJavaHeapStackProfEnabled() const {
1043 return perfetto_javaheapprof_enabled_;
1044 }
1045
wangguibo0d290722021-04-24 11:27:06 +08001046 bool IsMonitorTimeoutEnabled() const {
1047 return monitor_timeout_enable_;
1048 }
1049
1050 uint64_t GetMonitorTimeoutNs() const {
1051 return monitor_timeout_ns_;
1052 }
Mathieu Chartierccc75192019-10-28 13:34:03 -07001053 // Return true if we should load oat files as executable or not.
1054 bool GetOatFilesExecutable() const;
1055
Eric Holka79872b2020-10-01 13:09:53 -07001056 metrics::ArtMetrics* GetMetrics() { return &metrics_; }
1057
Calin Juravlec2753e62021-06-25 15:34:09 -07001058 AppInfo* GetAppInfo() { return &app_info_; }
1059
Eric Holk5e435b22021-02-23 17:24:47 -08001060 void RequestMetricsReport(bool synchronous = true);
1061
Jagadeesh Pakaravoor06541532021-02-22 21:19:09 -08001062 static void MadviseFileForRange(size_t madvise_size_limit_bytes,
1063 size_t map_size_bytes,
1064 const uint8_t* map_begin,
1065 const uint8_t* map_end,
1066 const std::string& file_name);
1067
Nicolas Geoffrayd3c45c22021-04-27 13:21:28 +01001068 const std::string& GetApexVersions() const {
1069 return apex_versions_;
1070 }
1071
Nicolas Geoffraye7e026b2022-03-24 16:42:07 +00001072 // Return whether a boot image has a profile. This means it's an in-memory
1073 // image rather that an image loaded from disk.
1074 bool HasImageWithProfile() const;
1075
Calin Juravle09eacd92021-05-19 17:03:55 -07001076 // Trigger a flag reload from system properties or device congfigs.
1077 //
1078 // Should only be called from runtime init and zygote post fork as
1079 // we don't want to change the runtime config midway during execution.
1080 //
1081 // The caller argument should be the name of the function making this call
1082 // and will be used to enforce the appropriate names.
1083 //
1084 // See Flags::ReloadAllFlags as well.
1085 static void ReloadAllFlags(const std::string& caller);
1086
Carl Shapirob5573532011-07-12 18:22:59 -07001087 private:
Elliott Hughes457005c2012-04-16 13:54:25 -07001088 static void InitPlatformSignalHandlers();
Elliott Hughesffe67362011-07-17 12:09:27 -07001089
Elliott Hughesdcc24742011-09-07 14:02:44 -07001090 Runtime();
Carl Shapiro61e019d2011-07-14 16:53:09 -07001091
Elliott Hughesc1674ed2011-08-25 18:09:09 -07001092 void BlockSignals();
1093
Vladimir Marko88b2b802015-12-04 14:19:04 +00001094 bool Init(RuntimeArgumentMap&& runtime_options)
Ian Rogersb726dcb2012-09-05 08:57:23 -07001095 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
Mathieu Chartier90443472015-07-16 20:32:27 -07001096 void InitNativeMethods() REQUIRES(!Locks::mutator_lock_);
Elliott Hughesff17f1f2012-01-24 18:12:29 -08001097 void RegisterRuntimeNativeMethods(JNIEnv* env);
Calin Juravle1ff90562021-06-16 14:37:42 -07001098 void InitMetrics();
Elliott Hughesd1cc8362011-10-24 16:58:50 -07001099
Elliott Hughes85d15452011-09-16 17:33:01 -07001100 void StartDaemonThreads();
Elliott Hughesd1cc8362011-10-24 16:58:50 -07001101 void StartSignalCatcher();
Carl Shapiro61e019d2011-07-14 16:53:09 -07001102
Calin Juravle31f2c152015-10-23 17:56:15 +01001103 void MaybeSaveJitProfilingInfo();
1104
Andreas Gampe585da952016-12-02 14:52:29 -08001105 // Visit all of the thread roots.
1106 void VisitThreadRoots(RootVisitor* visitor, VisitRootFlags flags)
1107 REQUIRES_SHARED(Locks::mutator_lock_);
1108
1109 // Visit all other roots which must be done with mutators suspended.
1110 void VisitNonConcurrentRoots(RootVisitor* visitor, VisitRootFlags flags)
1111 REQUIRES_SHARED(Locks::mutator_lock_);
1112
1113 // Constant roots are the roots which never change after the runtime is initialized, they only
1114 // need to be visited once per GC cycle.
1115 void VisitConstantRoots(RootVisitor* visitor)
1116 REQUIRES_SHARED(Locks::mutator_lock_);
1117
Andreas Gampe44f67602018-11-28 08:27:27 -08001118 // Note: To be lock-free, GetFaultMessage temporarily replaces the lock message with null.
1119 // As such, there is a window where a call will return an empty string. In general,
1120 // only aborting code should retrieve this data (via GetFaultMessageForAbortLogging
1121 // friend).
1122 std::string GetFaultMessage();
1123
Mathieu Chartierada33d72018-12-17 13:17:30 -08001124 ThreadPool* AcquireThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
1125 void ReleaseThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
1126
Nicolas Geoffrayd3c45c22021-04-27 13:21:28 +01001127 // Parses /apex/apex-info-list.xml to initialize a string containing versions
1128 // of boot classpath jars and encoded into .oat files.
1129 void InitializeApexVersions();
1130
Mathieu Chartier2cebb242015-04-21 16:50:40 -07001131 // A pointer to the active runtime or null.
Elliott Hughesb3bd5f02012-03-08 21:05:27 -08001132 static Runtime* instance_;
1133
Ian Rogers8afeb852014-04-02 14:55:49 -07001134 // NOTE: these must match the gc::ProcessState values as they come directly from the framework.
1135 static constexpr int kProfileForground = 0;
Calin Juravle31f2c152015-10-23 17:56:15 +01001136 static constexpr int kProfileBackground = 1;
Ian Rogers8afeb852014-04-02 14:55:49 -07001137
Mingyao Yang0a87a652017-04-12 13:43:15 -07001138 static constexpr uint32_t kCalleeSaveSize = 6u;
Andreas Gampe8228cdf2017-05-30 15:03:54 -07001139
Mathieu Chartiere401d142015-04-22 13:56:20 -07001140 // 64 bit so that we can share the same asm offsets for both 32 and 64 bits.
Andreas Gampe8228cdf2017-05-30 15:03:54 -07001141 uint64_t callee_save_methods_[kCalleeSaveSize];
Roland Levillain7b0e8442018-04-11 18:27:47 +01001142 // Pre-allocated exceptions (see Runtime::Init).
1143 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_throwing_exception_;
1144 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_throwing_oome_;
1145 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_handling_stack_overflow_;
Ian Rogers63557452014-06-04 16:57:15 -07001146 GcRoot<mirror::Throwable> pre_allocated_NoClassDefFoundError_;
Mathieu Chartiere401d142015-04-22 13:56:20 -07001147 ArtMethod* resolution_method_;
1148 ArtMethod* imt_conflict_method_;
Mathieu Chartier2d2621a2014-10-23 16:48:06 -07001149 // Unresolved method has the same behavior as the conflict method, it is used by the class linker
1150 // for differentiating between unfilled imt slots vs conflict slots in superclasses.
Mathieu Chartiere401d142015-04-22 13:56:20 -07001151 ArtMethod* imt_unimplemented_method_;
Ian Rogers6ed19fd2014-03-20 08:10:17 -07001152
Ian Rogersc0542af2014-09-03 16:16:56 -07001153 // Special sentinel object used to invalid conditions in JNI (cleared weak references) and
1154 // JDWP (invalid references).
1155 GcRoot<mirror::Object> sentinel_;
1156
Vladimir Marko7624d252014-05-02 14:40:15 +01001157 InstructionSet instruction_set_;
Vladimir Marko7624d252014-05-02 14:40:15 +01001158
Vladimir Marko2b5eaa22013-12-13 13:59:30 +00001159 CompilerCallbacks* compiler_callbacks_;
Elliott Hughes9ca7a1f2011-10-11 14:29:52 -07001160 bool is_zygote_;
Nicolas Geoffray4444f1b2019-06-10 14:09:19 +01001161 bool is_primary_zygote_;
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +01001162 bool is_system_server_;
Alex Lighta59dd802014-07-02 16:28:08 -07001163 bool must_relocate_;
Mathieu Chartier069387a2012-06-18 12:01:01 -07001164 bool is_concurrent_gc_enabled_;
Anwar Ghuloum87183592013-08-14 12:12:19 -07001165 bool is_explicit_gc_disabled_;
Alex Light64ad14d2014-08-19 14:23:13 -07001166 bool image_dex2oat_enabled_;
Brian Carlstrom0a5b14d2011-09-27 13:29:15 -07001167
Tsu Chiang Chuang12e6d742014-05-22 10:22:25 -07001168 std::string compiler_executable_;
Brian Carlstrom6449c622014-02-10 23:48:36 -08001169 std::vector<std::string> compiler_options_;
1170 std::vector<std::string> image_compiler_options_;
Victor Hsieh61ffd042021-05-20 15:14:25 -07001171 std::vector<std::string> image_locations_;
Dragos Sbirlea7467ee02013-06-21 09:20:34 -07001172
Vladimir Markod1908512018-11-22 14:57:28 +00001173 std::vector<std::string> boot_class_path_;
1174 std::vector<std::string> boot_class_path_locations_;
Nicolas Geoffraybbdb1ed2021-06-29 14:12:05 +01001175 std::string boot_class_path_checksums_;
Victor Hsieha09d8b72021-05-24 14:21:55 -07001176 std::vector<int> boot_class_path_fds_;
Victor Hsiehce9b9022021-07-21 10:44:06 -07001177 std::vector<int> boot_class_path_image_fds_;
1178 std::vector<int> boot_class_path_vdex_fds_;
1179 std::vector<int> boot_class_path_oat_fds_;
Brian Carlstroma004aa92012-02-08 18:05:09 -08001180 std::string class_path_string_;
Elliott Hughes7ede61e2011-09-14 18:18:06 -07001181 std::vector<std::string> properties_;
1182
Andreas Gampeaadcbc62017-12-28 14:05:42 -08001183 std::list<ti::AgentSpec> agent_specs_;
1184 std::list<std::unique_ptr<ti::Agent>> agents_;
Alex Light185d1342016-08-11 10:48:03 -07001185 std::vector<Plugin> plugins_;
Alex Light7233c7e2016-07-28 10:07:45 -07001186
Brian Carlstromb765be02011-08-17 23:54:10 -07001187 // The default stack size for managed threads created by the runtime.
Elliott Hughesbe759c62011-09-08 19:38:21 -07001188 size_t default_stack_size_;
Brian Carlstromb765be02011-08-17 23:54:10 -07001189
Hans Boehmb2155572019-03-27 14:25:53 -07001190 // Finalizers running for longer than this many milliseconds abort the runtime.
1191 unsigned int finalizer_timeout_ms_;
1192
Ian Rogers1d54e732013-05-02 21:10:01 -07001193 gc::Heap* heap_;
Elliott Hughesb3bd5f02012-03-08 21:05:27 -08001194
Nicolas Geoffray25e04562016-03-01 13:17:58 +00001195 std::unique_ptr<ArenaPool> jit_arena_pool_;
Mathieu Chartier9b34b242015-03-09 11:30:17 -07001196 std::unique_ptr<ArenaPool> arena_pool_;
Mathieu Chartierc7853442015-03-27 14:35:38 -07001197 // Special low 4gb pool for compiler linear alloc. We need ArtFields to be in low 4gb if we are
1198 // compiling using a 32 bit image on a 64 bit compiler in case we resolve things in the image
1199 // since the field arrays are int arrays in this case.
1200 std::unique_ptr<ArenaPool> low_4gb_arena_pool_;
1201
1202 // Shared linear alloc for now.
1203 std::unique_ptr<LinearAlloc> linear_alloc_;
Mathieu Chartier9b34b242015-03-09 11:30:17 -07001204
Ian Rogersd9c4fc92013-10-01 19:45:43 -07001205 // The number of spins that are done before thread suspension is used to forcibly inflate.
1206 size_t max_spins_before_thin_lock_inflation_;
Elliott Hughesc33a32b2011-10-11 18:18:07 -07001207 MonitorList* monitor_list_;
Ian Rogersef7d42f2014-01-06 12:55:46 -08001208 MonitorPool* monitor_pool_;
Elliott Hughesc33a32b2011-10-11 18:18:07 -07001209
Carl Shapirob5573532011-07-12 18:22:59 -07001210 ThreadList* thread_list_;
Carl Shapiro61e019d2011-07-14 16:53:09 -07001211
Elliott Hughescf4c6c42011-09-01 15:16:42 -07001212 InternTable* intern_table_;
1213
Brian Carlstromb0460ea2011-07-29 10:08:05 -07001214 ClassLinker* class_linker_;
1215
Elliott Hughese27955c2011-08-26 15:21:24 -07001216 SignalCatcher* signal_catcher_;
Narayan Kamatheb710332017-05-10 11:48:46 +01001217
Hans Boehm4dcac362021-09-23 12:26:04 -07001218 SmallIrtAllocator* small_irt_allocator_;
1219
Alex Light79d6c802019-06-27 15:50:11 +00001220 std::unique_ptr<jni::JniIdManager> jni_id_manager_;
1221
Richard Uhlerda0a69e2016-10-11 15:06:38 +01001222 std::unique_ptr<JavaVMExt> java_vm_;
Elliott Hughesf2682d52011-08-15 16:37:04 -07001223
Mathieu Chartiere5f13e52015-02-24 09:37:21 -08001224 std::unique_ptr<jit::Jit> jit_;
Orion Hodsonad28f5e2018-10-17 09:08:17 +01001225 std::unique_ptr<jit::JitCodeCache> jit_code_cache_;
Mathieu Chartiere5f13e52015-02-24 09:37:21 -08001226 std::unique_ptr<jit::JitOptions> jit_options_;
1227
Mathieu Chartierada33d72018-12-17 13:17:30 -08001228 // Runtime thread pool. The pool is only for startup and gets deleted after.
1229 std::unique_ptr<ThreadPool> thread_pool_ GUARDED_BY(Locks::runtime_thread_pool_lock_);
1230 size_t thread_pool_ref_count_ GUARDED_BY(Locks::runtime_thread_pool_lock_);
1231
Andreas Gampe44f67602018-11-28 08:27:27 -08001232 // Fault message, printed when we get a SIGSEGV. Stored as a native-heap object and accessed
1233 // lock-free, so needs to be atomic.
1234 std::atomic<std::string*> fault_message_;
Mathieu Chartier15d34022014-02-26 17:16:38 -08001235
Ian Rogers120f1c72012-09-28 17:17:10 -07001236 // A non-zero value indicates that a thread has been created but not yet initialized. Guarded by
1237 // the shutdown lock so that threads aren't born while we're shutting down.
1238 size_t threads_being_born_ GUARDED_BY(Locks::runtime_shutdown_lock_);
1239
1240 // Waited upon until no threads are being born.
Ian Rogers700a4022014-05-19 16:49:03 -07001241 std::unique_ptr<ConditionVariable> shutdown_cond_ GUARDED_BY(Locks::runtime_shutdown_lock_);
Ian Rogers120f1c72012-09-28 17:17:10 -07001242
Hans Boehm70aa29e2021-08-11 12:11:19 -07001243 // Set when runtime shutdown is past the point that new threads may attach. Usually
1244 // GUARDED_BY(Locks::runtime_shutdown_lock_). But we need to check it in Abort without the
1245 // lock, because we may already own it.
1246 std::atomic<bool> shutting_down_;
Ian Rogers120f1c72012-09-28 17:17:10 -07001247
1248 // The runtime is starting to shutdown but is blocked waiting on shutdown_cond_.
1249 bool shutting_down_started_ GUARDED_BY(Locks::runtime_shutdown_lock_);
1250
Elliott Hughesdcc24742011-09-07 14:02:44 -07001251 bool started_;
1252
Mathieu Chartier7664f5c2012-06-08 18:15:32 -07001253 // New flag added which tells us if the runtime has finished starting. If
1254 // this flag is set then the Daemon threads are created and the class loader
1255 // is created. This flag is needed for knowing if its safe to request CMS.
1256 bool finished_starting_;
1257
Brian Carlstrom6ea095a2011-08-16 15:26:54 -07001258 // Hooks supported by JNI_CreateJavaVM
1259 jint (*vfprintf_)(FILE* stream, const char* format, va_list ap);
1260 void (*exit_)(jint status);
1261 void (*abort_)();
1262
Elliott Hughes9d5ccec2011-09-19 13:19:50 -07001263 bool stats_enabled_;
1264 RuntimeStats stats_;
1265
Evgenii Stepanov1e133742015-05-20 12:30:59 -07001266 const bool is_running_on_memory_tool_;
Mathieu Chartierda44d772014-04-01 15:01:46 -07001267
Andreas Gampef6a780a2015-04-02 18:51:05 -07001268 std::unique_ptr<TraceConfig> trace_config_;
1269
Ian Rogers62d6c772013-02-27 08:32:07 -08001270 instrumentation::Instrumentation instrumentation_;
jeffhao2692b572011-12-16 15:42:28 -08001271
Ian Rogers365c1022012-06-22 15:05:28 -07001272 jobject main_thread_group_;
1273 jobject system_thread_group_;
1274
Brian Carlstromce888532013-10-10 00:32:58 -07001275 // As returned by ClassLoader.getSystemClassLoader().
1276 jobject system_class_loader_;
1277
Hiroshi Yamauchi2e899a92013-11-22 16:50:12 -08001278 // If true, then we dump the GC cumulative timings on shutdown.
1279 bool dump_gc_performance_on_shutdown_;
1280
Chang Xing605fe242017-07-20 15:57:21 -07001281 // Transactions used for pre-initializing classes at compilation time.
1282 // Support nested transactions, maintain a list containing all transactions. Transactions are
1283 // handled under a stack discipline. Because GC needs to go over all transactions, we choose list
1284 // as substantial data structure instead of stack.
Vladimir Markob6e67922021-07-06 15:53:07 +01001285 std::forward_list<Transaction> preinitialization_transactions_;
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +01001286
Igor Murashkin7617abd2015-07-10 18:27:47 -07001287 // If kNone, verification is disabled. kEnable by default.
1288 verifier::VerifyMode verify_;
Jeff Hao4a200f52014-04-01 14:58:49 -07001289
Dmitriy Ivanov785049f2014-07-18 10:08:57 -07001290 // List of supported cpu abis.
1291 std::vector<std::string> cpu_abilist_;
1292
Jeff Haof00571c2014-05-29 17:29:47 -07001293 // Specifies target SDK version to allow workarounds for certain API levels.
David Brazdil2bb2fbd2018-11-13 18:24:26 +00001294 uint32_t target_sdk_version_;
Jeff Haof00571c2014-05-29 17:29:47 -07001295
Andrei Onea037d2822020-11-19 00:20:04 +00001296 // ART counterpart for the compat framework (go/compat-framework).
1297 CompatFramework compat_framework_;
atrostfab72082019-12-06 13:37:36 +00001298
Dave Allison69dfe512014-07-11 17:11:58 +00001299 // Implicit checks flags.
1300 bool implicit_null_checks_; // NullPointer checks are implicit.
1301 bool implicit_so_checks_; // StackOverflow checks are implicit.
1302 bool implicit_suspend_checks_; // Thread suspension checks are implicit.
1303
Calin Juravle01aaf6e2015-06-19 22:05:39 +01001304 // Whether or not the sig chain (and implicitly the fault handler) should be
Vladimir Markoa497a392018-09-26 10:52:50 +01001305 // disabled. Tools like dex2oat don't need them. This enables
Calin Juravle01aaf6e2015-06-19 22:05:39 +01001306 // building a statically link version of dex2oat.
1307 bool no_sig_chain_;
1308
Calin Juravled3e7c6c2016-02-04 19:07:51 +00001309 // Force the use of native bridge even if the app ISA matches the runtime ISA.
1310 bool force_native_bridge_;
1311
Calin Juravle07d83c72014-10-22 21:02:23 +01001312 // Whether or not a native bridge has been loaded.
Calin Juravlec8423522014-08-12 20:55:20 +01001313 //
1314 // The native bridge allows running native code compiled for a foreign ISA. The way it works is,
1315 // if standard dlopen fails to load native library associated with native activity, it calls to
1316 // the native bridge to load it and then gets the trampoline for the entry to native activity.
Calin Juravle07d83c72014-10-22 21:02:23 +01001317 //
1318 // The option 'native_bridge_library_filename' specifies the name of the native bridge.
1319 // When non-empty the native bridge will be loaded from the given file. An empty value means
1320 // that there's no native bridge.
1321 bool is_native_bridge_loaded_;
Calin Juravlec8423522014-08-12 20:55:20 +01001322
David Srbeckyf4480162016-03-16 00:06:24 +00001323 // Whether we are running under native debugger.
1324 bool is_native_debuggable_;
1325
Alex Light7919db92017-11-29 09:00:55 -08001326 // whether or not any async exceptions have ever been thrown. This is used to speed up the
1327 // MterpShouldSwitchInterpreters function.
1328 bool async_exceptions_thrown_;
1329
Alex Light0aa7a5a2018-10-10 15:58:14 +00001330 // Whether anything is going to be using the shadow-frame APIs to force a function to return
1331 // early. Doing this requires that (1) we be debuggable and (2) that mterp is exited.
1332 bool non_standard_exits_enabled_;
1333
Nicolas Geoffray433b79a2017-01-30 20:54:45 +00001334 // Whether Java code needs to be debuggable.
1335 bool is_java_debuggable_;
Alex Light6b16d892016-11-11 11:21:04 -08001336
wangguibo0d290722021-04-24 11:27:06 +08001337 bool monitor_timeout_enable_;
1338 uint64_t monitor_timeout_ns_;
1339
Florian Mayer0bc9bef2021-04-28 15:52:33 +01001340 // Whether or not this application can be profiled by the shell user,
1341 // even when running on a device that is running in user mode.
Florian Mayer07710c52019-09-16 15:53:38 +00001342 bool is_profileable_from_shell_ = false;
1343
Florian Mayer0bc9bef2021-04-28 15:52:33 +01001344 // Whether or not this application can be profiled by system services on a
1345 // device running in user mode, but not necessarily by the shell user.
1346 bool is_profileable_ = false;
1347
Narayan Kamath5a2be3f2015-02-16 13:51:51 +00001348 // The maximum number of failed boots we allow before pruning the dalvik cache
1349 // and trying again. This option is only inspected when we're running as a
1350 // zygote.
1351 uint32_t zygote_max_failed_boots_;
1352
Igor Murashkin158f35c2015-06-10 15:55:30 -07001353 // Enable experimental opcodes that aren't fully specified yet. The intent is to
1354 // eventually publish them as public-usable opcodes, but they aren't ready yet.
1355 //
1356 // Experimental opcodes should not be used by other production code.
Alex Lighteb7c1442015-08-31 13:17:42 -07001357 ExperimentalFlags experimental_flags_;
Igor Murashkin158f35c2015-06-10 15:55:30 -07001358
Andreas Gampedd671252015-07-23 14:37:18 -07001359 // Contains the build fingerprint, if given as a parameter.
1360 std::string fingerprint_;
1361
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -07001362 // Oat file manager, keeps track of what oat files are open.
Mathieu Chartiere58991b2015-10-13 07:59:34 -07001363 OatFileManager* oat_file_manager_;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -07001364
Mathieu Chartier32cc9ee2015-10-15 09:19:15 -07001365 // Whether or not we are on a low RAM device.
1366 bool is_low_memory_mode_;
1367
Mathieu Chartierc42cb0e2017-10-13 11:35:00 -07001368 // Whether or not we use MADV_RANDOM on files that are thought to have random access patterns.
1369 // This is beneficial for low RAM devices since it reduces page cache thrashing.
1370 bool madvise_random_access_;
1371
Jagadeesh Pakaravoor06541532021-02-22 21:19:09 -08001372 // Limiting size (in bytes) for applying MADV_WILLNEED on vdex files
1373 // A 0 for this will turn off madvising to MADV_WILLNEED
1374 size_t madvise_willneed_vdex_filesize_;
1375
1376 // Limiting size (in bytes) for applying MADV_WILLNEED on odex files
1377 // A 0 for this will turn off madvising to MADV_WILLNEED
1378 size_t madvise_willneed_odex_filesize_;
1379
1380 // Limiting size (in bytes) for applying MADV_WILLNEED on art files
1381 // A 0 for this will turn off madvising to MADV_WILLNEED
1382 size_t madvise_willneed_art_filesize_;
1383
Nicolas Geoffray787ae8e2015-11-05 11:32:24 +00001384 // Whether the application should run in safe mode, that is, interpreter only.
1385 bool safe_mode_;
1386
David Brazdil3e0fa0a2018-01-15 18:41:44 +00001387 // Whether access checks on hidden API should be performed.
Mathew Inwooda5dc52c2018-02-19 15:30:51 +00001388 hiddenapi::EnforcementPolicy hidden_api_policy_;
David Brazdil3e0fa0a2018-01-15 18:41:44 +00001389
David Brazdile7681822018-12-14 16:25:33 +00001390 // Whether access checks on core platform API should be performed.
1391 hiddenapi::EnforcementPolicy core_platform_api_policy_;
1392
satayev09efc162021-02-22 17:24:57 +00001393 // Whether access checks on test API should be performed.
1394 hiddenapi::EnforcementPolicy test_api_policy_;
1395
Orion Hodson611d71c2021-08-27 17:00:10 +01001396 // List of signature prefixes of methods that have been removed from the blocklist, and treated
1397 // as if SDK.
Mathew Inwood3383aa52018-03-16 14:18:33 +00001398 std::vector<std::string> hidden_api_exemptions_;
1399
David Brazdilee7d2fd2018-01-20 17:25:23 +00001400 // Do not warn about the same hidden API access violation twice.
1401 // This is only used for testing.
1402 bool dedupe_hidden_api_warnings_;
1403
Mathew Inwood5bcef172018-05-01 14:40:12 +01001404 // How often to log hidden API access to the event log. An integer between 0
1405 // (never) and 0x10000 (always).
Mathew Inwood73ddda42018-04-03 15:32:32 +01001406 uint32_t hidden_api_access_event_log_rate_;
1407
Mathew Inwood5bcef172018-05-01 14:40:12 +01001408 // The package of the app running in this process.
1409 std::string process_package_name_;
1410
David Brazdil35a3f6a2019-03-04 15:59:06 +00001411 // The data directory of the app running in this process.
1412 std::string process_data_directory_;
1413
Nicolas Geoffraya73280d2016-02-15 13:05:16 +00001414 // Whether threads should dump their native stack on SIGQUIT.
1415 bool dump_native_stack_on_sig_quit_;
1416
Mathieu Chartierf8cb1782016-03-18 18:45:41 -07001417 // Whether or not we currently care about pause times.
1418 ProcessState process_state_;
1419
Andreas Gampef38a6612016-04-11 08:42:26 -07001420 // Whether zygote code is in a section that should not start threads.
1421 bool zygote_no_threads_;
1422
Alex Light40320712017-12-14 11:52:04 -08001423 // The string containing requested jdwp options
1424 std::string jdwp_options_;
1425
1426 // The jdwp provider we were configured with.
1427 JdwpProvider jdwp_provider_;
1428
Alex Light79d6c802019-06-27 15:50:11 +00001429 // True if jmethodID and jfieldID are opaque Indices. When false (the default) these are simply
1430 // pointers. This is set by -Xopaque-jni-ids:{true,false}.
1431 JniIdType jni_ids_indirection_;
1432
Alex Light4ca2f482019-11-25 16:07:22 -08001433 // Set to false in cases where we want to directly control when jni-id
1434 // indirection is changed. This is intended only for testing JNI id swapping.
1435 bool automatically_set_jni_ids_indirection_;
1436
Orion Hodson971068d2021-06-30 21:17:53 +01001437 // True if files in /data/misc/apexdata/com.android.art are considered untrustworthy.
1438 bool deny_art_apex_data_files_;
1439
David Sehrd106d9f2016-08-16 19:22:57 -07001440 // Saved environment.
1441 class EnvSnapshot {
1442 public:
1443 EnvSnapshot() = default;
1444 void TakeSnapshot();
1445 char** GetSnapshot() const;
1446
1447 private:
1448 std::unique_ptr<char*[]> c_env_vector_;
1449 std::vector<std::unique_ptr<std::string>> name_value_pairs_;
1450
1451 DISALLOW_COPY_AND_ASSIGN(EnvSnapshot);
1452 } env_snapshot_;
1453
Andreas Gampefda57142016-09-08 20:29:18 -07001454 // Generic system-weak holders.
1455 std::vector<gc::AbstractSystemWeakHolder*> system_weak_holders_;
1456
Andreas Gampeac30fa22017-01-18 21:02:36 -08001457 std::unique_ptr<RuntimeCallbacks> callbacks_;
Andreas Gampe04bbb5b2017-01-19 17:49:03 +00001458
Nicolas Geoffray81cc43e2017-05-10 12:04:49 +01001459 std::atomic<uint32_t> deoptimization_counts_[
1460 static_cast<uint32_t>(DeoptimizationKind::kLast) + 1];
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +01001461
Vladimir Markoc34bebf2018-08-16 16:12:49 +01001462 MemMap protected_fault_page_;
Andreas Gampe2ac67d52017-05-11 22:30:38 -07001463
Andreas Gampe0b0ffc12018-08-01 14:41:27 -07001464 uint32_t verifier_logging_threshold_ms_;
1465
Mathieu Chartiera88abfa2019-02-04 11:08:29 -08001466 bool load_app_image_startup_cache_ = false;
1467
Mathieu Chartier175ce3d2019-03-06 16:54:24 -08001468 // If startup has completed, must happen at most once.
1469 std::atomic<bool> startup_completed_ = false;
1470
Andreas Gamped84794d2019-07-18 13:40:03 -07001471 bool verifier_missing_kthrow_fatal_;
Hans Boehm1792c6f2021-06-24 17:35:50 -07001472 bool force_java_zygote_fork_loop_;
Florian Mayer0972d082020-05-15 14:07:31 +02001473 bool perfetto_hprof_enabled_;
Wessam Hassaneinb5a10be2020-11-11 16:42:52 -08001474 bool perfetto_javaheapprof_enabled_;
Andreas Gamped84794d2019-07-18 13:40:03 -07001475
Eric Holka79872b2020-10-01 13:09:53 -07001476 metrics::ArtMetrics metrics_;
Eric Holk59d4b532020-10-21 17:49:39 -07001477 std::unique_ptr<metrics::MetricsReporter> metrics_reporter_;
Eric Holka79872b2020-10-01 13:09:53 -07001478
Nicolas Geoffrayd3c45c22021-04-27 13:21:28 +01001479 // Apex versions of boot classpath jars concatenated in a string. The format
1480 // is of the type:
1481 // '/apex1_version/apex2_version//'
1482 //
1483 // When the apex is the factory version, we don't encode it (for example in
1484 // the third entry in the example above).
1485 std::string apex_versions_;
1486
Calin Juravlec2753e62021-06-25 15:34:09 -07001487 // The info about the application code paths.
1488 AppInfo app_info_;
1489
Andreas Gampe44f67602018-11-28 08:27:27 -08001490 // Note: See comments on GetFaultMessage.
1491 friend std::string GetFaultMessageForAbortLogging();
Vladimir Markoc0e0e5e2020-01-23 17:43:05 +00001492 friend class Dex2oatImageTest;
Mathieu Chartierada33d72018-12-17 13:17:30 -08001493 friend class ScopedThreadPoolUsage;
Vladimir Markof3d88a82018-12-21 16:38:47 +00001494 friend class OatFileAssistantTest;
Mathieu Chartierad390fa2019-10-16 20:03:00 -07001495 class NotifyStartupCompletedTask;
Andreas Gampe44f67602018-11-28 08:27:27 -08001496
Carl Shapiro61e019d2011-07-14 16:53:09 -07001497 DISALLOW_COPY_AND_ASSIGN(Runtime);
Carl Shapiro1fb86202011-06-27 17:43:13 -07001498};
1499
Eric Holka79872b2020-10-01 13:09:53 -07001500inline metrics::ArtMetrics* GetMetrics() { return Runtime::Current()->GetMetrics(); }
1501
Carl Shapiro1fb86202011-06-27 17:43:13 -07001502} // namespace art
1503
Brian Carlstromfc0e3212013-07-17 14:40:12 -07001504#endif // ART_RUNTIME_RUNTIME_H_