diff options
| author | 2013-07-25 11:02:11 -0700 | |
|---|---|---|
| committer | 2013-07-25 11:02:11 -0700 | |
| commit | a4061d443eec47e97388e8d69053b72a5678da6a (patch) | |
| tree | 463c270c2e0c1252dad46406d3675ab4e58f6d2a /compiler/driver/compiler_driver.cc | |
| parent | df28d4a8c17375e4cd1c37ed801ed9a9f080d450 (diff) | |
| parent | d792cc1569c3505d68352c11a72447419ee6eaaf (diff) | |
am d792cc15: Add art support for Zygote NoPreloadHolder which black lists early initialization.
* commit 'd792cc1569c3505d68352c11a72447419ee6eaaf':
  Add art support for Zygote NoPreloadHolder which black lists early initialization.
Diffstat (limited to 'compiler/driver/compiler_driver.cc')
| -rw-r--r-- | compiler/driver/compiler_driver.cc | 14 | 
1 files changed, 8 insertions, 6 deletions
| diff --git a/compiler/driver/compiler_driver.cc b/compiler/driver/compiler_driver.cc index 486c536956..c2a1312354 100644 --- a/compiler/driver/compiler_driver.cc +++ b/compiler/driver/compiler_driver.cc @@ -1981,7 +1981,6 @@ static const char* class_initializer_black_list[] = {    "Ljavax/security/cert/X509Certificate$1;", // Calls VMClassLoader.getBootClassPathSize.    "Ljavax/microedition/khronos/egl/EGL10;", // Requires EGLContext.    "Ljavax/microedition/khronos/egl/EGLContext;", // Requires com.google.android.gles_jni.EGLImpl. -  "Ljavax/net/ssl/HttpsURLConnection$DefaultHolder;", // Calls VMClassLoader.getBootClassPathSize().    "Ljavax/xml/datatype/DatatypeConstants;", // Calls OsConstants.initConstants.    "Ljavax/xml/datatype/FactoryFinder;", // Calls OsConstants.initConstants.    "Ljavax/xml/namespace/QName;", // Calls OsConstants.initConstants. @@ -2071,11 +2070,14 @@ static void InitializeClass(const ParallelCompilationManager* manager, size_t cl        }        if (!klass->IsInitialized()) {          if (can_init_static_fields) { -          bool is_black_listed = false; -          for (size_t i = 0; i < arraysize(class_initializer_black_list); ++i) { -            if (StringPiece(descriptor) == class_initializer_black_list[i]) { -              is_black_listed = true; -              break; +          // NoPreloadHolder inner class implies this should not be initialized early. +          bool is_black_listed = StringPiece(descriptor).ends_with("$NoPreloadHolder;"); +          if (!is_black_listed) { +            for (size_t i = 0; i < arraysize(class_initializer_black_list); ++i) { +              if (StringPiece(descriptor) == class_initializer_black_list[i]) { +                is_black_listed = true; +                break; +              }              }            }            if (!is_black_listed) { |