From 4e99b3d8955131f3fc71aa113f0fa71f0092cb6f Mon Sep 17 00:00:00 2001 From: Sebastien Hertz Date: Tue, 24 Jun 2014 14:35:40 +0200 Subject: Add missing class initialization during compilation and tests Adds missing class initialization during compilation and tests, especially java.lang.Class. Otherwise, we'd be able to execute code while the referring class is not initialized or initializing. Also adds mirror::Class::AssertInitializedOrInitializingInThread method to check class initialization when entering the interpreter: the called method's declaring class must either be initialized or be initializing by the current thread (other threads must be waiting for the class initialization to complete holding its lock). Note we only do this check in debug build. Bump oat version to force compilation. Bug: 15899971 Change-Id: I9a4edd3739a3ca4cf1c4929dcbb44cdf7a1ca1fe --- runtime/common_runtime_test.h | 1 + 1 file changed, 1 insertion(+) (limited to 'runtime/common_runtime_test.h') diff --git a/runtime/common_runtime_test.h b/runtime/common_runtime_test.h index 289dc1de4e..ac6d44b950 100644 --- a/runtime/common_runtime_test.h +++ b/runtime/common_runtime_test.h @@ -206,6 +206,7 @@ class CommonRuntimeTest : public testing::Test { runtime_.reset(Runtime::Current()); class_linker_ = runtime_->GetClassLinker(); class_linker_->FixupDexCaches(runtime_->GetResolutionMethod()); + class_linker_->RunRootClinits(); // Runtime::Create acquired the mutator_lock_ that is normally given away when we // Runtime::Start, give it away now and then switch to a more managable ScopedObjectAccess. -- cgit v1.2.3-59-g8ed1b