blob: 1436a5f353ed5d55c95d4cb48312b59fda83f570 [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
Elliott Hughese27955c2011-08-26 15:21:24 -070023#include <iosfwd>
Eric Holka79872b2020-10-01 13:09:53 -070024#include <memory>
Hiroshi Yamauchi799eb3a2014-07-18 15:38:17 -070025#include <set>
Brian Carlstrom6ea095a2011-08-16 15:26:54 -070026#include <string>
Carl Shapirofc322c72011-07-27 00:20:01 -070027#include <utility>
Brian Carlstrom6ea095a2011-08-16 15:26:54 -070028#include <vector>
Brian Carlstrom578bbdc2011-07-21 14:07:47 -070029
Andreas Gampe44f67602018-11-28 08:27:27 -080030#include "base/locks.h"
Andreas Gampe794ad762015-02-23 08:12:24 -080031#include "base/macros.h"
Vladimir Markoc34bebf2018-08-16 16:12:49 +010032#include "base/mem_map.h"
Eric Holk480d9812021-01-27 23:41:45 +000033#include "base/metrics/metrics.h"
Nicolas Geoffray4cbb51a2020-02-07 11:25:54 +000034#include "base/string_view_cpp20.h"
Andrei Onea037d2822020-11-19 00:20:04 +000035#include "compat_framework.h"
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +010036#include "deoptimization_kind.h"
David Sehr9e734c72018-01-04 17:56:19 -080037#include "dex/dex_file_types.h"
Alex Lighteb7c1442015-08-31 13:17:42 -070038#include "experimental_flags.h"
Hiroshi Yamauchi94f7b492014-07-22 18:08:23 -070039#include "gc_root.h"
Ian Rogers62d6c772013-02-27 08:32:07 -080040#include "instrumentation.h"
Alex Light40320712017-12-14 11:52:04 -080041#include "jdwp_provider.h"
Alex Light79d6c802019-06-27 15:50:11 +000042#include "jni/jni_id_manager.h"
43#include "jni_id_type.h"
Eric Holk39d529f2021-02-17 12:48:53 -080044#include "metrics/reporter.h"
Mathieu Chartier8778c522016-10-04 19:06:30 -070045#include "obj_ptr.h"
Ian Rogers576ca0c2014-06-06 15:58:22 -070046#include "offsets.h"
Mathieu Chartierf8cb1782016-03-18 18:45:41 -070047#include "process_state.h"
Vladimir Marko7624d252014-05-02 14:40:15 +010048#include "quick/quick_method_frame_info.h"
Alex Lightc18eba32019-09-24 14:36:27 -070049#include "reflective_value_visitor.h"
Elliott Hughes9d5ccec2011-09-19 13:19:50 -070050#include "runtime_stats.h"
Carl Shapirob5573532011-07-12 18:22:59 -070051
Carl Shapiro1fb86202011-06-27 17:43:13 -070052namespace art {
53
Ian Rogers1d54e732013-05-02 21:10:01 -070054namespace gc {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080055class AbstractSystemWeakHolder;
56class Heap;
Ian Rogers576ca0c2014-06-06 15:58:22 -070057} // namespace gc
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080058
Mathew Inwooda5dc52c2018-02-19 15:30:51 +000059namespace hiddenapi {
60enum class EnforcementPolicy;
61} // namespace hiddenapi
62
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080063namespace jit {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080064class Jit;
Orion Hodsonad28f5e2018-10-17 09:08:17 +010065class JitCodeCache;
Igor Murashkin2ffb7032017-11-08 13:35:21 -080066class JitOptions;
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080067} // namespace jit
68
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080069namespace mirror {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080070class Array;
71class ClassLoader;
72class DexCache;
73template<class T> class ObjectArray;
74template<class T> class PrimitiveArray;
75typedef PrimitiveArray<int8_t> ByteArray;
76class String;
77class Throwable;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080078} // namespace mirror
Alex Light7233c7e2016-07-28 10:07:45 -070079namespace ti {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080080class Agent;
Andreas Gampeaadcbc62017-12-28 14:05:42 -080081class AgentSpec;
Alex Light7233c7e2016-07-28 10:07:45 -070082} // namespace ti
Mathieu Chartierc528dba2013-11-26 12:00:11 -080083namespace verifier {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080084class MethodVerifier;
85enum class VerifyMode : int8_t;
Ian Rogers6a3c1fc2014-10-31 00:33:20 -070086} // namespace verifier
Mathieu Chartiere401d142015-04-22 13:56:20 -070087class ArenaPool;
88class ArtMethod;
Andreas Gampe8228cdf2017-05-30 15:03:54 -070089enum class CalleeSaveType: uint32_t;
Carl Shapiro61e019d2011-07-14 16:53:09 -070090class ClassLinker;
Mathieu Chartiere401d142015-04-22 13:56:20 -070091class CompilerCallbacks;
Vladimir Markoc0e0e5e2020-01-23 17:43:05 +000092class Dex2oatImageTest;
Carl Shapirofc322c72011-07-27 00:20:01 -070093class DexFile;
Andreas Gampe639b2b12019-01-08 10:32:50 -080094enum class InstructionSet;
Elliott Hughescf4c6c42011-09-01 15:16:42 -070095class InternTable;
Andreas Gamped482e732017-04-24 17:59:09 -070096class IsMarkedVisitor;
Ian Rogersb48b9eb2014-02-28 16:20:21 -080097class JavaVMExt;
Mathieu Chartiere401d142015-04-22 13:56:20 -070098class LinearAlloc;
Elliott Hughesc33a32b2011-10-11 18:18:07 -070099class MonitorList;
Ian Rogersef7d42f2014-01-06 12:55:46 -0800100class MonitorPool;
Ian Rogers576ca0c2014-06-06 15:58:22 -0700101class NullPointerHandler;
Vladimir Markof3d88a82018-12-21 16:38:47 +0000102class OatFileAssistantTest;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -0700103class OatFileManager;
Alex Light185d1342016-08-11 10:48:03 -0700104class Plugin;
Vladimir Marko88b2b802015-12-04 14:19:04 +0000105struct RuntimeArgumentMap;
Andreas Gampeac30fa22017-01-18 21:02:36 -0800106class RuntimeCallbacks;
Elliott Hughese27955c2011-08-26 15:21:24 -0700107class SignalCatcher;
Ian Rogers576ca0c2014-06-06 15:58:22 -0700108class StackOverflowHandler;
109class SuspensionHandler;
Carl Shapiro61e019d2011-07-14 16:53:09 -0700110class ThreadList;
Mathieu Chartierc6068c72018-11-13 16:00:58 -0800111class ThreadPool;
jeffhao2692b572011-12-16 15:42:28 -0800112class Trace;
Andreas Gampef6a780a2015-04-02 18:51:05 -0700113struct TraceConfig;
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100114class Transaction;
Carl Shapiro61e019d2011-07-14 16:53:09 -0700115
Ian Rogerse63db272014-07-15 15:36:11 -0700116typedef std::vector<std::pair<std::string, const void*>> RuntimeOptions;
117
Carl Shapiro1fb86202011-06-27 17:43:13 -0700118class Runtime {
119 public:
Vladimir Marko88b2b802015-12-04 14:19:04 +0000120 // Parse raw runtime options.
121 static bool ParseOptions(const RuntimeOptions& raw_options,
122 bool ignore_unrecognized,
123 RuntimeArgumentMap* runtime_options);
124
Carl Shapiro61e019d2011-07-14 16:53:09 -0700125 // Creates and initializes a new runtime.
Vladimir Marko88b2b802015-12-04 14:19:04 +0000126 static bool Create(RuntimeArgumentMap&& runtime_options)
127 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
128
129 // Creates and initializes a new runtime.
130 static bool Create(const RuntimeOptions& raw_options, bool ignore_unrecognized)
Ian Rogersb726dcb2012-09-05 08:57:23 -0700131 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
Brian Carlstrom69b15fb2011-09-03 12:25:21 -0700132
Florian Mayer07710c52019-09-16 15:53:38 +0000133 bool EnsurePluginLoaded(const char* plugin_name, std::string* error_msg);
134 bool EnsurePerfettoPlugin(std::string* error_msg);
135
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800136 // IsAotCompiler for compilers that don't have a running runtime. Only dex2oat currently.
137 bool IsAotCompiler() const {
Calin Juravleffc87072016-04-20 14:22:09 +0100138 return !UseJitCompilation() && IsCompiler();
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800139 }
140
141 // IsCompiler is any runtime which has a running compiler, either dex2oat or JIT.
Elliott Hughesd9c67be2012-02-02 19:54:06 -0800142 bool IsCompiler() const {
Vladimir Marko2b5eaa22013-12-13 13:59:30 +0000143 return compiler_callbacks_ != nullptr;
144 }
145
Andreas Gampe4585f872015-03-27 23:45:15 -0700146 // If a compiler, are we compiling a boot image?
147 bool IsCompilingBootImage() const;
148
149 bool CanRelocate() const;
Alex Lighta59dd802014-07-02 16:28:08 -0700150
151 bool ShouldRelocate() const {
152 return must_relocate_ && CanRelocate();
153 }
154
155 bool MustRelocateIfPossible() const {
156 return must_relocate_;
157 }
158
Alex Light64ad14d2014-08-19 14:23:13 -0700159 bool IsImageDex2OatEnabled() const {
160 return image_dex2oat_enabled_;
Nicolas Geoffray4fcdc942014-07-22 10:48:00 +0100161 }
162
Vladimir Marko2b5eaa22013-12-13 13:59:30 +0000163 CompilerCallbacks* GetCompilerCallbacks() {
164 return compiler_callbacks_;
Elliott Hughesd9c67be2012-02-02 19:54:06 -0800165 }
166
Mathieu Chartier07ddb6f2015-11-05 11:16:34 -0800167 void SetCompilerCallbacks(CompilerCallbacks* callbacks) {
168 CHECK(callbacks != nullptr);
169 compiler_callbacks_ = callbacks;
170 }
171
Brian Carlstromcaabb1b2011-10-11 18:09:13 -0700172 bool IsZygote() const {
173 return is_zygote_;
174 }
175
Nicolas Geoffray4444f1b2019-06-10 14:09:19 +0100176 bool IsPrimaryZygote() const {
177 return is_primary_zygote_;
178 }
179
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +0100180 bool IsSystemServer() const {
181 return is_system_server_;
182 }
183
Nicolas Geoffraya67daeb2019-08-12 10:41:25 +0100184 void SetAsSystemServer() {
185 is_system_server_ = true;
186 is_zygote_ = false;
187 is_primary_zygote_ = false;
188 }
189
190 void SetAsZygoteChild(bool is_system_server, bool is_zygote) {
191 // System server should have been set earlier in SetAsSystemServer.
192 CHECK_EQ(is_system_server_, is_system_server);
193 is_zygote_ = is_zygote;
194 is_primary_zygote_ = false;
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +0100195 }
196
Anwar Ghuloum87183592013-08-14 12:12:19 -0700197 bool IsExplicitGcDisabled() const {
198 return is_explicit_gc_disabled_;
199 }
200
Tsu Chiang Chuang12e6d742014-05-22 10:22:25 -0700201 std::string GetCompilerExecutable() const;
202
Brian Carlstrom6449c622014-02-10 23:48:36 -0800203 const std::vector<std::string>& GetCompilerOptions() const {
204 return compiler_options_;
Dragos Sbirlea7467ee02013-06-21 09:20:34 -0700205 }
206
Vladimir Marko5c657fe2016-11-03 15:12:29 +0000207 void AddCompilerOption(const std::string& option) {
Andreas Gamped2abbc92014-12-19 09:53:27 -0800208 compiler_options_.push_back(option);
209 }
210
Brian Carlstrom6449c622014-02-10 23:48:36 -0800211 const std::vector<std::string>& GetImageCompilerOptions() const {
212 return image_compiler_options_;
Anwar Ghuloum8447d842013-04-30 17:27:40 -0700213 }
214
Victor Hsieh61ffd042021-05-20 15:14:25 -0700215 const std::vector<std::string>& GetImageLocations() const {
216 return image_locations_;
Brian Carlstrom31d8f522014-09-29 11:22:54 -0700217 }
218
Brian Carlstrom69b15fb2011-09-03 12:25:21 -0700219 // Starts a runtime, which may cause threads to be started and code to run.
Brian Carlstrombd86bcc2013-03-10 20:26:16 -0700220 bool Start() UNLOCK_FUNCTION(Locks::mutator_lock_);
Carl Shapiro2ed144c2011-07-26 16:52:08 -0700221
Mathieu Chartier590fee92013-09-13 13:46:47 -0700222 bool IsShuttingDown(Thread* self);
Mathieu Chartier90443472015-07-16 20:32:27 -0700223 bool IsShuttingDownLocked() const REQUIRES(Locks::runtime_shutdown_lock_) {
Ian Rogers9af209c2012-06-03 20:50:30 -0700224 return shutting_down_;
225 }
226
Mathieu Chartier90443472015-07-16 20:32:27 -0700227 size_t NumberOfThreadsBeingBorn() const REQUIRES(Locks::runtime_shutdown_lock_) {
Ian Rogers120f1c72012-09-28 17:17:10 -0700228 return threads_being_born_;
229 }
230
Mathieu Chartier90443472015-07-16 20:32:27 -0700231 void StartThreadBirth() REQUIRES(Locks::runtime_shutdown_lock_) {
Ian Rogers120f1c72012-09-28 17:17:10 -0700232 threads_being_born_++;
233 }
234
Mathieu Chartier90443472015-07-16 20:32:27 -0700235 void EndThreadBirth() REQUIRES(Locks::runtime_shutdown_lock_);
Ian Rogers120f1c72012-09-28 17:17:10 -0700236
Ian Rogers9af209c2012-06-03 20:50:30 -0700237 bool IsStarted() const {
238 return started_;
239 }
Elliott Hughesdcc24742011-09-07 14:02:44 -0700240
Mathieu Chartier7664f5c2012-06-08 18:15:32 -0700241 bool IsFinishedStarting() const {
242 return finished_starting_;
243 }
244
Vladimir Markodcfcce42018-06-27 10:00:28 +0000245 void RunRootClinits(Thread* self) REQUIRES_SHARED(Locks::mutator_lock_);
246
Carl Shapiro2ed144c2011-07-26 16:52:08 -0700247 static Runtime* Current() {
248 return instance_;
249 }
Carl Shapiro1fb86202011-06-27 17:43:13 -0700250
Nicolas Geoffraydb978712014-12-09 13:33:38 +0000251 // Aborts semi-cleanly. Used in the implementation of LOG(FATAL), which most
252 // callers should prefer.
Andreas Gampe90a32b12016-10-03 19:47:08 -0700253 NO_RETURN static void Abort(const char* msg) REQUIRES(!Locks::abort_lock_);
Elliott Hughesffe67362011-07-17 12:09:27 -0700254
Ian Rogers365c1022012-06-22 15:05:28 -0700255 // Returns the "main" ThreadGroup, used when attaching user threads.
Brian Carlstrom034f76b2012-08-01 15:51:58 -0700256 jobject GetMainThreadGroup() const;
Ian Rogers365c1022012-06-22 15:05:28 -0700257
258 // Returns the "system" ThreadGroup, used when attaching our internal threads.
Brian Carlstrom034f76b2012-08-01 15:51:58 -0700259 jobject GetSystemThreadGroup() const;
Ian Rogers365c1022012-06-22 15:05:28 -0700260
Brian Carlstromce888532013-10-10 00:32:58 -0700261 // Returns the system ClassLoader which represents the CLASSPATH.
262 jobject GetSystemClassLoader() const;
263
Elliott Hughes462c9442012-03-23 18:47:50 -0700264 // Attaches the calling native thread to the runtime.
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700265 bool AttachCurrentThread(const char* thread_name, bool as_daemon, jobject thread_group,
Mathieu Chartier664bebf2012-11-12 16:54:11 -0800266 bool create_peer);
Carl Shapiro61e019d2011-07-14 16:53:09 -0700267
Elliott Hughesbf86d042011-08-31 17:53:14 -0700268 void CallExitHook(jint status);
269
Carl Shapiro61e019d2011-07-14 16:53:09 -0700270 // Detaches the current native thread from the runtime.
Mathieu Chartier90443472015-07-16 20:32:27 -0700271 void DetachCurrentThread() REQUIRES(!Locks::mutator_lock_);
Carl Shapiro61e019d2011-07-14 16:53:09 -0700272
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +0100273 void DumpDeoptimizations(std::ostream& os);
Ian Rogers7b078e82014-09-10 14:44:24 -0700274 void DumpForSigQuit(std::ostream& os);
Elliott Hughes21a5bf22011-12-07 14:35:20 -0800275 void DumpLockHolders(std::ostream& os);
Elliott Hughese27955c2011-08-26 15:21:24 -0700276
Carl Shapiro61e019d2011-07-14 16:53:09 -0700277 ~Runtime();
Carl Shapirob5573532011-07-12 18:22:59 -0700278
Vladimir Markod1908512018-11-22 14:57:28 +0000279 const std::vector<std::string>& GetBootClassPath() const {
280 return boot_class_path_;
281 }
282
283 const std::vector<std::string>& GetBootClassPathLocations() const {
284 DCHECK(boot_class_path_locations_.empty() ||
285 boot_class_path_locations_.size() == boot_class_path_.size());
286 return boot_class_path_locations_.empty() ? boot_class_path_ : boot_class_path_locations_;
Brian Carlstroma004aa92012-02-08 18:05:09 -0800287 }
288
289 const std::string& GetClassPathString() const {
290 return class_path_string_;
Brian Carlstromb765be02011-08-17 23:54:10 -0700291 }
292
293 ClassLinker* GetClassLinker() const {
Carl Shapiro7a909592011-07-24 19:21:59 -0700294 return class_linker_;
295 }
296
Alex Light79d6c802019-06-27 15:50:11 +0000297 jni::JniIdManager* GetJniIdManager() const {
298 return jni_id_manager_.get();
299 }
300
Elliott Hughes7ede61e2011-09-14 18:18:06 -0700301 size_t GetDefaultStackSize() const {
302 return default_stack_size_;
303 }
304
Hans Boehmb2155572019-03-27 14:25:53 -0700305 unsigned int GetFinalizerTimeoutMs() const {
306 return finalizer_timeout_ms_;
307 }
308
Ian Rogers1d54e732013-05-02 21:10:01 -0700309 gc::Heap* GetHeap() const {
Elliott Hughesb3bd5f02012-03-08 21:05:27 -0800310 return heap_;
311 }
312
Elliott Hughescf4c6c42011-09-01 15:16:42 -0700313 InternTable* GetInternTable() const {
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700314 DCHECK(intern_table_ != nullptr);
Elliott Hughescf4c6c42011-09-01 15:16:42 -0700315 return intern_table_;
316 }
317
Elliott Hughes0af55432011-08-17 18:37:28 -0700318 JavaVMExt* GetJavaVM() const {
Richard Uhlerda0a69e2016-10-11 15:06:38 +0100319 return java_vm_.get();
Elliott Hughesf2682d52011-08-15 16:37:04 -0700320 }
321
Hans Boehmb3da36c2016-12-15 13:12:59 -0800322 size_t GetMaxSpinsBeforeThinLockInflation() const {
Ian Rogersd9c4fc92013-10-01 19:45:43 -0700323 return max_spins_before_thin_lock_inflation_;
324 }
325
Elliott Hughesc33a32b2011-10-11 18:18:07 -0700326 MonitorList* GetMonitorList() const {
327 return monitor_list_;
328 }
329
Ian Rogersef7d42f2014-01-06 12:55:46 -0800330 MonitorPool* GetMonitorPool() const {
331 return monitor_pool_;
332 }
333
Ian Rogersc0542af2014-09-03 16:16:56 -0700334 // Is the given object the special object used to mark a cleared JNI weak global?
Mathieu Chartier8778c522016-10-04 19:06:30 -0700335 bool IsClearedJniWeakGlobal(ObjPtr<mirror::Object> obj) REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogersc0542af2014-09-03 16:16:56 -0700336
337 // Get the special object used to mark a cleared JNI weak global.
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700338 mirror::Object* GetClearedJniWeakGlobal() REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogersc0542af2014-09-03 16:16:56 -0700339
Roland Levillain7b0e8442018-04-11 18:27:47 +0100340 mirror::Throwable* GetPreAllocatedOutOfMemoryErrorWhenThrowingException()
341 REQUIRES_SHARED(Locks::mutator_lock_);
342 mirror::Throwable* GetPreAllocatedOutOfMemoryErrorWhenThrowingOOME()
343 REQUIRES_SHARED(Locks::mutator_lock_);
344 mirror::Throwable* GetPreAllocatedOutOfMemoryErrorWhenHandlingStackOverflow()
345 REQUIRES_SHARED(Locks::mutator_lock_);
Elliott Hughes225f5a12012-06-11 11:23:48 -0700346
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700347 mirror::Throwable* GetPreAllocatedNoClassDefFoundError()
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700348 REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogers63557452014-06-04 16:57:15 -0700349
Elliott Hughes225f5a12012-06-11 11:23:48 -0700350 const std::vector<std::string>& GetProperties() const {
351 return properties_;
352 }
353
Elliott Hughesd92bec42011-09-02 17:04:36 -0700354 ThreadList* GetThreadList() const {
355 return thread_list_;
356 }
357
Brian Carlstrom491ca9e2014-03-02 18:24:38 -0800358 static const char* GetVersion() {
Andreas Gampe2153f932014-06-26 08:09:17 -0700359 return "2.1.0";
Elliott Hughes7ede61e2011-09-14 18:18:06 -0700360 }
361
Narayan Kamath25352fc2016-08-03 12:46:58 +0100362 bool IsMethodHandlesEnabled() const {
Narayan Kamath93206752017-01-17 13:20:55 +0000363 return true;
Narayan Kamath25352fc2016-08-03 12:46:58 +0100364 }
365
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700366 void DisallowNewSystemWeaks() REQUIRES_SHARED(Locks::mutator_lock_);
367 void AllowNewSystemWeaks() REQUIRES_SHARED(Locks::mutator_lock_);
Hiroshi Yamauchi30493242016-11-03 13:06:52 -0700368 // broadcast_for_checkpoint is true when we broadcast for making blocking threads to respond to
369 // checkpoint requests. It's false when we broadcast to unblock blocking threads after system weak
370 // access is reenabled.
371 void BroadcastForNewSystemWeaks(bool broadcast_for_checkpoint = false);
Mathieu Chartierc11d9b82013-09-19 10:01:59 -0700372
Ian Rogers1d54e732013-05-02 21:10:01 -0700373 // Visit all the roots. If only_dirty is true then non-dirty roots won't be visited. If
374 // clean_dirty is true then dirty roots will be marked as non-dirty after visiting.
Mathieu Chartierbb87e0f2015-04-03 11:21:55 -0700375 void VisitRoots(RootVisitor* visitor, VisitRootFlags flags = kVisitRootFlagAllRoots)
Andreas Gamped98b4ed2016-11-04 20:27:24 -0700376 REQUIRES(!Locks::classlinker_classes_lock_, !Locks::trace_lock_)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700377 REQUIRES_SHARED(Locks::mutator_lock_);
Brian Carlstrom1f870082011-08-23 16:02:11 -0700378
Mathieu Chartier461687d2015-03-31 12:05:24 -0700379 // Visit image roots, only used for hprof since the GC uses the image space mod union table
380 // instead.
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700381 void VisitImageRoots(RootVisitor* visitor) REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier461687d2015-03-31 12:05:24 -0700382
Roland Levillainef012222017-06-21 16:28:06 +0100383 // Visit all of the roots we can safely visit concurrently.
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700384 void VisitConcurrentRoots(RootVisitor* visitor,
385 VisitRootFlags flags = kVisitRootFlagAllRoots)
Andreas Gamped98b4ed2016-11-04 20:27:24 -0700386 REQUIRES(!Locks::classlinker_classes_lock_, !Locks::trace_lock_)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700387 REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier9ebae1f2012-10-15 17:38:16 -0700388
Mathieu Chartier858f1c52012-10-17 17:45:55 -0700389 // Visit all of the non thread roots, we can do this with mutators unpaused.
Mathieu Chartierbb87e0f2015-04-03 11:21:55 -0700390 void VisitNonThreadRoots(RootVisitor* visitor)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700391 REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier858f1c52012-10-17 17:45:55 -0700392
Mathieu Chartierbb87e0f2015-04-03 11:21:55 -0700393 void VisitTransactionRoots(RootVisitor* visitor)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700394 REQUIRES_SHARED(Locks::mutator_lock_);
Hiroshi Yamauchi2cd334a2015-01-09 14:03:35 -0800395
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700396 // Sweep system weaks, the system weak is deleted if the visitor return null. Otherwise, the
Mathieu Chartier6aa3df92013-09-17 15:17:28 -0700397 // system weak is updated to be the visitor's returned value.
Mathieu Chartier97509952015-07-13 14:35:43 -0700398 void SweepSystemWeaks(IsMarkedVisitor* visitor)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700399 REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier6aa3df92013-09-17 15:17:28 -0700400
Alex Lightc18eba32019-09-24 14:36:27 -0700401 // Walk all reflective objects and visit their targets as well as any method/fields held by the
402 // runtime threads that are marked as being reflective.
403 void VisitReflectiveTargets(ReflectiveValueVisitor* visitor) REQUIRES(Locks::mutator_lock_);
404 // Helper for visiting reflective targets with lambdas for both field and method reflective
405 // targets.
406 template <typename FieldVis, typename MethodVis>
407 void VisitReflectiveTargets(FieldVis&& fv, MethodVis&& mv) REQUIRES(Locks::mutator_lock_) {
408 FunctionReflectiveValueVisitor frvv(fv, mv);
409 VisitReflectiveTargets(&frvv);
410 }
411
Ian Rogers9af209c2012-06-03 20:50:30 -0700412 // Returns a special method that calls into a trampoline for runtime method resolution
Mathieu Chartierfbc31082016-01-24 11:59:56 -0800413 ArtMethod* GetResolutionMethod();
Ian Rogers9af209c2012-06-03 20:50:30 -0700414
415 bool HasResolutionMethod() const {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700416 return resolution_method_ != nullptr;
Ian Rogers9af209c2012-06-03 20:50:30 -0700417 }
418
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700419 void SetResolutionMethod(ArtMethod* method) REQUIRES_SHARED(Locks::mutator_lock_);
Igor Murashkin8275fba2017-05-02 15:58:02 -0700420 void ClearResolutionMethod() {
421 resolution_method_ = nullptr;
422 }
Ian Rogers9af209c2012-06-03 20:50:30 -0700423
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700424 ArtMethod* CreateResolutionMethod() REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogers19846512012-02-24 11:42:47 -0800425
Ian Rogerse63db272014-07-15 15:36:11 -0700426 // Returns a special method that calls into a trampoline for runtime imt conflicts.
Mathieu Chartierfbc31082016-01-24 11:59:56 -0800427 ArtMethod* GetImtConflictMethod();
428 ArtMethod* GetImtUnimplementedMethod();
Jeff Hao88474b42013-10-23 16:24:40 -0700429
430 bool HasImtConflictMethod() const {
Mathieu Chartiere401d142015-04-22 13:56:20 -0700431 return imt_conflict_method_ != nullptr;
Jeff Hao88474b42013-10-23 16:24:40 -0700432 }
433
Igor Murashkin8275fba2017-05-02 15:58:02 -0700434 void ClearImtConflictMethod() {
435 imt_conflict_method_ = nullptr;
436 }
437
Nicolas Geoffrayf05f04b2019-10-31 11:50:41 +0000438 void FixupConflictTables() REQUIRES_SHARED(Locks::mutator_lock_);
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700439 void SetImtConflictMethod(ArtMethod* method) REQUIRES_SHARED(Locks::mutator_lock_);
440 void SetImtUnimplementedMethod(ArtMethod* method) REQUIRES_SHARED(Locks::mutator_lock_);
Jeff Hao88474b42013-10-23 16:24:40 -0700441
Nicolas Geoffray796d6302016-03-13 22:22:31 +0000442 ArtMethod* CreateImtConflictMethod(LinearAlloc* linear_alloc)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700443 REQUIRES_SHARED(Locks::mutator_lock_);
Jeff Hao88474b42013-10-23 16:24:40 -0700444
Igor Murashkin8275fba2017-05-02 15:58:02 -0700445 void ClearImtUnimplementedMethod() {
446 imt_unimplemented_method_ = nullptr;
447 }
448
Ian Rogers9af209c2012-06-03 20:50:30 -0700449 bool HasCalleeSaveMethod(CalleeSaveType type) const {
Andreas Gampe8228cdf2017-05-30 15:03:54 -0700450 return callee_save_methods_[static_cast<size_t>(type)] != 0u;
Ian Rogers9af209c2012-06-03 20:50:30 -0700451 }
452
Mathieu Chartiere401d142015-04-22 13:56:20 -0700453 ArtMethod* GetCalleeSaveMethod(CalleeSaveType type)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700454 REQUIRES_SHARED(Locks::mutator_lock_);
Hiroshi Yamauchiab088112014-07-14 13:00:14 -0700455
Mathieu Chartiere401d142015-04-22 13:56:20 -0700456 ArtMethod* GetCalleeSaveMethodUnchecked(CalleeSaveType type)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700457 REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogers9af209c2012-06-03 20:50:30 -0700458
Mathieu Chartiere401d142015-04-22 13:56:20 -0700459 QuickMethodFrameInfo GetRuntimeMethodFrameInfo(ArtMethod* method)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700460 REQUIRES_SHARED(Locks::mutator_lock_);
Vladimir Marko7624d252014-05-02 14:40:15 +0100461
David Srbecky56de89a2018-10-01 15:32:20 +0100462 static constexpr size_t GetCalleeSaveMethodOffset(CalleeSaveType type) {
Andreas Gampe8228cdf2017-05-30 15:03:54 -0700463 return OFFSETOF_MEMBER(Runtime, callee_save_methods_[static_cast<size_t>(type)]);
Ian Rogers936b37f2014-02-14 00:52:24 -0800464 }
465
Vladimir Marko7624d252014-05-02 14:40:15 +0100466 InstructionSet GetInstructionSet() const {
467 return instruction_set_;
468 }
469
470 void SetInstructionSet(InstructionSet instruction_set);
Igor Murashkin8275fba2017-05-02 15:58:02 -0700471 void ClearInstructionSet();
Vladimir Marko7624d252014-05-02 14:40:15 +0100472
Mathieu Chartiere401d142015-04-22 13:56:20 -0700473 void SetCalleeSaveMethod(ArtMethod* method, CalleeSaveType type);
Igor Murashkin8275fba2017-05-02 15:58:02 -0700474 void ClearCalleeSaveMethods();
Ian Rogers4f0d07c2011-10-06 23:38:47 -0700475
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700476 ArtMethod* CreateCalleeSaveMethod() REQUIRES_SHARED(Locks::mutator_lock_);
Ian Rogersff1ed472011-09-20 13:46:24 -0700477
Andreas Gampe7ee607e2019-07-23 12:22:04 -0700478 uint64_t GetStat(int kind);
Elliott Hughes9d5ccec2011-09-19 13:19:50 -0700479
Ian Rogers9af209c2012-06-03 20:50:30 -0700480 RuntimeStats* GetStats() {
481 return &stats_;
482 }
Elliott Hughes9d5ccec2011-09-19 13:19:50 -0700483
484 bool HasStatsEnabled() const {
485 return stats_enabled_;
486 }
487
488 void ResetStats(int kinds);
489
Mathieu Chartier90443472015-07-16 20:32:27 -0700490 void SetStatsEnabled(bool new_state)
491 REQUIRES(!Locks::instrument_entrypoints_lock_, !Locks::mutator_lock_);
Elliott Hughes9d5ccec2011-09-19 13:19:50 -0700492
Andreas Gampe6be67ee2014-09-02 21:22:18 -0700493 enum class NativeBridgeAction { // private
494 kUnload,
495 kInitialize
496 };
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800497
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000498 jit::Jit* GetJit() const {
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800499 return jit_.get();
500 }
Calin Juravleffc87072016-04-20 14:22:09 +0100501
David Srbecky9ac8e432019-08-13 13:16:13 +0100502 jit::JitCodeCache* GetJitCodeCache() const {
503 return jit_code_cache_.get();
504 }
505
Calin Juravleffc87072016-04-20 14:22:09 +0100506 // Returns true if JIT compilations are enabled. GetJit() will be not null in this case.
507 bool UseJitCompilation() const;
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800508
Narayan Kamath3de95a72014-04-02 12:54:23 +0100509 void PreZygoteFork();
Nicolas Geoffrayce9ed362018-11-29 03:19:28 +0000510 void PostZygoteFork();
Nicolas Geoffrayd66c8622015-12-11 14:59:16 +0000511 void InitNonZygoteOrPostFork(
Calin Juravle016fcbe22018-05-03 19:47:35 -0700512 JNIEnv* env,
513 bool is_system_server,
Lev Rumyantsev87f36302019-12-13 15:49:37 -0800514 bool is_child_zygote,
Calin Juravle016fcbe22018-05-03 19:47:35 -0700515 NativeBridgeAction action,
516 const char* isa,
517 bool profile_system_server = false);
Brian Carlstromcaabb1b2011-10-11 18:09:13 -0700518
Ian Rogers9bc54402014-04-17 16:40:01 -0700519 const instrumentation::Instrumentation* GetInstrumentation() const {
520 return &instrumentation_;
521 }
522
Ian Rogers62d6c772013-02-27 08:32:07 -0800523 instrumentation::Instrumentation* GetInstrumentation() {
524 return &instrumentation_;
525 }
jeffhao2692b572011-12-16 15:42:28 -0800526
Calin Juravle66f55232015-12-08 15:09:10 +0000527 void RegisterAppInfo(const std::vector<std::string>& code_paths,
Calin Juravle77651c42017-03-03 18:04:02 -0800528 const std::string& profile_output_filename);
Dave Allison0aded082013-11-07 13:15:11 -0800529
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100530 // Transaction support.
Chang Xing605fe242017-07-20 15:57:21 -0700531 bool IsActiveTransaction() const;
Chang Xing5a906fc2017-07-26 15:01:16 -0700532 void EnterTransactionMode(bool strict, mirror::Class* root);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100533 void ExitTransactionMode();
Chang Xing605fe242017-07-20 15:57:21 -0700534 void RollbackAllTransactions() REQUIRES_SHARED(Locks::mutator_lock_);
Chang Xing16d1dd82017-07-20 17:56:26 -0700535 // Transaction rollback and exit transaction are always done together, it's convenience to
536 // do them in one function.
537 void RollbackAndExitTransactionMode() REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100538 bool IsTransactionAborted() const;
Chang Xing605fe242017-07-20 15:57:21 -0700539 const std::unique_ptr<Transaction>& GetTransaction() const;
Chang Xing5a906fc2017-07-26 15:01:16 -0700540 bool IsActiveStrictTransactionMode() const;
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100541
Sebastien Hertz2fd7e692015-04-02 11:11:19 +0200542 void AbortTransactionAndThrowAbortError(Thread* self, const std::string& abort_message)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700543 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz2fd7e692015-04-02 11:11:19 +0200544 void ThrowTransactionAbortError(Thread* self)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700545 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100546
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700547 void RecordWriteFieldBoolean(mirror::Object* obj, MemberOffset field_offset, uint8_t value,
Fred Shih37f05ef2014-07-16 18:38:08 -0700548 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700549 void RecordWriteFieldByte(mirror::Object* obj, MemberOffset field_offset, int8_t value,
Fred Shih37f05ef2014-07-16 18:38:08 -0700550 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700551 void RecordWriteFieldChar(mirror::Object* obj, MemberOffset field_offset, uint16_t value,
Fred Shih37f05ef2014-07-16 18:38:08 -0700552 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700553 void RecordWriteFieldShort(mirror::Object* obj, MemberOffset field_offset, int16_t value,
Fred Shih37f05ef2014-07-16 18:38:08 -0700554 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700555 void RecordWriteField32(mirror::Object* obj, MemberOffset field_offset, uint32_t value,
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100556 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700557 void RecordWriteField64(mirror::Object* obj, MemberOffset field_offset, uint64_t value,
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100558 bool is_volatile) const;
Mathieu Chartiera058fdf2016-10-06 15:13:58 -0700559 void RecordWriteFieldReference(mirror::Object* obj,
560 MemberOffset field_offset,
561 ObjPtr<mirror::Object> value,
562 bool is_volatile) const
563 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100564 void RecordWriteArray(mirror::Array* array, size_t index, uint64_t value) const
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700565 REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier9e868092016-10-31 14:58:04 -0700566 void RecordStrongStringInsertion(ObjPtr<mirror::String> s) const
Mathieu Chartier90443472015-07-16 20:32:27 -0700567 REQUIRES(Locks::intern_table_lock_);
Mathieu Chartier9e868092016-10-31 14:58:04 -0700568 void RecordWeakStringInsertion(ObjPtr<mirror::String> s) const
Mathieu Chartier90443472015-07-16 20:32:27 -0700569 REQUIRES(Locks::intern_table_lock_);
Mathieu Chartier9e868092016-10-31 14:58:04 -0700570 void RecordStrongStringRemoval(ObjPtr<mirror::String> s) const
Mathieu Chartier90443472015-07-16 20:32:27 -0700571 REQUIRES(Locks::intern_table_lock_);
Mathieu Chartier9e868092016-10-31 14:58:04 -0700572 void RecordWeakStringRemoval(ObjPtr<mirror::String> s) const
Mathieu Chartier90443472015-07-16 20:32:27 -0700573 REQUIRES(Locks::intern_table_lock_);
Andreas Gampe8a0128a2016-11-28 07:38:35 -0800574 void RecordResolveString(ObjPtr<mirror::DexCache> dex_cache, dex::StringIndex string_idx) const
Mathieu Chartierbb816d62016-09-07 10:17:46 -0700575 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100576
Andreas Gampe44f67602018-11-28 08:27:27 -0800577 void SetFaultMessage(const std::string& message);
Mathieu Chartier15d34022014-02-26 17:16:38 -0800578
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700579 void AddCurrentRuntimeFeaturesAsDex2OatArguments(std::vector<std::string>* arg_vector) const;
Ian Rogers8afeb852014-04-02 14:55:49 -0700580
Dave Allisonb373e092014-02-20 16:06:36 -0800581 bool ExplicitStackOverflowChecks() const {
Andreas Gampe928f72b2014-09-09 19:53:48 -0700582 return !implicit_so_checks_;
Dave Allisonb373e092014-02-20 16:06:36 -0800583 }
584
Nicolas Geoffray68bf3902017-09-07 14:40:48 +0100585 void DisableVerifier();
Igor Murashkin7617abd2015-07-10 18:27:47 -0700586 bool IsVerificationEnabled() const;
587 bool IsVerificationSoftFail() const;
Jeff Hao4a200f52014-04-01 14:58:49 -0700588
Mathew Inwooda5dc52c2018-02-19 15:30:51 +0000589 void SetHiddenApiEnforcementPolicy(hiddenapi::EnforcementPolicy policy) {
590 hidden_api_policy_ = policy;
David Brazdil3e0fa0a2018-01-15 18:41:44 +0000591 }
592
Mathew Inwooda5dc52c2018-02-19 15:30:51 +0000593 hiddenapi::EnforcementPolicy GetHiddenApiEnforcementPolicy() const {
594 return hidden_api_policy_;
David Brazdil3e0fa0a2018-01-15 18:41:44 +0000595 }
596
David Brazdile7681822018-12-14 16:25:33 +0000597 void SetCorePlatformApiEnforcementPolicy(hiddenapi::EnforcementPolicy policy) {
598 core_platform_api_policy_ = policy;
599 }
600
601 hiddenapi::EnforcementPolicy GetCorePlatformApiEnforcementPolicy() const {
602 return core_platform_api_policy_;
603 }
604
satayev09efc162021-02-22 17:24:57 +0000605 void SetTestApiEnforcementPolicy(hiddenapi::EnforcementPolicy policy) {
606 test_api_policy_ = policy;
607 }
608
609 hiddenapi::EnforcementPolicy GetTestApiEnforcementPolicy() const {
610 return test_api_policy_;
611 }
612
Mathew Inwood3383aa52018-03-16 14:18:33 +0000613 void SetHiddenApiExemptions(const std::vector<std::string>& exemptions) {
614 hidden_api_exemptions_ = exemptions;
615 }
616
617 const std::vector<std::string>& GetHiddenApiExemptions() {
618 return hidden_api_exemptions_;
619 }
620
David Brazdilee7d2fd2018-01-20 17:25:23 +0000621 void SetDedupeHiddenApiWarnings(bool value) {
622 dedupe_hidden_api_warnings_ = value;
623 }
624
625 bool ShouldDedupeHiddenApiWarnings() {
626 return dedupe_hidden_api_warnings_;
627 }
628
Mathew Inwood73ddda42018-04-03 15:32:32 +0100629 void SetHiddenApiEventLogSampleRate(uint32_t rate) {
630 hidden_api_access_event_log_rate_ = rate;
631 }
632
633 uint32_t GetHiddenApiEventLogSampleRate() const {
634 return hidden_api_access_event_log_rate_;
635 }
636
Mathew Inwood5bcef172018-05-01 14:40:12 +0100637 const std::string& GetProcessPackageName() const {
638 return process_package_name_;
639 }
640
641 void SetProcessPackageName(const char* package_name) {
642 if (package_name == nullptr) {
643 process_package_name_.clear();
644 } else {
645 process_package_name_ = package_name;
646 }
647 }
648
David Brazdil35a3f6a2019-03-04 15:59:06 +0000649 const std::string& GetProcessDataDirectory() const {
650 return process_data_directory_;
651 }
652
653 void SetProcessDataDirectory(const char* data_dir) {
654 if (data_dir == nullptr) {
655 process_data_directory_.clear();
656 } else {
657 process_data_directory_ = data_dir;
658 }
659 }
660
Dmitriy Ivanov785049f2014-07-18 10:08:57 -0700661 const std::vector<std::string>& GetCpuAbilist() const {
662 return cpu_abilist_;
663 }
664
Evgenii Stepanov1e133742015-05-20 12:30:59 -0700665 bool IsRunningOnMemoryTool() const {
666 return is_running_on_memory_tool_;
Mathieu Chartierda44d772014-04-01 15:01:46 -0700667 }
668
David Brazdil2bb2fbd2018-11-13 18:24:26 +0000669 void SetTargetSdkVersion(uint32_t version) {
Jeff Haof00571c2014-05-29 17:29:47 -0700670 target_sdk_version_ = version;
671 }
672
David Brazdil2bb2fbd2018-11-13 18:24:26 +0000673 uint32_t GetTargetSdkVersion() const {
Jeff Haof00571c2014-05-29 17:29:47 -0700674 return target_sdk_version_;
675 }
676
Andrei Onea037d2822020-11-19 00:20:04 +0000677 CompatFramework& GetCompatFramework() {
678 return compat_framework_;
atrostfab72082019-12-06 13:37:36 +0000679 }
680
Narayan Kamath5a2be3f2015-02-16 13:51:51 +0000681 uint32_t GetZygoteMaxFailedBoots() const {
682 return zygote_max_failed_boots_;
683 }
684
Alex Lighteb7c1442015-08-31 13:17:42 -0700685 bool AreExperimentalFlagsEnabled(ExperimentalFlags flags) {
686 return (experimental_flags_ & flags) != ExperimentalFlags::kNone;
Igor Murashkin158f35c2015-06-10 15:55:30 -0700687 }
688
Orion Hodsonad28f5e2018-10-17 09:08:17 +0100689 void CreateJitCodeCache(bool rwx_memory_allowed);
690
Mathieu Chartier455f67c2015-03-17 13:48:29 -0700691 // Create the JIT and instrumentation and code cache.
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800692 void CreateJit();
693
Mathieu Chartier9b34b242015-03-09 11:30:17 -0700694 ArenaPool* GetArenaPool() {
695 return arena_pool_.get();
696 }
Nicolas Geoffray25e04562016-03-01 13:17:58 +0000697 ArenaPool* GetJitArenaPool() {
698 return jit_arena_pool_.get();
699 }
Mathieu Chartier9b34b242015-03-09 11:30:17 -0700700 const ArenaPool* GetArenaPool() const {
701 return arena_pool_.get();
702 }
Jean-Philippe Halimica76a1a2016-02-02 19:48:52 +0100703
704 void ReclaimArenaPoolMemory();
705
Mathieu Chartierc7853442015-03-27 14:35:38 -0700706 LinearAlloc* GetLinearAlloc() {
707 return linear_alloc_.get();
708 }
Mathieu Chartier9b34b242015-03-09 11:30:17 -0700709
Mathieu Chartier455f67c2015-03-17 13:48:29 -0700710 jit::JitOptions* GetJITOptions() {
711 return jit_options_.get();
712 }
713
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000714 bool IsJavaDebuggable() const {
715 return is_java_debuggable_;
Alex Light6b16d892016-11-11 11:21:04 -0800716 }
717
Florian Mayer07710c52019-09-16 15:53:38 +0000718 void SetProfileableFromShell(bool value) {
719 is_profileable_from_shell_ = value;
720 }
721
722 bool IsProfileableFromShell() const {
723 return is_profileable_from_shell_;
724 }
725
Florian Mayer0bc9bef2021-04-28 15:52:33 +0100726 void SetProfileable(bool value) {
727 is_profileable_ = value;
728 }
729
730 bool IsProfileable() const {
731 return is_profileable_;
732 }
733
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000734 void SetJavaDebuggable(bool value);
735
736 // Deoptimize the boot image, called for Java debuggable apps.
Nicolas Geoffray226805d2018-12-14 10:59:02 +0000737 void DeoptimizeBootImage() REQUIRES(Locks::mutator_lock_);
Alex Light6b16d892016-11-11 11:21:04 -0800738
David Srbeckyf4480162016-03-16 00:06:24 +0000739 bool IsNativeDebuggable() const {
740 return is_native_debuggable_;
741 }
742
743 void SetNativeDebuggable(bool value) {
744 is_native_debuggable_ = value;
745 }
746
randy.jeong5bef0222019-05-27 10:29:09 +0900747 void SetSignalHookDebuggable(bool value);
748
Alex Light0aa7a5a2018-10-10 15:58:14 +0000749 bool AreNonStandardExitsEnabled() const {
750 return non_standard_exits_enabled_;
751 }
752
753 void SetNonStandardExitsEnabled() {
David Srbecky28f6cff2018-10-16 15:07:28 +0100754 DoAndMaybeSwitchInterpreter([=](){ non_standard_exits_enabled_ = true; });
Alex Light0aa7a5a2018-10-10 15:58:14 +0000755 }
756
Alex Light7919db92017-11-29 09:00:55 -0800757 bool AreAsyncExceptionsThrown() const {
758 return async_exceptions_thrown_;
759 }
760
761 void SetAsyncExceptionsThrown() {
David Srbecky28f6cff2018-10-16 15:07:28 +0100762 DoAndMaybeSwitchInterpreter([=](){ async_exceptions_thrown_ = true; });
Alex Light7919db92017-11-29 09:00:55 -0800763 }
764
David Srbecky28f6cff2018-10-16 15:07:28 +0100765 // Change state and re-check which interpreter should be used.
766 //
767 // This must be called whenever there is an event that forces
768 // us to use different interpreter (e.g. debugger is attached).
769 //
770 // Changing the state using the lamda gives us some multihreading safety.
771 // It ensures that two calls do not interfere with each other and
772 // it makes it possible to DCHECK that thread local flag is correct.
773 template<typename Action>
David Srbeckyd3883902019-02-26 17:29:32 +0000774 static void DoAndMaybeSwitchInterpreter(Action lamda);
David Srbecky28f6cff2018-10-16 15:07:28 +0100775
Andreas Gampedd671252015-07-23 14:37:18 -0700776 // Returns the build fingerprint, if set. Otherwise an empty string is returned.
777 std::string GetFingerprint() {
778 return fingerprint_;
779 }
780
Mathieu Chartier673ed3d2015-08-28 14:56:43 -0700781 // Called from class linker.
Vladimir Marko024d69f2019-06-13 10:52:32 +0100782 void SetSentinel(ObjPtr<mirror::Object> sentinel) REQUIRES_SHARED(Locks::mutator_lock_);
Roland Levillain0e155592018-11-05 18:31:49 +0000783 // For testing purpose only.
784 // TODO: Remove this when this is no longer needed (b/116087961).
785 GcRoot<mirror::Object> GetSentinel() REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier673ed3d2015-08-28 14:56:43 -0700786
Nicolas Geoffraye3f775b2019-12-04 14:41:52 +0000787
788 // Use a sentinel for marking entries in a table that have been cleared.
789 // This helps diagnosing in case code tries to wrongly access such
790 // entries.
791 static mirror::Class* GetWeakClassSentinel() {
792 return reinterpret_cast<mirror::Class*>(0xebadbeef);
793 }
794
795 // Helper for the GC to process a weak class in a table.
796 static void ProcessWeakClass(GcRoot<mirror::Class>* root_ptr,
797 IsMarkedVisitor* visitor,
798 mirror::Class* update)
799 REQUIRES_SHARED(Locks::mutator_lock_);
800
Mathieu Chartier951ec2c2015-09-22 08:50:05 -0700801 // Create a normal LinearAlloc or low 4gb version if we are 64 bit AOT compiler.
802 LinearAlloc* CreateLinearAlloc();
803
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -0700804 OatFileManager& GetOatFileManager() const {
805 DCHECK(oat_file_manager_ != nullptr);
Mathieu Chartiere58991b2015-10-13 07:59:34 -0700806 return *oat_file_manager_;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -0700807 }
808
Mathieu Chartier32cc9ee2015-10-15 09:19:15 -0700809 double GetHashTableMinLoadFactor() const;
810 double GetHashTableMaxLoadFactor() const;
811
Andreas Gampe83e20492018-11-07 11:12:26 -0800812 bool IsSafeMode() const {
Andreas Gampe83e20492018-11-07 11:12:26 -0800813 return safe_mode_;
814 }
815
Nicolas Geoffray787ae8e2015-11-05 11:32:24 +0000816 void SetSafeMode(bool mode) {
817 safe_mode_ = mode;
818 }
819
Nicolas Geoffraya73280d2016-02-15 13:05:16 +0000820 bool GetDumpNativeStackOnSigQuit() const {
821 return dump_native_stack_on_sig_quit_;
822 }
823
Mathieu Chartierf8cb1782016-03-18 18:45:41 -0700824 void UpdateProcessState(ProcessState process_state);
825
826 // Returns true if we currently care about long mutator pause.
827 bool InJankPerceptibleProcessState() const {
828 return process_state_ == kProcessStateJankPerceptible;
829 }
830
Calin Juravle97cbc922016-04-15 16:16:35 +0100831 void RegisterSensitiveThread() const;
832
Andreas Gampef38a6612016-04-11 08:42:26 -0700833 void SetZygoteNoThreadSection(bool val) {
834 zygote_no_threads_ = val;
835 }
836
837 bool IsZygoteNoThreadSection() const {
838 return zygote_no_threads_;
839 }
840
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000841 // Returns if the code can be deoptimized asynchronously. Code may be compiled with some
Mingyao Yangf711f2c2016-05-23 12:29:39 -0700842 // optimization that makes it impossible to deoptimize.
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000843 bool IsAsyncDeoptimizeable(uintptr_t code) const REQUIRES_SHARED(Locks::mutator_lock_);
Mingyao Yangf711f2c2016-05-23 12:29:39 -0700844
David Sehrd106d9f2016-08-16 19:22:57 -0700845 // Returns a saved copy of the environment (getenv/setenv values).
846 // Used by Fork to protect against overwriting LD_LIBRARY_PATH, etc.
847 char** GetEnvSnapshot() const {
848 return env_snapshot_.GetSnapshot();
849 }
850
Andreas Gampefda57142016-09-08 20:29:18 -0700851 void AddSystemWeakHolder(gc::AbstractSystemWeakHolder* holder);
852 void RemoveSystemWeakHolder(gc::AbstractSystemWeakHolder* holder);
853
Alex Lightf889c702018-02-23 15:25:45 -0800854 void AttachAgent(JNIEnv* env, const std::string& agent_arg, jobject class_loader);
Leonard Mosescueb842212016-10-06 17:26:36 -0700855
Andreas Gampeaadcbc62017-12-28 14:05:42 -0800856 const std::list<std::unique_ptr<ti::Agent>>& GetAgents() const {
Alex Light65af20b2017-04-20 09:15:08 -0700857 return agents_;
858 }
859
Andreas Gampeac30fa22017-01-18 21:02:36 -0800860 RuntimeCallbacks* GetRuntimeCallbacks();
Andreas Gampe04bbb5b2017-01-19 17:49:03 +0000861
Alex Light77fee872017-09-05 14:51:49 -0700862 bool HasLoadedPlugins() const {
863 return !plugins_.empty();
864 }
865
Andreas Gampebad529d2017-02-13 18:52:10 -0800866 void InitThreadGroups(Thread* self);
867
Mathieu Chartier1d495012017-04-11 17:50:00 -0700868 void SetDumpGCPerformanceOnShutdown(bool value) {
869 dump_gc_performance_on_shutdown_ = value;
870 }
871
Lokesh Gidra10d0c962019-03-07 22:40:36 +0000872 bool GetDumpGCPerformanceOnShutdown() const {
873 return dump_gc_performance_on_shutdown_;
874 }
875
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +0100876 void IncrementDeoptimizationCount(DeoptimizationKind kind) {
877 DCHECK_LE(kind, DeoptimizationKind::kLast);
878 deoptimization_counts_[static_cast<size_t>(kind)]++;
879 }
880
Nicolas Geoffrayb9bec2e2017-05-24 15:59:18 +0100881 uint32_t GetNumberOfDeoptimizations() const {
882 uint32_t result = 0;
883 for (size_t i = 0; i <= static_cast<size_t>(DeoptimizationKind::kLast); ++i) {
884 result += deoptimization_counts_[i];
885 }
886 return result;
887 }
888
Mathieu Chartierc42cb0e2017-10-13 11:35:00 -0700889 // Whether or not we use MADV_RANDOM on files that are thought to have random access patterns.
890 // This is beneficial for low RAM devices since it reduces page cache thrashing.
891 bool MAdviseRandomAccess() const {
892 return madvise_random_access_;
893 }
894
Jagadeesh Pakaravoor06541532021-02-22 21:19:09 -0800895 size_t GetMadviseWillNeedSizeVdex() const {
896 return madvise_willneed_vdex_filesize_;
897 }
898
899 size_t GetMadviseWillNeedSizeOdex() const {
900 return madvise_willneed_odex_filesize_;
901 }
902
903 size_t GetMadviseWillNeedSizeArt() const {
904 return madvise_willneed_art_filesize_;
905 }
906
Alex Light40320712017-12-14 11:52:04 -0800907 const std::string& GetJdwpOptions() {
908 return jdwp_options_;
909 }
910
911 JdwpProvider GetJdwpProvider() const {
912 return jdwp_provider_;
913 }
914
Alex Lightf3677472019-06-26 16:31:53 -0700915 JniIdType GetJniIdType() const {
916 return jni_ids_indirection_;
Alex Light79d6c802019-06-27 15:50:11 +0000917 }
918
Alex Lightf3677472019-06-26 16:31:53 -0700919 bool CanSetJniIdType() const {
920 return GetJniIdType() == JniIdType::kSwapablePointer;
921 }
922
923 // Changes the JniIdType to the given type. Only allowed if CanSetJniIdType(). All threads must be
924 // suspended to call this function.
925 void SetJniIdType(JniIdType t);
926
Andreas Gampe0b0ffc12018-08-01 14:41:27 -0700927 uint32_t GetVerifierLoggingThresholdMs() const {
928 return verifier_logging_threshold_ms_;
929 }
930
Mathieu Chartierada33d72018-12-17 13:17:30 -0800931 // Atomically delete the thread pool if the reference count is 0.
932 bool DeleteThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
933
934 // Wait for all the thread workers to be attached.
935 void WaitForThreadPoolWorkersToStart() REQUIRES(!Locks::runtime_thread_pool_lock_);
936
937 // Scoped usage of the runtime thread pool. Prevents the pool from being
938 // deleted. Note that the thread pool is only for startup and gets deleted after.
939 class ScopedThreadPoolUsage {
940 public:
941 ScopedThreadPoolUsage();
942 ~ScopedThreadPoolUsage();
943
944 // Return the thread pool.
945 ThreadPool* GetThreadPool() const {
946 return thread_pool_;
947 }
948
949 private:
950 ThreadPool* const thread_pool_;
951 };
952
Mathieu Chartiera88abfa2019-02-04 11:08:29 -0800953 bool LoadAppImageStartupCache() const {
954 return load_app_image_startup_cache_;
955 }
956
957 void SetLoadAppImageStartupCacheEnabled(bool enabled) {
958 load_app_image_startup_cache_ = enabled;
959 }
960
Mathieu Chartier03625442019-06-24 17:29:23 -0700961 // Reset the startup completed status so that we can call NotifyStartupCompleted again. Should
962 // only be used for testing.
963 void ResetStartupCompleted();
964
Mathieu Chartier175ce3d2019-03-06 16:54:24 -0800965 // Notify the runtime that application startup is considered completed. Only has effect for the
966 // first call.
967 void NotifyStartupCompleted();
968
969 // Return true if startup is already completed.
970 bool GetStartupCompleted() const;
971
Andreas Gamped84794d2019-07-18 13:40:03 -0700972 bool IsVerifierMissingKThrowFatal() const {
973 return verifier_missing_kthrow_fatal_;
974 }
975
Florian Mayer0972d082020-05-15 14:07:31 +0200976 bool IsPerfettoHprofEnabled() const {
977 return perfetto_hprof_enabled_;
978 }
979
Wessam Hassaneinb5a10be2020-11-11 16:42:52 -0800980 bool IsPerfettoJavaHeapStackProfEnabled() const {
981 return perfetto_javaheapprof_enabled_;
982 }
983
wangguibo0d290722021-04-24 11:27:06 +0800984 bool IsMonitorTimeoutEnabled() const {
985 return monitor_timeout_enable_;
986 }
987
988 uint64_t GetMonitorTimeoutNs() const {
989 return monitor_timeout_ns_;
990 }
Mathieu Chartierccc75192019-10-28 13:34:03 -0700991 // Return true if we should load oat files as executable or not.
992 bool GetOatFilesExecutable() const;
993
Eric Holka79872b2020-10-01 13:09:53 -0700994 metrics::ArtMetrics* GetMetrics() { return &metrics_; }
995
Eric Holk5e435b22021-02-23 17:24:47 -0800996 void RequestMetricsReport(bool synchronous = true);
997
Jagadeesh Pakaravoor06541532021-02-22 21:19:09 -0800998 static void MadviseFileForRange(size_t madvise_size_limit_bytes,
999 size_t map_size_bytes,
1000 const uint8_t* map_begin,
1001 const uint8_t* map_end,
1002 const std::string& file_name);
1003
Nicolas Geoffrayd3c45c22021-04-27 13:21:28 +01001004 const std::string& GetApexVersions() const {
1005 return apex_versions_;
1006 }
1007
Calin Juravle09eacd92021-05-19 17:03:55 -07001008 // Trigger a flag reload from system properties or device congfigs.
1009 //
1010 // Should only be called from runtime init and zygote post fork as
1011 // we don't want to change the runtime config midway during execution.
1012 //
1013 // The caller argument should be the name of the function making this call
1014 // and will be used to enforce the appropriate names.
1015 //
1016 // See Flags::ReloadAllFlags as well.
1017 static void ReloadAllFlags(const std::string& caller);
1018
Carl Shapirob5573532011-07-12 18:22:59 -07001019 private:
Elliott Hughes457005c2012-04-16 13:54:25 -07001020 static void InitPlatformSignalHandlers();
Elliott Hughesffe67362011-07-17 12:09:27 -07001021
Elliott Hughesdcc24742011-09-07 14:02:44 -07001022 Runtime();
Carl Shapiro61e019d2011-07-14 16:53:09 -07001023
Elliott Hughesc1674ed2011-08-25 18:09:09 -07001024 void BlockSignals();
1025
Vladimir Marko88b2b802015-12-04 14:19:04 +00001026 bool Init(RuntimeArgumentMap&& runtime_options)
Ian Rogersb726dcb2012-09-05 08:57:23 -07001027 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
Mathieu Chartier90443472015-07-16 20:32:27 -07001028 void InitNativeMethods() REQUIRES(!Locks::mutator_lock_);
Elliott Hughesff17f1f2012-01-24 18:12:29 -08001029 void RegisterRuntimeNativeMethods(JNIEnv* env);
Eric Holkdf69bd72021-02-23 11:36:21 -08001030 void InitMetrics(const RuntimeArgumentMap& runtime_options);
Elliott Hughesd1cc8362011-10-24 16:58:50 -07001031
Elliott Hughes85d15452011-09-16 17:33:01 -07001032 void StartDaemonThreads();
Elliott Hughesd1cc8362011-10-24 16:58:50 -07001033 void StartSignalCatcher();
Carl Shapiro61e019d2011-07-14 16:53:09 -07001034
Calin Juravle31f2c152015-10-23 17:56:15 +01001035 void MaybeSaveJitProfilingInfo();
1036
Andreas Gampe585da952016-12-02 14:52:29 -08001037 // Visit all of the thread roots.
1038 void VisitThreadRoots(RootVisitor* visitor, VisitRootFlags flags)
1039 REQUIRES_SHARED(Locks::mutator_lock_);
1040
1041 // Visit all other roots which must be done with mutators suspended.
1042 void VisitNonConcurrentRoots(RootVisitor* visitor, VisitRootFlags flags)
1043 REQUIRES_SHARED(Locks::mutator_lock_);
1044
1045 // Constant roots are the roots which never change after the runtime is initialized, they only
1046 // need to be visited once per GC cycle.
1047 void VisitConstantRoots(RootVisitor* visitor)
1048 REQUIRES_SHARED(Locks::mutator_lock_);
1049
Andreas Gampe44f67602018-11-28 08:27:27 -08001050 // Note: To be lock-free, GetFaultMessage temporarily replaces the lock message with null.
1051 // As such, there is a window where a call will return an empty string. In general,
1052 // only aborting code should retrieve this data (via GetFaultMessageForAbortLogging
1053 // friend).
1054 std::string GetFaultMessage();
1055
Mathieu Chartierada33d72018-12-17 13:17:30 -08001056 ThreadPool* AcquireThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
1057 void ReleaseThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
1058
Nicolas Geoffrayd3c45c22021-04-27 13:21:28 +01001059 // Parses /apex/apex-info-list.xml to initialize a string containing versions
1060 // of boot classpath jars and encoded into .oat files.
1061 void InitializeApexVersions();
1062
Mathieu Chartier2cebb242015-04-21 16:50:40 -07001063 // A pointer to the active runtime or null.
Elliott Hughesb3bd5f02012-03-08 21:05:27 -08001064 static Runtime* instance_;
1065
Ian Rogers8afeb852014-04-02 14:55:49 -07001066 // NOTE: these must match the gc::ProcessState values as they come directly from the framework.
1067 static constexpr int kProfileForground = 0;
Calin Juravle31f2c152015-10-23 17:56:15 +01001068 static constexpr int kProfileBackground = 1;
Ian Rogers8afeb852014-04-02 14:55:49 -07001069
Mingyao Yang0a87a652017-04-12 13:43:15 -07001070 static constexpr uint32_t kCalleeSaveSize = 6u;
Andreas Gampe8228cdf2017-05-30 15:03:54 -07001071
Mathieu Chartiere401d142015-04-22 13:56:20 -07001072 // 64 bit so that we can share the same asm offsets for both 32 and 64 bits.
Andreas Gampe8228cdf2017-05-30 15:03:54 -07001073 uint64_t callee_save_methods_[kCalleeSaveSize];
Roland Levillain7b0e8442018-04-11 18:27:47 +01001074 // Pre-allocated exceptions (see Runtime::Init).
1075 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_throwing_exception_;
1076 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_throwing_oome_;
1077 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_handling_stack_overflow_;
Ian Rogers63557452014-06-04 16:57:15 -07001078 GcRoot<mirror::Throwable> pre_allocated_NoClassDefFoundError_;
Mathieu Chartiere401d142015-04-22 13:56:20 -07001079 ArtMethod* resolution_method_;
1080 ArtMethod* imt_conflict_method_;
Mathieu Chartier2d2621a2014-10-23 16:48:06 -07001081 // Unresolved method has the same behavior as the conflict method, it is used by the class linker
1082 // for differentiating between unfilled imt slots vs conflict slots in superclasses.
Mathieu Chartiere401d142015-04-22 13:56:20 -07001083 ArtMethod* imt_unimplemented_method_;
Ian Rogers6ed19fd2014-03-20 08:10:17 -07001084
Ian Rogersc0542af2014-09-03 16:16:56 -07001085 // Special sentinel object used to invalid conditions in JNI (cleared weak references) and
1086 // JDWP (invalid references).
1087 GcRoot<mirror::Object> sentinel_;
1088
Vladimir Marko7624d252014-05-02 14:40:15 +01001089 InstructionSet instruction_set_;
Vladimir Marko7624d252014-05-02 14:40:15 +01001090
Vladimir Marko2b5eaa22013-12-13 13:59:30 +00001091 CompilerCallbacks* compiler_callbacks_;
Elliott Hughes9ca7a1f2011-10-11 14:29:52 -07001092 bool is_zygote_;
Nicolas Geoffray4444f1b2019-06-10 14:09:19 +01001093 bool is_primary_zygote_;
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +01001094 bool is_system_server_;
Alex Lighta59dd802014-07-02 16:28:08 -07001095 bool must_relocate_;
Mathieu Chartier069387a2012-06-18 12:01:01 -07001096 bool is_concurrent_gc_enabled_;
Anwar Ghuloum87183592013-08-14 12:12:19 -07001097 bool is_explicit_gc_disabled_;
Alex Light64ad14d2014-08-19 14:23:13 -07001098 bool image_dex2oat_enabled_;
Brian Carlstrom0a5b14d2011-09-27 13:29:15 -07001099
Tsu Chiang Chuang12e6d742014-05-22 10:22:25 -07001100 std::string compiler_executable_;
Brian Carlstrom6449c622014-02-10 23:48:36 -08001101 std::vector<std::string> compiler_options_;
1102 std::vector<std::string> image_compiler_options_;
Victor Hsieh61ffd042021-05-20 15:14:25 -07001103 std::vector<std::string> image_locations_;
Dragos Sbirlea7467ee02013-06-21 09:20:34 -07001104
Vladimir Markod1908512018-11-22 14:57:28 +00001105 std::vector<std::string> boot_class_path_;
1106 std::vector<std::string> boot_class_path_locations_;
Brian Carlstroma004aa92012-02-08 18:05:09 -08001107 std::string class_path_string_;
Elliott Hughes7ede61e2011-09-14 18:18:06 -07001108 std::vector<std::string> properties_;
1109
Andreas Gampeaadcbc62017-12-28 14:05:42 -08001110 std::list<ti::AgentSpec> agent_specs_;
1111 std::list<std::unique_ptr<ti::Agent>> agents_;
Alex Light185d1342016-08-11 10:48:03 -07001112 std::vector<Plugin> plugins_;
Alex Light7233c7e2016-07-28 10:07:45 -07001113
Brian Carlstromb765be02011-08-17 23:54:10 -07001114 // The default stack size for managed threads created by the runtime.
Elliott Hughesbe759c62011-09-08 19:38:21 -07001115 size_t default_stack_size_;
Brian Carlstromb765be02011-08-17 23:54:10 -07001116
Hans Boehmb2155572019-03-27 14:25:53 -07001117 // Finalizers running for longer than this many milliseconds abort the runtime.
1118 unsigned int finalizer_timeout_ms_;
1119
Ian Rogers1d54e732013-05-02 21:10:01 -07001120 gc::Heap* heap_;
Elliott Hughesb3bd5f02012-03-08 21:05:27 -08001121
Nicolas Geoffray25e04562016-03-01 13:17:58 +00001122 std::unique_ptr<ArenaPool> jit_arena_pool_;
Mathieu Chartier9b34b242015-03-09 11:30:17 -07001123 std::unique_ptr<ArenaPool> arena_pool_;
Mathieu Chartierc7853442015-03-27 14:35:38 -07001124 // Special low 4gb pool for compiler linear alloc. We need ArtFields to be in low 4gb if we are
1125 // compiling using a 32 bit image on a 64 bit compiler in case we resolve things in the image
1126 // since the field arrays are int arrays in this case.
1127 std::unique_ptr<ArenaPool> low_4gb_arena_pool_;
1128
1129 // Shared linear alloc for now.
1130 std::unique_ptr<LinearAlloc> linear_alloc_;
Mathieu Chartier9b34b242015-03-09 11:30:17 -07001131
Ian Rogersd9c4fc92013-10-01 19:45:43 -07001132 // The number of spins that are done before thread suspension is used to forcibly inflate.
1133 size_t max_spins_before_thin_lock_inflation_;
Elliott Hughesc33a32b2011-10-11 18:18:07 -07001134 MonitorList* monitor_list_;
Ian Rogersef7d42f2014-01-06 12:55:46 -08001135 MonitorPool* monitor_pool_;
Elliott Hughesc33a32b2011-10-11 18:18:07 -07001136
Carl Shapirob5573532011-07-12 18:22:59 -07001137 ThreadList* thread_list_;
Carl Shapiro61e019d2011-07-14 16:53:09 -07001138
Elliott Hughescf4c6c42011-09-01 15:16:42 -07001139 InternTable* intern_table_;
1140
Brian Carlstromb0460ea2011-07-29 10:08:05 -07001141 ClassLinker* class_linker_;
1142
Elliott Hughese27955c2011-08-26 15:21:24 -07001143 SignalCatcher* signal_catcher_;
Narayan Kamatheb710332017-05-10 11:48:46 +01001144
Alex Light79d6c802019-06-27 15:50:11 +00001145 std::unique_ptr<jni::JniIdManager> jni_id_manager_;
1146
Richard Uhlerda0a69e2016-10-11 15:06:38 +01001147 std::unique_ptr<JavaVMExt> java_vm_;
Elliott Hughesf2682d52011-08-15 16:37:04 -07001148
Mathieu Chartiere5f13e52015-02-24 09:37:21 -08001149 std::unique_ptr<jit::Jit> jit_;
Orion Hodsonad28f5e2018-10-17 09:08:17 +01001150 std::unique_ptr<jit::JitCodeCache> jit_code_cache_;
Mathieu Chartiere5f13e52015-02-24 09:37:21 -08001151 std::unique_ptr<jit::JitOptions> jit_options_;
1152
Mathieu Chartierada33d72018-12-17 13:17:30 -08001153 // Runtime thread pool. The pool is only for startup and gets deleted after.
1154 std::unique_ptr<ThreadPool> thread_pool_ GUARDED_BY(Locks::runtime_thread_pool_lock_);
1155 size_t thread_pool_ref_count_ GUARDED_BY(Locks::runtime_thread_pool_lock_);
1156
Andreas Gampe44f67602018-11-28 08:27:27 -08001157 // Fault message, printed when we get a SIGSEGV. Stored as a native-heap object and accessed
1158 // lock-free, so needs to be atomic.
1159 std::atomic<std::string*> fault_message_;
Mathieu Chartier15d34022014-02-26 17:16:38 -08001160
Ian Rogers120f1c72012-09-28 17:17:10 -07001161 // A non-zero value indicates that a thread has been created but not yet initialized. Guarded by
1162 // the shutdown lock so that threads aren't born while we're shutting down.
1163 size_t threads_being_born_ GUARDED_BY(Locks::runtime_shutdown_lock_);
1164
1165 // Waited upon until no threads are being born.
Ian Rogers700a4022014-05-19 16:49:03 -07001166 std::unique_ptr<ConditionVariable> shutdown_cond_ GUARDED_BY(Locks::runtime_shutdown_lock_);
Ian Rogers120f1c72012-09-28 17:17:10 -07001167
1168 // Set when runtime shutdown is past the point that new threads may attach.
1169 bool shutting_down_ GUARDED_BY(Locks::runtime_shutdown_lock_);
1170
1171 // The runtime is starting to shutdown but is blocked waiting on shutdown_cond_.
1172 bool shutting_down_started_ GUARDED_BY(Locks::runtime_shutdown_lock_);
1173
Elliott Hughesdcc24742011-09-07 14:02:44 -07001174 bool started_;
1175
Mathieu Chartier7664f5c2012-06-08 18:15:32 -07001176 // New flag added which tells us if the runtime has finished starting. If
1177 // this flag is set then the Daemon threads are created and the class loader
1178 // is created. This flag is needed for knowing if its safe to request CMS.
1179 bool finished_starting_;
1180
Brian Carlstrom6ea095a2011-08-16 15:26:54 -07001181 // Hooks supported by JNI_CreateJavaVM
1182 jint (*vfprintf_)(FILE* stream, const char* format, va_list ap);
1183 void (*exit_)(jint status);
1184 void (*abort_)();
1185
Elliott Hughes9d5ccec2011-09-19 13:19:50 -07001186 bool stats_enabled_;
1187 RuntimeStats stats_;
1188
Evgenii Stepanov1e133742015-05-20 12:30:59 -07001189 const bool is_running_on_memory_tool_;
Mathieu Chartierda44d772014-04-01 15:01:46 -07001190
Andreas Gampef6a780a2015-04-02 18:51:05 -07001191 std::unique_ptr<TraceConfig> trace_config_;
1192
Ian Rogers62d6c772013-02-27 08:32:07 -08001193 instrumentation::Instrumentation instrumentation_;
jeffhao2692b572011-12-16 15:42:28 -08001194
Ian Rogers365c1022012-06-22 15:05:28 -07001195 jobject main_thread_group_;
1196 jobject system_thread_group_;
1197
Brian Carlstromce888532013-10-10 00:32:58 -07001198 // As returned by ClassLoader.getSystemClassLoader().
1199 jobject system_class_loader_;
1200
Hiroshi Yamauchi2e899a92013-11-22 16:50:12 -08001201 // If true, then we dump the GC cumulative timings on shutdown.
1202 bool dump_gc_performance_on_shutdown_;
1203
Chang Xing605fe242017-07-20 15:57:21 -07001204 // Transactions used for pre-initializing classes at compilation time.
1205 // Support nested transactions, maintain a list containing all transactions. Transactions are
1206 // handled under a stack discipline. Because GC needs to go over all transactions, we choose list
1207 // as substantial data structure instead of stack.
1208 std::list<std::unique_ptr<Transaction>> preinitialization_transactions_;
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +01001209
Igor Murashkin7617abd2015-07-10 18:27:47 -07001210 // If kNone, verification is disabled. kEnable by default.
1211 verifier::VerifyMode verify_;
Jeff Hao4a200f52014-04-01 14:58:49 -07001212
Dmitriy Ivanov785049f2014-07-18 10:08:57 -07001213 // List of supported cpu abis.
1214 std::vector<std::string> cpu_abilist_;
1215
Jeff Haof00571c2014-05-29 17:29:47 -07001216 // Specifies target SDK version to allow workarounds for certain API levels.
David Brazdil2bb2fbd2018-11-13 18:24:26 +00001217 uint32_t target_sdk_version_;
Jeff Haof00571c2014-05-29 17:29:47 -07001218
Andrei Onea037d2822020-11-19 00:20:04 +00001219 // ART counterpart for the compat framework (go/compat-framework).
1220 CompatFramework compat_framework_;
atrostfab72082019-12-06 13:37:36 +00001221
Dave Allison69dfe512014-07-11 17:11:58 +00001222 // Implicit checks flags.
1223 bool implicit_null_checks_; // NullPointer checks are implicit.
1224 bool implicit_so_checks_; // StackOverflow checks are implicit.
1225 bool implicit_suspend_checks_; // Thread suspension checks are implicit.
1226
Calin Juravle01aaf6e2015-06-19 22:05:39 +01001227 // Whether or not the sig chain (and implicitly the fault handler) should be
Vladimir Markoa497a392018-09-26 10:52:50 +01001228 // disabled. Tools like dex2oat don't need them. This enables
Calin Juravle01aaf6e2015-06-19 22:05:39 +01001229 // building a statically link version of dex2oat.
1230 bool no_sig_chain_;
1231
Calin Juravled3e7c6c2016-02-04 19:07:51 +00001232 // Force the use of native bridge even if the app ISA matches the runtime ISA.
1233 bool force_native_bridge_;
1234
Calin Juravle07d83c72014-10-22 21:02:23 +01001235 // Whether or not a native bridge has been loaded.
Calin Juravlec8423522014-08-12 20:55:20 +01001236 //
1237 // The native bridge allows running native code compiled for a foreign ISA. The way it works is,
1238 // if standard dlopen fails to load native library associated with native activity, it calls to
1239 // the native bridge to load it and then gets the trampoline for the entry to native activity.
Calin Juravle07d83c72014-10-22 21:02:23 +01001240 //
1241 // The option 'native_bridge_library_filename' specifies the name of the native bridge.
1242 // When non-empty the native bridge will be loaded from the given file. An empty value means
1243 // that there's no native bridge.
1244 bool is_native_bridge_loaded_;
Calin Juravlec8423522014-08-12 20:55:20 +01001245
David Srbeckyf4480162016-03-16 00:06:24 +00001246 // Whether we are running under native debugger.
1247 bool is_native_debuggable_;
1248
Alex Light7919db92017-11-29 09:00:55 -08001249 // whether or not any async exceptions have ever been thrown. This is used to speed up the
1250 // MterpShouldSwitchInterpreters function.
1251 bool async_exceptions_thrown_;
1252
Alex Light0aa7a5a2018-10-10 15:58:14 +00001253 // Whether anything is going to be using the shadow-frame APIs to force a function to return
1254 // early. Doing this requires that (1) we be debuggable and (2) that mterp is exited.
1255 bool non_standard_exits_enabled_;
1256
Nicolas Geoffray433b79a2017-01-30 20:54:45 +00001257 // Whether Java code needs to be debuggable.
1258 bool is_java_debuggable_;
Alex Light6b16d892016-11-11 11:21:04 -08001259
wangguibo0d290722021-04-24 11:27:06 +08001260 bool monitor_timeout_enable_;
1261 uint64_t monitor_timeout_ns_;
1262
Florian Mayer0bc9bef2021-04-28 15:52:33 +01001263 // Whether or not this application can be profiled by the shell user,
1264 // even when running on a device that is running in user mode.
Florian Mayer07710c52019-09-16 15:53:38 +00001265 bool is_profileable_from_shell_ = false;
1266
Florian Mayer0bc9bef2021-04-28 15:52:33 +01001267 // Whether or not this application can be profiled by system services on a
1268 // device running in user mode, but not necessarily by the shell user.
1269 bool is_profileable_ = false;
1270
Narayan Kamath5a2be3f2015-02-16 13:51:51 +00001271 // The maximum number of failed boots we allow before pruning the dalvik cache
1272 // and trying again. This option is only inspected when we're running as a
1273 // zygote.
1274 uint32_t zygote_max_failed_boots_;
1275
Igor Murashkin158f35c2015-06-10 15:55:30 -07001276 // Enable experimental opcodes that aren't fully specified yet. The intent is to
1277 // eventually publish them as public-usable opcodes, but they aren't ready yet.
1278 //
1279 // Experimental opcodes should not be used by other production code.
Alex Lighteb7c1442015-08-31 13:17:42 -07001280 ExperimentalFlags experimental_flags_;
Igor Murashkin158f35c2015-06-10 15:55:30 -07001281
Andreas Gampedd671252015-07-23 14:37:18 -07001282 // Contains the build fingerprint, if given as a parameter.
1283 std::string fingerprint_;
1284
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -07001285 // Oat file manager, keeps track of what oat files are open.
Mathieu Chartiere58991b2015-10-13 07:59:34 -07001286 OatFileManager* oat_file_manager_;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -07001287
Mathieu Chartier32cc9ee2015-10-15 09:19:15 -07001288 // Whether or not we are on a low RAM device.
1289 bool is_low_memory_mode_;
1290
Mathieu Chartierc42cb0e2017-10-13 11:35:00 -07001291 // Whether or not we use MADV_RANDOM on files that are thought to have random access patterns.
1292 // This is beneficial for low RAM devices since it reduces page cache thrashing.
1293 bool madvise_random_access_;
1294
Jagadeesh Pakaravoor06541532021-02-22 21:19:09 -08001295 // Limiting size (in bytes) for applying MADV_WILLNEED on vdex files
1296 // A 0 for this will turn off madvising to MADV_WILLNEED
1297 size_t madvise_willneed_vdex_filesize_;
1298
1299 // Limiting size (in bytes) for applying MADV_WILLNEED on odex files
1300 // A 0 for this will turn off madvising to MADV_WILLNEED
1301 size_t madvise_willneed_odex_filesize_;
1302
1303 // Limiting size (in bytes) for applying MADV_WILLNEED on art files
1304 // A 0 for this will turn off madvising to MADV_WILLNEED
1305 size_t madvise_willneed_art_filesize_;
1306
Nicolas Geoffray787ae8e2015-11-05 11:32:24 +00001307 // Whether the application should run in safe mode, that is, interpreter only.
1308 bool safe_mode_;
1309
David Brazdil3e0fa0a2018-01-15 18:41:44 +00001310 // Whether access checks on hidden API should be performed.
Mathew Inwooda5dc52c2018-02-19 15:30:51 +00001311 hiddenapi::EnforcementPolicy hidden_api_policy_;
David Brazdil3e0fa0a2018-01-15 18:41:44 +00001312
David Brazdile7681822018-12-14 16:25:33 +00001313 // Whether access checks on core platform API should be performed.
1314 hiddenapi::EnforcementPolicy core_platform_api_policy_;
1315
satayev09efc162021-02-22 17:24:57 +00001316 // Whether access checks on test API should be performed.
1317 hiddenapi::EnforcementPolicy test_api_policy_;
1318
Mathew Inwoodc8ce5f52018-04-05 13:58:55 +01001319 // List of signature prefixes of methods that have been removed from the blacklist, and treated
1320 // as if whitelisted.
Mathew Inwood3383aa52018-03-16 14:18:33 +00001321 std::vector<std::string> hidden_api_exemptions_;
1322
David Brazdilee7d2fd2018-01-20 17:25:23 +00001323 // Do not warn about the same hidden API access violation twice.
1324 // This is only used for testing.
1325 bool dedupe_hidden_api_warnings_;
1326
Mathew Inwood5bcef172018-05-01 14:40:12 +01001327 // How often to log hidden API access to the event log. An integer between 0
1328 // (never) and 0x10000 (always).
Mathew Inwood73ddda42018-04-03 15:32:32 +01001329 uint32_t hidden_api_access_event_log_rate_;
1330
Mathew Inwood5bcef172018-05-01 14:40:12 +01001331 // The package of the app running in this process.
1332 std::string process_package_name_;
1333
David Brazdil35a3f6a2019-03-04 15:59:06 +00001334 // The data directory of the app running in this process.
1335 std::string process_data_directory_;
1336
Nicolas Geoffraya73280d2016-02-15 13:05:16 +00001337 // Whether threads should dump their native stack on SIGQUIT.
1338 bool dump_native_stack_on_sig_quit_;
1339
Mathieu Chartierf8cb1782016-03-18 18:45:41 -07001340 // Whether or not we currently care about pause times.
1341 ProcessState process_state_;
1342
Andreas Gampef38a6612016-04-11 08:42:26 -07001343 // Whether zygote code is in a section that should not start threads.
1344 bool zygote_no_threads_;
1345
Alex Light40320712017-12-14 11:52:04 -08001346 // The string containing requested jdwp options
1347 std::string jdwp_options_;
1348
1349 // The jdwp provider we were configured with.
1350 JdwpProvider jdwp_provider_;
1351
Alex Light79d6c802019-06-27 15:50:11 +00001352 // True if jmethodID and jfieldID are opaque Indices. When false (the default) these are simply
1353 // pointers. This is set by -Xopaque-jni-ids:{true,false}.
1354 JniIdType jni_ids_indirection_;
1355
Alex Light4ca2f482019-11-25 16:07:22 -08001356 // Set to false in cases where we want to directly control when jni-id
1357 // indirection is changed. This is intended only for testing JNI id swapping.
1358 bool automatically_set_jni_ids_indirection_;
1359
David Sehrd106d9f2016-08-16 19:22:57 -07001360 // Saved environment.
1361 class EnvSnapshot {
1362 public:
1363 EnvSnapshot() = default;
1364 void TakeSnapshot();
1365 char** GetSnapshot() const;
1366
1367 private:
1368 std::unique_ptr<char*[]> c_env_vector_;
1369 std::vector<std::unique_ptr<std::string>> name_value_pairs_;
1370
1371 DISALLOW_COPY_AND_ASSIGN(EnvSnapshot);
1372 } env_snapshot_;
1373
Andreas Gampefda57142016-09-08 20:29:18 -07001374 // Generic system-weak holders.
1375 std::vector<gc::AbstractSystemWeakHolder*> system_weak_holders_;
1376
Andreas Gampeac30fa22017-01-18 21:02:36 -08001377 std::unique_ptr<RuntimeCallbacks> callbacks_;
Andreas Gampe04bbb5b2017-01-19 17:49:03 +00001378
Nicolas Geoffray81cc43e2017-05-10 12:04:49 +01001379 std::atomic<uint32_t> deoptimization_counts_[
1380 static_cast<uint32_t>(DeoptimizationKind::kLast) + 1];
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +01001381
Vladimir Markoc34bebf2018-08-16 16:12:49 +01001382 MemMap protected_fault_page_;
Andreas Gampe2ac67d52017-05-11 22:30:38 -07001383
Andreas Gampe0b0ffc12018-08-01 14:41:27 -07001384 uint32_t verifier_logging_threshold_ms_;
1385
Mathieu Chartiera88abfa2019-02-04 11:08:29 -08001386 bool load_app_image_startup_cache_ = false;
1387
Mathieu Chartier175ce3d2019-03-06 16:54:24 -08001388 // If startup has completed, must happen at most once.
1389 std::atomic<bool> startup_completed_ = false;
1390
Andreas Gamped84794d2019-07-18 13:40:03 -07001391 bool verifier_missing_kthrow_fatal_;
Florian Mayer0972d082020-05-15 14:07:31 +02001392 bool perfetto_hprof_enabled_;
Wessam Hassaneinb5a10be2020-11-11 16:42:52 -08001393 bool perfetto_javaheapprof_enabled_;
Andreas Gamped84794d2019-07-18 13:40:03 -07001394
Eric Holka79872b2020-10-01 13:09:53 -07001395 metrics::ArtMetrics metrics_;
Eric Holk59d4b532020-10-21 17:49:39 -07001396 std::unique_ptr<metrics::MetricsReporter> metrics_reporter_;
Eric Holka79872b2020-10-01 13:09:53 -07001397
Nicolas Geoffrayd3c45c22021-04-27 13:21:28 +01001398 // Apex versions of boot classpath jars concatenated in a string. The format
1399 // is of the type:
1400 // '/apex1_version/apex2_version//'
1401 //
1402 // When the apex is the factory version, we don't encode it (for example in
1403 // the third entry in the example above).
1404 std::string apex_versions_;
1405
Andreas Gampe44f67602018-11-28 08:27:27 -08001406 // Note: See comments on GetFaultMessage.
1407 friend std::string GetFaultMessageForAbortLogging();
Vladimir Markoc0e0e5e2020-01-23 17:43:05 +00001408 friend class Dex2oatImageTest;
Mathieu Chartierada33d72018-12-17 13:17:30 -08001409 friend class ScopedThreadPoolUsage;
Vladimir Markof3d88a82018-12-21 16:38:47 +00001410 friend class OatFileAssistantTest;
Mathieu Chartierad390fa2019-10-16 20:03:00 -07001411 class NotifyStartupCompletedTask;
Andreas Gampe44f67602018-11-28 08:27:27 -08001412
Carl Shapiro61e019d2011-07-14 16:53:09 -07001413 DISALLOW_COPY_AND_ASSIGN(Runtime);
Carl Shapiro1fb86202011-06-27 17:43:13 -07001414};
1415
Eric Holka79872b2020-10-01 13:09:53 -07001416inline metrics::ArtMetrics* GetMetrics() { return Runtime::Current()->GetMetrics(); }
1417
Carl Shapiro1fb86202011-06-27 17:43:13 -07001418} // namespace art
1419
Brian Carlstromfc0e3212013-07-17 14:40:12 -07001420#endif // ART_RUNTIME_RUNTIME_H_