blob: 0b336c7345b12b5227b668a1e66313110dfc4e62 [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>
Hiroshi Yamauchi799eb3a2014-07-18 15:38:17 -070024#include <set>
Brian Carlstrom6ea095a2011-08-16 15:26:54 -070025#include <string>
Carl Shapirofc322c72011-07-27 00:20:01 -070026#include <utility>
Chang Xing16d1dd82017-07-20 17:56:26 -070027#include <memory>
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"
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +010033#include "deoptimization_kind.h"
David Sehr9e734c72018-01-04 17:56:19 -080034#include "dex/dex_file_types.h"
Alex Lighteb7c1442015-08-31 13:17:42 -070035#include "experimental_flags.h"
Andreas Gampe86823542019-02-25 09:38:49 -080036#include "gc/space/image_space_loading_order.h"
Hiroshi Yamauchi94f7b492014-07-22 18:08:23 -070037#include "gc_root.h"
Ian Rogers62d6c772013-02-27 08:32:07 -080038#include "instrumentation.h"
Alex Light40320712017-12-14 11:52:04 -080039#include "jdwp_provider.h"
Alex Light79d6c802019-06-27 15:50:11 +000040#include "jni/jni_id_manager.h"
41#include "jni_id_type.h"
Mathieu Chartier8778c522016-10-04 19:06:30 -070042#include "obj_ptr.h"
Ian Rogers576ca0c2014-06-06 15:58:22 -070043#include "offsets.h"
Mathieu Chartierf8cb1782016-03-18 18:45:41 -070044#include "process_state.h"
Vladimir Marko7624d252014-05-02 14:40:15 +010045#include "quick/quick_method_frame_info.h"
Alex Lightc18eba32019-09-24 14:36:27 -070046#include "reflective_value_visitor.h"
Elliott Hughes9d5ccec2011-09-19 13:19:50 -070047#include "runtime_stats.h"
Carl Shapirob5573532011-07-12 18:22:59 -070048
Carl Shapiro1fb86202011-06-27 17:43:13 -070049namespace art {
50
Ian Rogers1d54e732013-05-02 21:10:01 -070051namespace gc {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080052class AbstractSystemWeakHolder;
53class Heap;
Ian Rogers576ca0c2014-06-06 15:58:22 -070054} // namespace gc
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080055
Mathew Inwooda5dc52c2018-02-19 15:30:51 +000056namespace hiddenapi {
57enum class EnforcementPolicy;
58} // namespace hiddenapi
59
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080060namespace jit {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080061class Jit;
Orion Hodsonad28f5e2018-10-17 09:08:17 +010062class JitCodeCache;
Igor Murashkin2ffb7032017-11-08 13:35:21 -080063class JitOptions;
Mathieu Chartiere5f13e52015-02-24 09:37:21 -080064} // namespace jit
65
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080066namespace mirror {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080067class Array;
68class ClassLoader;
69class DexCache;
70template<class T> class ObjectArray;
71template<class T> class PrimitiveArray;
72typedef PrimitiveArray<int8_t> ByteArray;
73class String;
74class Throwable;
Ian Rogers2dd0e2c2013-01-24 12:42:14 -080075} // namespace mirror
Alex Light7233c7e2016-07-28 10:07:45 -070076namespace ti {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080077class Agent;
Andreas Gampeaadcbc62017-12-28 14:05:42 -080078class AgentSpec;
Alex Light7233c7e2016-07-28 10:07:45 -070079} // namespace ti
Mathieu Chartierc528dba2013-11-26 12:00:11 -080080namespace verifier {
Igor Murashkin2ffb7032017-11-08 13:35:21 -080081class MethodVerifier;
82enum class VerifyMode : int8_t;
Ian Rogers6a3c1fc2014-10-31 00:33:20 -070083} // namespace verifier
Mathieu Chartiere401d142015-04-22 13:56:20 -070084class ArenaPool;
85class ArtMethod;
Andreas Gampe8228cdf2017-05-30 15:03:54 -070086enum class CalleeSaveType: uint32_t;
Carl Shapiro61e019d2011-07-14 16:53:09 -070087class ClassLinker;
Mathieu Chartiere401d142015-04-22 13:56:20 -070088class CompilerCallbacks;
Carl Shapirofc322c72011-07-27 00:20:01 -070089class DexFile;
Andreas Gampe639b2b12019-01-08 10:32:50 -080090enum class InstructionSet;
Elliott Hughescf4c6c42011-09-01 15:16:42 -070091class InternTable;
Andreas Gamped482e732017-04-24 17:59:09 -070092class IsMarkedVisitor;
Ian Rogersb48b9eb2014-02-28 16:20:21 -080093class JavaVMExt;
Mathieu Chartiere401d142015-04-22 13:56:20 -070094class LinearAlloc;
Elliott Hughesc33a32b2011-10-11 18:18:07 -070095class MonitorList;
Ian Rogersef7d42f2014-01-06 12:55:46 -080096class MonitorPool;
Ian Rogers576ca0c2014-06-06 15:58:22 -070097class NullPointerHandler;
Vladimir Markof3d88a82018-12-21 16:38:47 +000098class OatFileAssistantTest;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -070099class OatFileManager;
Alex Light185d1342016-08-11 10:48:03 -0700100class Plugin;
Vladimir Marko88b2b802015-12-04 14:19:04 +0000101struct RuntimeArgumentMap;
Andreas Gampeac30fa22017-01-18 21:02:36 -0800102class RuntimeCallbacks;
Elliott Hughese27955c2011-08-26 15:21:24 -0700103class SignalCatcher;
Ian Rogers576ca0c2014-06-06 15:58:22 -0700104class StackOverflowHandler;
105class SuspensionHandler;
Carl Shapiro61e019d2011-07-14 16:53:09 -0700106class ThreadList;
Mathieu Chartierc6068c72018-11-13 16:00:58 -0800107class ThreadPool;
jeffhao2692b572011-12-16 15:42:28 -0800108class Trace;
Andreas Gampef6a780a2015-04-02 18:51:05 -0700109struct TraceConfig;
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100110class Transaction;
Carl Shapiro61e019d2011-07-14 16:53:09 -0700111
Ian Rogerse63db272014-07-15 15:36:11 -0700112typedef std::vector<std::pair<std::string, const void*>> RuntimeOptions;
113
Carl Shapiro1fb86202011-06-27 17:43:13 -0700114class Runtime {
115 public:
Vladimir Marko88b2b802015-12-04 14:19:04 +0000116 // Parse raw runtime options.
117 static bool ParseOptions(const RuntimeOptions& raw_options,
118 bool ignore_unrecognized,
119 RuntimeArgumentMap* runtime_options);
120
Carl Shapiro61e019d2011-07-14 16:53:09 -0700121 // Creates and initializes a new runtime.
Vladimir Marko88b2b802015-12-04 14:19:04 +0000122 static bool Create(RuntimeArgumentMap&& runtime_options)
123 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
124
125 // Creates and initializes a new runtime.
126 static bool Create(const RuntimeOptions& raw_options, bool ignore_unrecognized)
Ian Rogersb726dcb2012-09-05 08:57:23 -0700127 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
Brian Carlstrom69b15fb2011-09-03 12:25:21 -0700128
Florian Mayer07710c52019-09-16 15:53:38 +0000129 bool EnsurePluginLoaded(const char* plugin_name, std::string* error_msg);
130 bool EnsurePerfettoPlugin(std::string* error_msg);
131
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800132 // IsAotCompiler for compilers that don't have a running runtime. Only dex2oat currently.
133 bool IsAotCompiler() const {
Calin Juravleffc87072016-04-20 14:22:09 +0100134 return !UseJitCompilation() && IsCompiler();
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800135 }
136
137 // IsCompiler is any runtime which has a running compiler, either dex2oat or JIT.
Elliott Hughesd9c67be2012-02-02 19:54:06 -0800138 bool IsCompiler() const {
Vladimir Marko2b5eaa22013-12-13 13:59:30 +0000139 return compiler_callbacks_ != nullptr;
140 }
141
Andreas Gampe4585f872015-03-27 23:45:15 -0700142 // If a compiler, are we compiling a boot image?
143 bool IsCompilingBootImage() const;
144
145 bool CanRelocate() const;
Alex Lighta59dd802014-07-02 16:28:08 -0700146
147 bool ShouldRelocate() const {
148 return must_relocate_ && CanRelocate();
149 }
150
151 bool MustRelocateIfPossible() const {
152 return must_relocate_;
153 }
154
Alex Light64ad14d2014-08-19 14:23:13 -0700155 bool IsImageDex2OatEnabled() const {
156 return image_dex2oat_enabled_;
Nicolas Geoffray4fcdc942014-07-22 10:48:00 +0100157 }
158
Vladimir Marko2b5eaa22013-12-13 13:59:30 +0000159 CompilerCallbacks* GetCompilerCallbacks() {
160 return compiler_callbacks_;
Elliott Hughesd9c67be2012-02-02 19:54:06 -0800161 }
162
Mathieu Chartier07ddb6f2015-11-05 11:16:34 -0800163 void SetCompilerCallbacks(CompilerCallbacks* callbacks) {
164 CHECK(callbacks != nullptr);
165 compiler_callbacks_ = callbacks;
166 }
167
Brian Carlstromcaabb1b2011-10-11 18:09:13 -0700168 bool IsZygote() const {
169 return is_zygote_;
170 }
171
Nicolas Geoffray4444f1b2019-06-10 14:09:19 +0100172 bool IsPrimaryZygote() const {
173 return is_primary_zygote_;
174 }
175
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +0100176 bool IsSystemServer() const {
177 return is_system_server_;
178 }
179
Nicolas Geoffraya67daeb2019-08-12 10:41:25 +0100180 void SetAsSystemServer() {
181 is_system_server_ = true;
182 is_zygote_ = false;
183 is_primary_zygote_ = false;
184 }
185
186 void SetAsZygoteChild(bool is_system_server, bool is_zygote) {
187 // System server should have been set earlier in SetAsSystemServer.
188 CHECK_EQ(is_system_server_, is_system_server);
189 is_zygote_ = is_zygote;
190 is_primary_zygote_ = false;
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +0100191 }
192
Anwar Ghuloum87183592013-08-14 12:12:19 -0700193 bool IsExplicitGcDisabled() const {
194 return is_explicit_gc_disabled_;
195 }
196
Tsu Chiang Chuang12e6d742014-05-22 10:22:25 -0700197 std::string GetCompilerExecutable() const;
198
Brian Carlstrom6449c622014-02-10 23:48:36 -0800199 const std::vector<std::string>& GetCompilerOptions() const {
200 return compiler_options_;
Dragos Sbirlea7467ee02013-06-21 09:20:34 -0700201 }
202
Vladimir Marko5c657fe2016-11-03 15:12:29 +0000203 void AddCompilerOption(const std::string& option) {
Andreas Gamped2abbc92014-12-19 09:53:27 -0800204 compiler_options_.push_back(option);
205 }
206
Brian Carlstrom6449c622014-02-10 23:48:36 -0800207 const std::vector<std::string>& GetImageCompilerOptions() const {
208 return image_compiler_options_;
Anwar Ghuloum8447d842013-04-30 17:27:40 -0700209 }
210
Brian Carlstrom31d8f522014-09-29 11:22:54 -0700211 const std::string& GetImageLocation() const {
212 return image_location_;
213 }
214
David Srbecky3db3d372019-04-17 18:19:17 +0100215 bool IsUsingApexBootImageLocation() const {
216 return is_using_apex_boot_image_location_;
Nicolas Geoffray7417ce92019-02-01 10:52:42 +0000217 }
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
Mathieu Chartiere42888f2016-04-14 10:49:19 -0700438 void FixupConflictTables();
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,
514 NativeBridgeAction action,
515 const char* isa,
516 bool profile_system_server = false);
Brian Carlstromcaabb1b2011-10-11 18:09:13 -0700517
Ian Rogers9bc54402014-04-17 16:40:01 -0700518 const instrumentation::Instrumentation* GetInstrumentation() const {
519 return &instrumentation_;
520 }
521
Ian Rogers62d6c772013-02-27 08:32:07 -0800522 instrumentation::Instrumentation* GetInstrumentation() {
523 return &instrumentation_;
524 }
jeffhao2692b572011-12-16 15:42:28 -0800525
Calin Juravle66f55232015-12-08 15:09:10 +0000526 void RegisterAppInfo(const std::vector<std::string>& code_paths,
Calin Juravle77651c42017-03-03 18:04:02 -0800527 const std::string& profile_output_filename);
Dave Allison0aded082013-11-07 13:15:11 -0800528
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100529 // Transaction support.
Chang Xing605fe242017-07-20 15:57:21 -0700530 bool IsActiveTransaction() const;
Chang Xing5a906fc2017-07-26 15:01:16 -0700531 void EnterTransactionMode(bool strict, mirror::Class* root);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100532 void ExitTransactionMode();
Chang Xing605fe242017-07-20 15:57:21 -0700533 void RollbackAllTransactions() REQUIRES_SHARED(Locks::mutator_lock_);
Chang Xing16d1dd82017-07-20 17:56:26 -0700534 // Transaction rollback and exit transaction are always done together, it's convenience to
535 // do them in one function.
536 void RollbackAndExitTransactionMode() REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100537 bool IsTransactionAborted() const;
Chang Xing605fe242017-07-20 15:57:21 -0700538 const std::unique_ptr<Transaction>& GetTransaction() const;
Chang Xing5a906fc2017-07-26 15:01:16 -0700539 bool IsActiveStrictTransactionMode() const;
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100540
Sebastien Hertz2fd7e692015-04-02 11:11:19 +0200541 void AbortTransactionAndThrowAbortError(Thread* self, const std::string& abort_message)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700542 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz2fd7e692015-04-02 11:11:19 +0200543 void ThrowTransactionAbortError(Thread* self)
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700544 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertz1c80bec2015-02-03 11:58:06 +0100545
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700546 void RecordWriteFieldBoolean(mirror::Object* obj, MemberOffset field_offset, uint8_t value,
Fred Shih37f05ef2014-07-16 18:38:08 -0700547 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700548 void RecordWriteFieldByte(mirror::Object* obj, MemberOffset field_offset, int8_t value,
Fred Shih37f05ef2014-07-16 18:38:08 -0700549 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700550 void RecordWriteFieldChar(mirror::Object* obj, MemberOffset field_offset, uint16_t value,
Fred Shih37f05ef2014-07-16 18:38:08 -0700551 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700552 void RecordWriteFieldShort(mirror::Object* obj, MemberOffset field_offset, int16_t value,
Fred Shih37f05ef2014-07-16 18:38:08 -0700553 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700554 void RecordWriteField32(mirror::Object* obj, MemberOffset field_offset, uint32_t value,
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100555 bool is_volatile) const;
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700556 void RecordWriteField64(mirror::Object* obj, MemberOffset field_offset, uint64_t value,
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100557 bool is_volatile) const;
Mathieu Chartiera058fdf2016-10-06 15:13:58 -0700558 void RecordWriteFieldReference(mirror::Object* obj,
559 MemberOffset field_offset,
560 ObjPtr<mirror::Object> value,
561 bool is_volatile) const
562 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100563 void RecordWriteArray(mirror::Array* array, size_t index, uint64_t value) const
Andreas Gampebdf7f1c2016-08-30 16:38:47 -0700564 REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier9e868092016-10-31 14:58:04 -0700565 void RecordStrongStringInsertion(ObjPtr<mirror::String> s) const
Mathieu Chartier90443472015-07-16 20:32:27 -0700566 REQUIRES(Locks::intern_table_lock_);
Mathieu Chartier9e868092016-10-31 14:58:04 -0700567 void RecordWeakStringInsertion(ObjPtr<mirror::String> s) const
Mathieu Chartier90443472015-07-16 20:32:27 -0700568 REQUIRES(Locks::intern_table_lock_);
Mathieu Chartier9e868092016-10-31 14:58:04 -0700569 void RecordStrongStringRemoval(ObjPtr<mirror::String> s) const
Mathieu Chartier90443472015-07-16 20:32:27 -0700570 REQUIRES(Locks::intern_table_lock_);
Mathieu Chartier9e868092016-10-31 14:58:04 -0700571 void RecordWeakStringRemoval(ObjPtr<mirror::String> s) const
Mathieu Chartier90443472015-07-16 20:32:27 -0700572 REQUIRES(Locks::intern_table_lock_);
Andreas Gampe8a0128a2016-11-28 07:38:35 -0800573 void RecordResolveString(ObjPtr<mirror::DexCache> dex_cache, dex::StringIndex string_idx) const
Mathieu Chartierbb816d62016-09-07 10:17:46 -0700574 REQUIRES_SHARED(Locks::mutator_lock_);
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +0100575
Andreas Gampe44f67602018-11-28 08:27:27 -0800576 void SetFaultMessage(const std::string& message);
Mathieu Chartier15d34022014-02-26 17:16:38 -0800577
Igor Murashkinb1d8c312015-08-04 11:18:43 -0700578 void AddCurrentRuntimeFeaturesAsDex2OatArguments(std::vector<std::string>* arg_vector) const;
Ian Rogers8afeb852014-04-02 14:55:49 -0700579
Dave Allisonb373e092014-02-20 16:06:36 -0800580 bool ExplicitStackOverflowChecks() const {
Andreas Gampe928f72b2014-09-09 19:53:48 -0700581 return !implicit_so_checks_;
Dave Allisonb373e092014-02-20 16:06:36 -0800582 }
583
Nicolas Geoffray68bf3902017-09-07 14:40:48 +0100584 void DisableVerifier();
Igor Murashkin7617abd2015-07-10 18:27:47 -0700585 bool IsVerificationEnabled() const;
586 bool IsVerificationSoftFail() const;
Jeff Hao4a200f52014-04-01 14:58:49 -0700587
Mathew Inwooda5dc52c2018-02-19 15:30:51 +0000588 void SetHiddenApiEnforcementPolicy(hiddenapi::EnforcementPolicy policy) {
589 hidden_api_policy_ = policy;
David Brazdil3e0fa0a2018-01-15 18:41:44 +0000590 }
591
Mathew Inwooda5dc52c2018-02-19 15:30:51 +0000592 hiddenapi::EnforcementPolicy GetHiddenApiEnforcementPolicy() const {
593 return hidden_api_policy_;
David Brazdil3e0fa0a2018-01-15 18:41:44 +0000594 }
595
David Brazdile7681822018-12-14 16:25:33 +0000596 void SetCorePlatformApiEnforcementPolicy(hiddenapi::EnforcementPolicy policy) {
597 core_platform_api_policy_ = policy;
598 }
599
600 hiddenapi::EnforcementPolicy GetCorePlatformApiEnforcementPolicy() const {
601 return core_platform_api_policy_;
602 }
603
Mathew Inwood3383aa52018-03-16 14:18:33 +0000604 void SetHiddenApiExemptions(const std::vector<std::string>& exemptions) {
605 hidden_api_exemptions_ = exemptions;
606 }
607
608 const std::vector<std::string>& GetHiddenApiExemptions() {
609 return hidden_api_exemptions_;
610 }
611
David Brazdilee7d2fd2018-01-20 17:25:23 +0000612 void SetDedupeHiddenApiWarnings(bool value) {
613 dedupe_hidden_api_warnings_ = value;
614 }
615
616 bool ShouldDedupeHiddenApiWarnings() {
617 return dedupe_hidden_api_warnings_;
618 }
619
Mathew Inwood73ddda42018-04-03 15:32:32 +0100620 void SetHiddenApiEventLogSampleRate(uint32_t rate) {
621 hidden_api_access_event_log_rate_ = rate;
622 }
623
624 uint32_t GetHiddenApiEventLogSampleRate() const {
625 return hidden_api_access_event_log_rate_;
626 }
627
Mathew Inwood5bcef172018-05-01 14:40:12 +0100628 const std::string& GetProcessPackageName() const {
629 return process_package_name_;
630 }
631
632 void SetProcessPackageName(const char* package_name) {
633 if (package_name == nullptr) {
634 process_package_name_.clear();
635 } else {
636 process_package_name_ = package_name;
637 }
638 }
639
David Brazdil35a3f6a2019-03-04 15:59:06 +0000640 const std::string& GetProcessDataDirectory() const {
641 return process_data_directory_;
642 }
643
644 void SetProcessDataDirectory(const char* data_dir) {
645 if (data_dir == nullptr) {
646 process_data_directory_.clear();
647 } else {
648 process_data_directory_ = data_dir;
649 }
650 }
651
Jean Christophe Beyler24e04aa2014-09-12 12:03:25 -0700652 bool IsDexFileFallbackEnabled() const {
653 return allow_dex_file_fallback_;
654 }
655
Dmitriy Ivanov785049f2014-07-18 10:08:57 -0700656 const std::vector<std::string>& GetCpuAbilist() const {
657 return cpu_abilist_;
658 }
659
Evgenii Stepanov1e133742015-05-20 12:30:59 -0700660 bool IsRunningOnMemoryTool() const {
661 return is_running_on_memory_tool_;
Mathieu Chartierda44d772014-04-01 15:01:46 -0700662 }
663
David Brazdil2bb2fbd2018-11-13 18:24:26 +0000664 void SetTargetSdkVersion(uint32_t version) {
Jeff Haof00571c2014-05-29 17:29:47 -0700665 target_sdk_version_ = version;
666 }
667
David Brazdil2bb2fbd2018-11-13 18:24:26 +0000668 uint32_t GetTargetSdkVersion() const {
Jeff Haof00571c2014-05-29 17:29:47 -0700669 return target_sdk_version_;
670 }
671
Narayan Kamath5a2be3f2015-02-16 13:51:51 +0000672 uint32_t GetZygoteMaxFailedBoots() const {
673 return zygote_max_failed_boots_;
674 }
675
Alex Lighteb7c1442015-08-31 13:17:42 -0700676 bool AreExperimentalFlagsEnabled(ExperimentalFlags flags) {
677 return (experimental_flags_ & flags) != ExperimentalFlags::kNone;
Igor Murashkin158f35c2015-06-10 15:55:30 -0700678 }
679
Orion Hodsonad28f5e2018-10-17 09:08:17 +0100680 void CreateJitCodeCache(bool rwx_memory_allowed);
681
Mathieu Chartier455f67c2015-03-17 13:48:29 -0700682 // Create the JIT and instrumentation and code cache.
Mathieu Chartiere5f13e52015-02-24 09:37:21 -0800683 void CreateJit();
684
Mathieu Chartier9b34b242015-03-09 11:30:17 -0700685 ArenaPool* GetArenaPool() {
686 return arena_pool_.get();
687 }
Nicolas Geoffray25e04562016-03-01 13:17:58 +0000688 ArenaPool* GetJitArenaPool() {
689 return jit_arena_pool_.get();
690 }
Mathieu Chartier9b34b242015-03-09 11:30:17 -0700691 const ArenaPool* GetArenaPool() const {
692 return arena_pool_.get();
693 }
Jean-Philippe Halimica76a1a2016-02-02 19:48:52 +0100694
695 void ReclaimArenaPoolMemory();
696
Mathieu Chartierc7853442015-03-27 14:35:38 -0700697 LinearAlloc* GetLinearAlloc() {
698 return linear_alloc_.get();
699 }
Mathieu Chartier9b34b242015-03-09 11:30:17 -0700700
Mathieu Chartier455f67c2015-03-17 13:48:29 -0700701 jit::JitOptions* GetJITOptions() {
702 return jit_options_.get();
703 }
704
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000705 bool IsJavaDebuggable() const {
706 return is_java_debuggable_;
Alex Light6b16d892016-11-11 11:21:04 -0800707 }
708
Florian Mayer07710c52019-09-16 15:53:38 +0000709 void SetProfileableFromShell(bool value) {
710 is_profileable_from_shell_ = value;
711 }
712
713 bool IsProfileableFromShell() const {
714 return is_profileable_from_shell_;
715 }
716
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000717 void SetJavaDebuggable(bool value);
718
719 // Deoptimize the boot image, called for Java debuggable apps.
Nicolas Geoffray226805d2018-12-14 10:59:02 +0000720 void DeoptimizeBootImage() REQUIRES(Locks::mutator_lock_);
Alex Light6b16d892016-11-11 11:21:04 -0800721
David Srbeckyf4480162016-03-16 00:06:24 +0000722 bool IsNativeDebuggable() const {
723 return is_native_debuggable_;
724 }
725
726 void SetNativeDebuggable(bool value) {
727 is_native_debuggable_ = value;
728 }
729
randy.jeong5bef0222019-05-27 10:29:09 +0900730 void SetSignalHookDebuggable(bool value);
731
Alex Light0aa7a5a2018-10-10 15:58:14 +0000732 bool AreNonStandardExitsEnabled() const {
733 return non_standard_exits_enabled_;
734 }
735
736 void SetNonStandardExitsEnabled() {
David Srbecky28f6cff2018-10-16 15:07:28 +0100737 DoAndMaybeSwitchInterpreter([=](){ non_standard_exits_enabled_ = true; });
Alex Light0aa7a5a2018-10-10 15:58:14 +0000738 }
739
Alex Light7919db92017-11-29 09:00:55 -0800740 bool AreAsyncExceptionsThrown() const {
741 return async_exceptions_thrown_;
742 }
743
744 void SetAsyncExceptionsThrown() {
David Srbecky28f6cff2018-10-16 15:07:28 +0100745 DoAndMaybeSwitchInterpreter([=](){ async_exceptions_thrown_ = true; });
Alex Light7919db92017-11-29 09:00:55 -0800746 }
747
David Srbecky28f6cff2018-10-16 15:07:28 +0100748 // Change state and re-check which interpreter should be used.
749 //
750 // This must be called whenever there is an event that forces
751 // us to use different interpreter (e.g. debugger is attached).
752 //
753 // Changing the state using the lamda gives us some multihreading safety.
754 // It ensures that two calls do not interfere with each other and
755 // it makes it possible to DCHECK that thread local flag is correct.
756 template<typename Action>
David Srbeckyd3883902019-02-26 17:29:32 +0000757 static void DoAndMaybeSwitchInterpreter(Action lamda);
David Srbecky28f6cff2018-10-16 15:07:28 +0100758
Andreas Gampedd671252015-07-23 14:37:18 -0700759 // Returns the build fingerprint, if set. Otherwise an empty string is returned.
760 std::string GetFingerprint() {
761 return fingerprint_;
762 }
763
Mathieu Chartier673ed3d2015-08-28 14:56:43 -0700764 // Called from class linker.
Vladimir Marko024d69f2019-06-13 10:52:32 +0100765 void SetSentinel(ObjPtr<mirror::Object> sentinel) REQUIRES_SHARED(Locks::mutator_lock_);
Roland Levillain0e155592018-11-05 18:31:49 +0000766 // For testing purpose only.
767 // TODO: Remove this when this is no longer needed (b/116087961).
768 GcRoot<mirror::Object> GetSentinel() REQUIRES_SHARED(Locks::mutator_lock_);
Mathieu Chartier673ed3d2015-08-28 14:56:43 -0700769
Mathieu Chartier951ec2c2015-09-22 08:50:05 -0700770 // Create a normal LinearAlloc or low 4gb version if we are 64 bit AOT compiler.
771 LinearAlloc* CreateLinearAlloc();
772
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -0700773 OatFileManager& GetOatFileManager() const {
774 DCHECK(oat_file_manager_ != nullptr);
Mathieu Chartiere58991b2015-10-13 07:59:34 -0700775 return *oat_file_manager_;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -0700776 }
777
Mathieu Chartier32cc9ee2015-10-15 09:19:15 -0700778 double GetHashTableMinLoadFactor() const;
779 double GetHashTableMaxLoadFactor() const;
780
Andreas Gampe83e20492018-11-07 11:12:26 -0800781 bool IsSafeMode() const {
Andreas Gampe83e20492018-11-07 11:12:26 -0800782 return safe_mode_;
783 }
784
Nicolas Geoffray787ae8e2015-11-05 11:32:24 +0000785 void SetSafeMode(bool mode) {
786 safe_mode_ = mode;
787 }
788
Nicolas Geoffraya73280d2016-02-15 13:05:16 +0000789 bool GetDumpNativeStackOnSigQuit() const {
790 return dump_native_stack_on_sig_quit_;
791 }
792
Andreas Gampea1425a12016-03-11 17:44:04 -0800793 bool GetPrunedDalvikCache() const {
794 return pruned_dalvik_cache_;
795 }
796
797 void SetPrunedDalvikCache(bool pruned) {
798 pruned_dalvik_cache_ = pruned;
799 }
800
Mathieu Chartierf8cb1782016-03-18 18:45:41 -0700801 void UpdateProcessState(ProcessState process_state);
802
803 // Returns true if we currently care about long mutator pause.
804 bool InJankPerceptibleProcessState() const {
805 return process_state_ == kProcessStateJankPerceptible;
806 }
807
Calin Juravle97cbc922016-04-15 16:16:35 +0100808 void RegisterSensitiveThread() const;
809
Andreas Gampef38a6612016-04-11 08:42:26 -0700810 void SetZygoteNoThreadSection(bool val) {
811 zygote_no_threads_ = val;
812 }
813
814 bool IsZygoteNoThreadSection() const {
815 return zygote_no_threads_;
816 }
817
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000818 // Returns if the code can be deoptimized asynchronously. Code may be compiled with some
Mingyao Yangf711f2c2016-05-23 12:29:39 -0700819 // optimization that makes it impossible to deoptimize.
Nicolas Geoffray433b79a2017-01-30 20:54:45 +0000820 bool IsAsyncDeoptimizeable(uintptr_t code) const REQUIRES_SHARED(Locks::mutator_lock_);
Mingyao Yangf711f2c2016-05-23 12:29:39 -0700821
David Sehrd106d9f2016-08-16 19:22:57 -0700822 // Returns a saved copy of the environment (getenv/setenv values).
823 // Used by Fork to protect against overwriting LD_LIBRARY_PATH, etc.
824 char** GetEnvSnapshot() const {
825 return env_snapshot_.GetSnapshot();
826 }
827
Andreas Gampefda57142016-09-08 20:29:18 -0700828 void AddSystemWeakHolder(gc::AbstractSystemWeakHolder* holder);
829 void RemoveSystemWeakHolder(gc::AbstractSystemWeakHolder* holder);
830
Alex Lightf889c702018-02-23 15:25:45 -0800831 void AttachAgent(JNIEnv* env, const std::string& agent_arg, jobject class_loader);
Leonard Mosescueb842212016-10-06 17:26:36 -0700832
Andreas Gampeaadcbc62017-12-28 14:05:42 -0800833 const std::list<std::unique_ptr<ti::Agent>>& GetAgents() const {
Alex Light65af20b2017-04-20 09:15:08 -0700834 return agents_;
835 }
836
Andreas Gampeac30fa22017-01-18 21:02:36 -0800837 RuntimeCallbacks* GetRuntimeCallbacks();
Andreas Gampe04bbb5b2017-01-19 17:49:03 +0000838
Alex Light77fee872017-09-05 14:51:49 -0700839 bool HasLoadedPlugins() const {
840 return !plugins_.empty();
841 }
842
Andreas Gampebad529d2017-02-13 18:52:10 -0800843 void InitThreadGroups(Thread* self);
844
Mathieu Chartier1d495012017-04-11 17:50:00 -0700845 void SetDumpGCPerformanceOnShutdown(bool value) {
846 dump_gc_performance_on_shutdown_ = value;
847 }
848
Lokesh Gidra10d0c962019-03-07 22:40:36 +0000849 bool GetDumpGCPerformanceOnShutdown() const {
850 return dump_gc_performance_on_shutdown_;
851 }
852
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +0100853 void IncrementDeoptimizationCount(DeoptimizationKind kind) {
854 DCHECK_LE(kind, DeoptimizationKind::kLast);
855 deoptimization_counts_[static_cast<size_t>(kind)]++;
856 }
857
Nicolas Geoffrayb9bec2e2017-05-24 15:59:18 +0100858 uint32_t GetNumberOfDeoptimizations() const {
859 uint32_t result = 0;
860 for (size_t i = 0; i <= static_cast<size_t>(DeoptimizationKind::kLast); ++i) {
861 result += deoptimization_counts_[i];
862 }
863 return result;
864 }
865
Mathieu Chartierc42cb0e2017-10-13 11:35:00 -0700866 // Whether or not we use MADV_RANDOM on files that are thought to have random access patterns.
867 // This is beneficial for low RAM devices since it reduces page cache thrashing.
868 bool MAdviseRandomAccess() const {
869 return madvise_random_access_;
870 }
871
Alex Light40320712017-12-14 11:52:04 -0800872 const std::string& GetJdwpOptions() {
873 return jdwp_options_;
874 }
875
876 JdwpProvider GetJdwpProvider() const {
877 return jdwp_provider_;
878 }
879
Alex Lightf3677472019-06-26 16:31:53 -0700880 JniIdType GetJniIdType() const {
881 return jni_ids_indirection_;
Alex Light79d6c802019-06-27 15:50:11 +0000882 }
883
Alex Lightf3677472019-06-26 16:31:53 -0700884 bool CanSetJniIdType() const {
885 return GetJniIdType() == JniIdType::kSwapablePointer;
886 }
887
888 // Changes the JniIdType to the given type. Only allowed if CanSetJniIdType(). All threads must be
889 // suspended to call this function.
890 void SetJniIdType(JniIdType t);
891
Andreas Gampe0b0ffc12018-08-01 14:41:27 -0700892 uint32_t GetVerifierLoggingThresholdMs() const {
893 return verifier_logging_threshold_ms_;
894 }
895
Mathieu Chartierada33d72018-12-17 13:17:30 -0800896 // Atomically delete the thread pool if the reference count is 0.
897 bool DeleteThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
898
899 // Wait for all the thread workers to be attached.
900 void WaitForThreadPoolWorkersToStart() REQUIRES(!Locks::runtime_thread_pool_lock_);
901
902 // Scoped usage of the runtime thread pool. Prevents the pool from being
903 // deleted. Note that the thread pool is only for startup and gets deleted after.
904 class ScopedThreadPoolUsage {
905 public:
906 ScopedThreadPoolUsage();
907 ~ScopedThreadPoolUsage();
908
909 // Return the thread pool.
910 ThreadPool* GetThreadPool() const {
911 return thread_pool_;
912 }
913
914 private:
915 ThreadPool* const thread_pool_;
916 };
917
Mathieu Chartiera88abfa2019-02-04 11:08:29 -0800918 bool LoadAppImageStartupCache() const {
919 return load_app_image_startup_cache_;
920 }
921
922 void SetLoadAppImageStartupCacheEnabled(bool enabled) {
923 load_app_image_startup_cache_ = enabled;
924 }
925
Mathieu Chartier03625442019-06-24 17:29:23 -0700926 // Reset the startup completed status so that we can call NotifyStartupCompleted again. Should
927 // only be used for testing.
928 void ResetStartupCompleted();
929
Mathieu Chartier175ce3d2019-03-06 16:54:24 -0800930 // Notify the runtime that application startup is considered completed. Only has effect for the
931 // first call.
932 void NotifyStartupCompleted();
933
934 // Return true if startup is already completed.
935 bool GetStartupCompleted() const;
936
Andreas Gampe86823542019-02-25 09:38:49 -0800937 gc::space::ImageSpaceLoadingOrder GetImageSpaceLoadingOrder() const {
938 return image_space_loading_order_;
939 }
940
Andreas Gamped84794d2019-07-18 13:40:03 -0700941 bool IsVerifierMissingKThrowFatal() const {
942 return verifier_missing_kthrow_fatal_;
943 }
944
Carl Shapirob5573532011-07-12 18:22:59 -0700945 private:
Elliott Hughes457005c2012-04-16 13:54:25 -0700946 static void InitPlatformSignalHandlers();
Elliott Hughesffe67362011-07-17 12:09:27 -0700947
Elliott Hughesdcc24742011-09-07 14:02:44 -0700948 Runtime();
Carl Shapiro61e019d2011-07-14 16:53:09 -0700949
Elliott Hughesc1674ed2011-08-25 18:09:09 -0700950 void BlockSignals();
951
Vladimir Marko88b2b802015-12-04 14:19:04 +0000952 bool Init(RuntimeArgumentMap&& runtime_options)
Ian Rogersb726dcb2012-09-05 08:57:23 -0700953 SHARED_TRYLOCK_FUNCTION(true, Locks::mutator_lock_);
Mathieu Chartier90443472015-07-16 20:32:27 -0700954 void InitNativeMethods() REQUIRES(!Locks::mutator_lock_);
Elliott Hughesff17f1f2012-01-24 18:12:29 -0800955 void RegisterRuntimeNativeMethods(JNIEnv* env);
Elliott Hughesd1cc8362011-10-24 16:58:50 -0700956
Elliott Hughes85d15452011-09-16 17:33:01 -0700957 void StartDaemonThreads();
Elliott Hughesd1cc8362011-10-24 16:58:50 -0700958 void StartSignalCatcher();
Carl Shapiro61e019d2011-07-14 16:53:09 -0700959
Calin Juravle31f2c152015-10-23 17:56:15 +0100960 void MaybeSaveJitProfilingInfo();
961
Andreas Gampe585da952016-12-02 14:52:29 -0800962 // Visit all of the thread roots.
963 void VisitThreadRoots(RootVisitor* visitor, VisitRootFlags flags)
964 REQUIRES_SHARED(Locks::mutator_lock_);
965
966 // Visit all other roots which must be done with mutators suspended.
967 void VisitNonConcurrentRoots(RootVisitor* visitor, VisitRootFlags flags)
968 REQUIRES_SHARED(Locks::mutator_lock_);
969
970 // Constant roots are the roots which never change after the runtime is initialized, they only
971 // need to be visited once per GC cycle.
972 void VisitConstantRoots(RootVisitor* visitor)
973 REQUIRES_SHARED(Locks::mutator_lock_);
974
Andreas Gampe44f67602018-11-28 08:27:27 -0800975 // Note: To be lock-free, GetFaultMessage temporarily replaces the lock message with null.
976 // As such, there is a window where a call will return an empty string. In general,
977 // only aborting code should retrieve this data (via GetFaultMessageForAbortLogging
978 // friend).
979 std::string GetFaultMessage();
980
Mathieu Chartierada33d72018-12-17 13:17:30 -0800981 ThreadPool* AcquireThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
982 void ReleaseThreadPool() REQUIRES(!Locks::runtime_thread_pool_lock_);
983
Mathieu Chartier2cebb242015-04-21 16:50:40 -0700984 // A pointer to the active runtime or null.
Elliott Hughesb3bd5f02012-03-08 21:05:27 -0800985 static Runtime* instance_;
986
Ian Rogers8afeb852014-04-02 14:55:49 -0700987 // NOTE: these must match the gc::ProcessState values as they come directly from the framework.
988 static constexpr int kProfileForground = 0;
Calin Juravle31f2c152015-10-23 17:56:15 +0100989 static constexpr int kProfileBackground = 1;
Ian Rogers8afeb852014-04-02 14:55:49 -0700990
Mingyao Yang0a87a652017-04-12 13:43:15 -0700991 static constexpr uint32_t kCalleeSaveSize = 6u;
Andreas Gampe8228cdf2017-05-30 15:03:54 -0700992
Mathieu Chartiere401d142015-04-22 13:56:20 -0700993 // 64 bit so that we can share the same asm offsets for both 32 and 64 bits.
Andreas Gampe8228cdf2017-05-30 15:03:54 -0700994 uint64_t callee_save_methods_[kCalleeSaveSize];
Roland Levillain7b0e8442018-04-11 18:27:47 +0100995 // Pre-allocated exceptions (see Runtime::Init).
996 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_throwing_exception_;
997 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_throwing_oome_;
998 GcRoot<mirror::Throwable> pre_allocated_OutOfMemoryError_when_handling_stack_overflow_;
Ian Rogers63557452014-06-04 16:57:15 -0700999 GcRoot<mirror::Throwable> pre_allocated_NoClassDefFoundError_;
Mathieu Chartiere401d142015-04-22 13:56:20 -07001000 ArtMethod* resolution_method_;
1001 ArtMethod* imt_conflict_method_;
Mathieu Chartier2d2621a2014-10-23 16:48:06 -07001002 // Unresolved method has the same behavior as the conflict method, it is used by the class linker
1003 // for differentiating between unfilled imt slots vs conflict slots in superclasses.
Mathieu Chartiere401d142015-04-22 13:56:20 -07001004 ArtMethod* imt_unimplemented_method_;
Ian Rogers6ed19fd2014-03-20 08:10:17 -07001005
Ian Rogersc0542af2014-09-03 16:16:56 -07001006 // Special sentinel object used to invalid conditions in JNI (cleared weak references) and
1007 // JDWP (invalid references).
1008 GcRoot<mirror::Object> sentinel_;
1009
Vladimir Marko7624d252014-05-02 14:40:15 +01001010 InstructionSet instruction_set_;
Vladimir Marko7624d252014-05-02 14:40:15 +01001011
Vladimir Marko2b5eaa22013-12-13 13:59:30 +00001012 CompilerCallbacks* compiler_callbacks_;
Elliott Hughes9ca7a1f2011-10-11 14:29:52 -07001013 bool is_zygote_;
Nicolas Geoffray4444f1b2019-06-10 14:09:19 +01001014 bool is_primary_zygote_;
Nicolas Geoffray9ac09ee2019-05-08 23:38:27 +01001015 bool is_system_server_;
Alex Lighta59dd802014-07-02 16:28:08 -07001016 bool must_relocate_;
Mathieu Chartier069387a2012-06-18 12:01:01 -07001017 bool is_concurrent_gc_enabled_;
Anwar Ghuloum87183592013-08-14 12:12:19 -07001018 bool is_explicit_gc_disabled_;
Alex Light64ad14d2014-08-19 14:23:13 -07001019 bool image_dex2oat_enabled_;
Brian Carlstrom0a5b14d2011-09-27 13:29:15 -07001020
Tsu Chiang Chuang12e6d742014-05-22 10:22:25 -07001021 std::string compiler_executable_;
Brian Carlstrom6449c622014-02-10 23:48:36 -08001022 std::vector<std::string> compiler_options_;
1023 std::vector<std::string> image_compiler_options_;
Brian Carlstrom31d8f522014-09-29 11:22:54 -07001024 std::string image_location_;
David Srbecky3db3d372019-04-17 18:19:17 +01001025 bool is_using_apex_boot_image_location_;
Dragos Sbirlea7467ee02013-06-21 09:20:34 -07001026
Vladimir Markod1908512018-11-22 14:57:28 +00001027 std::vector<std::string> boot_class_path_;
1028 std::vector<std::string> boot_class_path_locations_;
Brian Carlstroma004aa92012-02-08 18:05:09 -08001029 std::string class_path_string_;
Elliott Hughes7ede61e2011-09-14 18:18:06 -07001030 std::vector<std::string> properties_;
1031
Andreas Gampeaadcbc62017-12-28 14:05:42 -08001032 std::list<ti::AgentSpec> agent_specs_;
1033 std::list<std::unique_ptr<ti::Agent>> agents_;
Alex Light185d1342016-08-11 10:48:03 -07001034 std::vector<Plugin> plugins_;
Alex Light7233c7e2016-07-28 10:07:45 -07001035
Brian Carlstromb765be02011-08-17 23:54:10 -07001036 // The default stack size for managed threads created by the runtime.
Elliott Hughesbe759c62011-09-08 19:38:21 -07001037 size_t default_stack_size_;
Brian Carlstromb765be02011-08-17 23:54:10 -07001038
Hans Boehmb2155572019-03-27 14:25:53 -07001039 // Finalizers running for longer than this many milliseconds abort the runtime.
1040 unsigned int finalizer_timeout_ms_;
1041
Ian Rogers1d54e732013-05-02 21:10:01 -07001042 gc::Heap* heap_;
Elliott Hughesb3bd5f02012-03-08 21:05:27 -08001043
Nicolas Geoffray25e04562016-03-01 13:17:58 +00001044 std::unique_ptr<ArenaPool> jit_arena_pool_;
Mathieu Chartier9b34b242015-03-09 11:30:17 -07001045 std::unique_ptr<ArenaPool> arena_pool_;
Mathieu Chartierc7853442015-03-27 14:35:38 -07001046 // Special low 4gb pool for compiler linear alloc. We need ArtFields to be in low 4gb if we are
1047 // compiling using a 32 bit image on a 64 bit compiler in case we resolve things in the image
1048 // since the field arrays are int arrays in this case.
1049 std::unique_ptr<ArenaPool> low_4gb_arena_pool_;
1050
1051 // Shared linear alloc for now.
1052 std::unique_ptr<LinearAlloc> linear_alloc_;
Mathieu Chartier9b34b242015-03-09 11:30:17 -07001053
Ian Rogersd9c4fc92013-10-01 19:45:43 -07001054 // The number of spins that are done before thread suspension is used to forcibly inflate.
1055 size_t max_spins_before_thin_lock_inflation_;
Elliott Hughesc33a32b2011-10-11 18:18:07 -07001056 MonitorList* monitor_list_;
Ian Rogersef7d42f2014-01-06 12:55:46 -08001057 MonitorPool* monitor_pool_;
Elliott Hughesc33a32b2011-10-11 18:18:07 -07001058
Carl Shapirob5573532011-07-12 18:22:59 -07001059 ThreadList* thread_list_;
Carl Shapiro61e019d2011-07-14 16:53:09 -07001060
Elliott Hughescf4c6c42011-09-01 15:16:42 -07001061 InternTable* intern_table_;
1062
Brian Carlstromb0460ea2011-07-29 10:08:05 -07001063 ClassLinker* class_linker_;
1064
Elliott Hughese27955c2011-08-26 15:21:24 -07001065 SignalCatcher* signal_catcher_;
Narayan Kamatheb710332017-05-10 11:48:46 +01001066
Alex Light79d6c802019-06-27 15:50:11 +00001067 std::unique_ptr<jni::JniIdManager> jni_id_manager_;
1068
Richard Uhlerda0a69e2016-10-11 15:06:38 +01001069 std::unique_ptr<JavaVMExt> java_vm_;
Elliott Hughesf2682d52011-08-15 16:37:04 -07001070
Mathieu Chartiere5f13e52015-02-24 09:37:21 -08001071 std::unique_ptr<jit::Jit> jit_;
Orion Hodsonad28f5e2018-10-17 09:08:17 +01001072 std::unique_ptr<jit::JitCodeCache> jit_code_cache_;
Mathieu Chartiere5f13e52015-02-24 09:37:21 -08001073 std::unique_ptr<jit::JitOptions> jit_options_;
1074
Mathieu Chartierada33d72018-12-17 13:17:30 -08001075 // Runtime thread pool. The pool is only for startup and gets deleted after.
1076 std::unique_ptr<ThreadPool> thread_pool_ GUARDED_BY(Locks::runtime_thread_pool_lock_);
1077 size_t thread_pool_ref_count_ GUARDED_BY(Locks::runtime_thread_pool_lock_);
1078
Andreas Gampe44f67602018-11-28 08:27:27 -08001079 // Fault message, printed when we get a SIGSEGV. Stored as a native-heap object and accessed
1080 // lock-free, so needs to be atomic.
1081 std::atomic<std::string*> fault_message_;
Mathieu Chartier15d34022014-02-26 17:16:38 -08001082
Ian Rogers120f1c72012-09-28 17:17:10 -07001083 // A non-zero value indicates that a thread has been created but not yet initialized. Guarded by
1084 // the shutdown lock so that threads aren't born while we're shutting down.
1085 size_t threads_being_born_ GUARDED_BY(Locks::runtime_shutdown_lock_);
1086
1087 // Waited upon until no threads are being born.
Ian Rogers700a4022014-05-19 16:49:03 -07001088 std::unique_ptr<ConditionVariable> shutdown_cond_ GUARDED_BY(Locks::runtime_shutdown_lock_);
Ian Rogers120f1c72012-09-28 17:17:10 -07001089
1090 // Set when runtime shutdown is past the point that new threads may attach.
1091 bool shutting_down_ GUARDED_BY(Locks::runtime_shutdown_lock_);
1092
1093 // The runtime is starting to shutdown but is blocked waiting on shutdown_cond_.
1094 bool shutting_down_started_ GUARDED_BY(Locks::runtime_shutdown_lock_);
1095
Elliott Hughesdcc24742011-09-07 14:02:44 -07001096 bool started_;
1097
Mathieu Chartier7664f5c2012-06-08 18:15:32 -07001098 // New flag added which tells us if the runtime has finished starting. If
1099 // this flag is set then the Daemon threads are created and the class loader
1100 // is created. This flag is needed for knowing if its safe to request CMS.
1101 bool finished_starting_;
1102
Brian Carlstrom6ea095a2011-08-16 15:26:54 -07001103 // Hooks supported by JNI_CreateJavaVM
1104 jint (*vfprintf_)(FILE* stream, const char* format, va_list ap);
1105 void (*exit_)(jint status);
1106 void (*abort_)();
1107
Elliott Hughes9d5ccec2011-09-19 13:19:50 -07001108 bool stats_enabled_;
1109 RuntimeStats stats_;
1110
Evgenii Stepanov1e133742015-05-20 12:30:59 -07001111 const bool is_running_on_memory_tool_;
Mathieu Chartierda44d772014-04-01 15:01:46 -07001112
Andreas Gampef6a780a2015-04-02 18:51:05 -07001113 std::unique_ptr<TraceConfig> trace_config_;
1114
Ian Rogers62d6c772013-02-27 08:32:07 -08001115 instrumentation::Instrumentation instrumentation_;
jeffhao2692b572011-12-16 15:42:28 -08001116
Ian Rogers365c1022012-06-22 15:05:28 -07001117 jobject main_thread_group_;
1118 jobject system_thread_group_;
1119
Brian Carlstromce888532013-10-10 00:32:58 -07001120 // As returned by ClassLoader.getSystemClassLoader().
1121 jobject system_class_loader_;
1122
Hiroshi Yamauchi2e899a92013-11-22 16:50:12 -08001123 // If true, then we dump the GC cumulative timings on shutdown.
1124 bool dump_gc_performance_on_shutdown_;
1125
Chang Xing605fe242017-07-20 15:57:21 -07001126 // Transactions used for pre-initializing classes at compilation time.
1127 // Support nested transactions, maintain a list containing all transactions. Transactions are
1128 // handled under a stack discipline. Because GC needs to go over all transactions, we choose list
1129 // as substantial data structure instead of stack.
1130 std::list<std::unique_ptr<Transaction>> preinitialization_transactions_;
Sebastien Hertzd2fe10a2014-01-15 10:20:56 +01001131
Igor Murashkin7617abd2015-07-10 18:27:47 -07001132 // If kNone, verification is disabled. kEnable by default.
1133 verifier::VerifyMode verify_;
Jeff Hao4a200f52014-04-01 14:58:49 -07001134
Jean Christophe Beyler24e04aa2014-09-12 12:03:25 -07001135 // If true, the runtime may use dex files directly with the interpreter if an oat file is not
1136 // available/usable.
1137 bool allow_dex_file_fallback_;
1138
Dmitriy Ivanov785049f2014-07-18 10:08:57 -07001139 // List of supported cpu abis.
1140 std::vector<std::string> cpu_abilist_;
1141
Jeff Haof00571c2014-05-29 17:29:47 -07001142 // Specifies target SDK version to allow workarounds for certain API levels.
David Brazdil2bb2fbd2018-11-13 18:24:26 +00001143 uint32_t target_sdk_version_;
Jeff Haof00571c2014-05-29 17:29:47 -07001144
Dave Allison69dfe512014-07-11 17:11:58 +00001145 // Implicit checks flags.
1146 bool implicit_null_checks_; // NullPointer checks are implicit.
1147 bool implicit_so_checks_; // StackOverflow checks are implicit.
1148 bool implicit_suspend_checks_; // Thread suspension checks are implicit.
1149
Calin Juravle01aaf6e2015-06-19 22:05:39 +01001150 // Whether or not the sig chain (and implicitly the fault handler) should be
Vladimir Markoa497a392018-09-26 10:52:50 +01001151 // disabled. Tools like dex2oat don't need them. This enables
Calin Juravle01aaf6e2015-06-19 22:05:39 +01001152 // building a statically link version of dex2oat.
1153 bool no_sig_chain_;
1154
Calin Juravled3e7c6c2016-02-04 19:07:51 +00001155 // Force the use of native bridge even if the app ISA matches the runtime ISA.
1156 bool force_native_bridge_;
1157
Calin Juravle07d83c72014-10-22 21:02:23 +01001158 // Whether or not a native bridge has been loaded.
Calin Juravlec8423522014-08-12 20:55:20 +01001159 //
1160 // The native bridge allows running native code compiled for a foreign ISA. The way it works is,
1161 // if standard dlopen fails to load native library associated with native activity, it calls to
1162 // the native bridge to load it and then gets the trampoline for the entry to native activity.
Calin Juravle07d83c72014-10-22 21:02:23 +01001163 //
1164 // The option 'native_bridge_library_filename' specifies the name of the native bridge.
1165 // When non-empty the native bridge will be loaded from the given file. An empty value means
1166 // that there's no native bridge.
1167 bool is_native_bridge_loaded_;
Calin Juravlec8423522014-08-12 20:55:20 +01001168
David Srbeckyf4480162016-03-16 00:06:24 +00001169 // Whether we are running under native debugger.
1170 bool is_native_debuggable_;
1171
Alex Light7919db92017-11-29 09:00:55 -08001172 // whether or not any async exceptions have ever been thrown. This is used to speed up the
1173 // MterpShouldSwitchInterpreters function.
1174 bool async_exceptions_thrown_;
1175
Alex Light0aa7a5a2018-10-10 15:58:14 +00001176 // Whether anything is going to be using the shadow-frame APIs to force a function to return
1177 // early. Doing this requires that (1) we be debuggable and (2) that mterp is exited.
1178 bool non_standard_exits_enabled_;
1179
Nicolas Geoffray433b79a2017-01-30 20:54:45 +00001180 // Whether Java code needs to be debuggable.
1181 bool is_java_debuggable_;
Alex Light6b16d892016-11-11 11:21:04 -08001182
Florian Mayer07710c52019-09-16 15:53:38 +00001183 bool is_profileable_from_shell_ = false;
1184
Narayan Kamath5a2be3f2015-02-16 13:51:51 +00001185 // The maximum number of failed boots we allow before pruning the dalvik cache
1186 // and trying again. This option is only inspected when we're running as a
1187 // zygote.
1188 uint32_t zygote_max_failed_boots_;
1189
Igor Murashkin158f35c2015-06-10 15:55:30 -07001190 // Enable experimental opcodes that aren't fully specified yet. The intent is to
1191 // eventually publish them as public-usable opcodes, but they aren't ready yet.
1192 //
1193 // Experimental opcodes should not be used by other production code.
Alex Lighteb7c1442015-08-31 13:17:42 -07001194 ExperimentalFlags experimental_flags_;
Igor Murashkin158f35c2015-06-10 15:55:30 -07001195
Andreas Gampedd671252015-07-23 14:37:18 -07001196 // Contains the build fingerprint, if given as a parameter.
1197 std::string fingerprint_;
1198
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -07001199 // Oat file manager, keeps track of what oat files are open.
Mathieu Chartiere58991b2015-10-13 07:59:34 -07001200 OatFileManager* oat_file_manager_;
Mathieu Chartierf9c6fc62015-10-07 11:44:05 -07001201
Mathieu Chartier32cc9ee2015-10-15 09:19:15 -07001202 // Whether or not we are on a low RAM device.
1203 bool is_low_memory_mode_;
1204
Mathieu Chartierc42cb0e2017-10-13 11:35:00 -07001205 // Whether or not we use MADV_RANDOM on files that are thought to have random access patterns.
1206 // This is beneficial for low RAM devices since it reduces page cache thrashing.
1207 bool madvise_random_access_;
1208
Nicolas Geoffray787ae8e2015-11-05 11:32:24 +00001209 // Whether the application should run in safe mode, that is, interpreter only.
1210 bool safe_mode_;
1211
David Brazdil3e0fa0a2018-01-15 18:41:44 +00001212 // Whether access checks on hidden API should be performed.
Mathew Inwooda5dc52c2018-02-19 15:30:51 +00001213 hiddenapi::EnforcementPolicy hidden_api_policy_;
David Brazdil3e0fa0a2018-01-15 18:41:44 +00001214
David Brazdile7681822018-12-14 16:25:33 +00001215 // Whether access checks on core platform API should be performed.
1216 hiddenapi::EnforcementPolicy core_platform_api_policy_;
1217
Mathew Inwoodc8ce5f52018-04-05 13:58:55 +01001218 // List of signature prefixes of methods that have been removed from the blacklist, and treated
1219 // as if whitelisted.
Mathew Inwood3383aa52018-03-16 14:18:33 +00001220 std::vector<std::string> hidden_api_exemptions_;
1221
David Brazdilee7d2fd2018-01-20 17:25:23 +00001222 // Do not warn about the same hidden API access violation twice.
1223 // This is only used for testing.
1224 bool dedupe_hidden_api_warnings_;
1225
Mathew Inwood5bcef172018-05-01 14:40:12 +01001226 // How often to log hidden API access to the event log. An integer between 0
1227 // (never) and 0x10000 (always).
Mathew Inwood73ddda42018-04-03 15:32:32 +01001228 uint32_t hidden_api_access_event_log_rate_;
1229
Mathew Inwood5bcef172018-05-01 14:40:12 +01001230 // The package of the app running in this process.
1231 std::string process_package_name_;
1232
David Brazdil35a3f6a2019-03-04 15:59:06 +00001233 // The data directory of the app running in this process.
1234 std::string process_data_directory_;
1235
Nicolas Geoffraya73280d2016-02-15 13:05:16 +00001236 // Whether threads should dump their native stack on SIGQUIT.
1237 bool dump_native_stack_on_sig_quit_;
1238
Andreas Gampea1425a12016-03-11 17:44:04 -08001239 // Whether the dalvik cache was pruned when initializing the runtime.
1240 bool pruned_dalvik_cache_;
1241
Mathieu Chartierf8cb1782016-03-18 18:45:41 -07001242 // Whether or not we currently care about pause times.
1243 ProcessState process_state_;
1244
Andreas Gampef38a6612016-04-11 08:42:26 -07001245 // Whether zygote code is in a section that should not start threads.
1246 bool zygote_no_threads_;
1247
Alex Light40320712017-12-14 11:52:04 -08001248 // The string containing requested jdwp options
1249 std::string jdwp_options_;
1250
1251 // The jdwp provider we were configured with.
1252 JdwpProvider jdwp_provider_;
1253
Alex Light79d6c802019-06-27 15:50:11 +00001254 // True if jmethodID and jfieldID are opaque Indices. When false (the default) these are simply
1255 // pointers. This is set by -Xopaque-jni-ids:{true,false}.
1256 JniIdType jni_ids_indirection_;
1257
David Sehrd106d9f2016-08-16 19:22:57 -07001258 // Saved environment.
1259 class EnvSnapshot {
1260 public:
1261 EnvSnapshot() = default;
1262 void TakeSnapshot();
1263 char** GetSnapshot() const;
1264
1265 private:
1266 std::unique_ptr<char*[]> c_env_vector_;
1267 std::vector<std::unique_ptr<std::string>> name_value_pairs_;
1268
1269 DISALLOW_COPY_AND_ASSIGN(EnvSnapshot);
1270 } env_snapshot_;
1271
Andreas Gampefda57142016-09-08 20:29:18 -07001272 // Generic system-weak holders.
1273 std::vector<gc::AbstractSystemWeakHolder*> system_weak_holders_;
1274
Andreas Gampeac30fa22017-01-18 21:02:36 -08001275 std::unique_ptr<RuntimeCallbacks> callbacks_;
Andreas Gampe04bbb5b2017-01-19 17:49:03 +00001276
Nicolas Geoffray81cc43e2017-05-10 12:04:49 +01001277 std::atomic<uint32_t> deoptimization_counts_[
1278 static_cast<uint32_t>(DeoptimizationKind::kLast) + 1];
Nicolas Geoffray4e92c3c2017-05-08 09:34:26 +01001279
Vladimir Markoc34bebf2018-08-16 16:12:49 +01001280 MemMap protected_fault_page_;
Andreas Gampe2ac67d52017-05-11 22:30:38 -07001281
Andreas Gampe0b0ffc12018-08-01 14:41:27 -07001282 uint32_t verifier_logging_threshold_ms_;
1283
Mathieu Chartiera88abfa2019-02-04 11:08:29 -08001284 bool load_app_image_startup_cache_ = false;
1285
Mathieu Chartier175ce3d2019-03-06 16:54:24 -08001286 // If startup has completed, must happen at most once.
1287 std::atomic<bool> startup_completed_ = false;
1288
Andreas Gampe86823542019-02-25 09:38:49 -08001289 gc::space::ImageSpaceLoadingOrder image_space_loading_order_ =
1290 gc::space::ImageSpaceLoadingOrder::kSystemFirst;
1291
Andreas Gamped84794d2019-07-18 13:40:03 -07001292 bool verifier_missing_kthrow_fatal_;
1293
Andreas Gampe44f67602018-11-28 08:27:27 -08001294 // Note: See comments on GetFaultMessage.
1295 friend std::string GetFaultMessageForAbortLogging();
Mathieu Chartierada33d72018-12-17 13:17:30 -08001296 friend class ScopedThreadPoolUsage;
Vladimir Markof3d88a82018-12-21 16:38:47 +00001297 friend class OatFileAssistantTest;
Andreas Gampe44f67602018-11-28 08:27:27 -08001298
Carl Shapiro61e019d2011-07-14 16:53:09 -07001299 DISALLOW_COPY_AND_ASSIGN(Runtime);
Carl Shapiro1fb86202011-06-27 17:43:13 -07001300};
1301
1302} // namespace art
1303
Brian Carlstromfc0e3212013-07-17 14:40:12 -07001304#endif // ART_RUNTIME_RUNTIME_H_