diff options
| author | 2018-11-28 16:06:12 +0000 | |
|---|---|---|
| committer | 2018-11-29 17:16:04 +0000 | |
| commit | a66d69e884b6f9f41a8da31e6d27b498984c7fa3 (patch) | |
| tree | 58efae80d2b2161feff23143ab620242d1c09605 /runtime/class_linker.cc | |
| parent | 8f50b2c27f9b32726bbadfcebba910640b94036e (diff) | |
Support shared libraries in CreateContextFromClassLoader.
Missed this method in my previous set of shared libraries support.
bug: 120036590
bug: 120031686
Test: test.py, app startup with speed-profile
Change-Id: I5c1ec567cfa5452a1f510a3279a9e15125f429ba
Diffstat (limited to 'runtime/class_linker.cc')
| -rw-r--r-- | runtime/class_linker.cc | 24 |
1 files changed, 11 insertions, 13 deletions
diff --git a/runtime/class_linker.cc b/runtime/class_linker.cc index 991faa27d3..9b2e1a10e4 100644 --- a/runtime/class_linker.cc +++ b/runtime/class_linker.cc @@ -9116,8 +9116,8 @@ ObjPtr<mirror::ClassLoader> ClassLinker::CreateWellKnownClassLoader( Thread* self, const std::vector<const DexFile*>& dex_files, Handle<mirror::Class> loader_class, - Handle<mirror::ObjectArray<mirror::ClassLoader>> shared_libraries, - Handle<mirror::ClassLoader> parent_loader) { + Handle<mirror::ClassLoader> parent_loader, + Handle<mirror::ObjectArray<mirror::ClassLoader>> shared_libraries) { StackHandleScope<5> hs(self); @@ -9246,7 +9246,8 @@ ObjPtr<mirror::ClassLoader> ClassLinker::CreateWellKnownClassLoader( jobject ClassLinker::CreateWellKnownClassLoader(Thread* self, const std::vector<const DexFile*>& dex_files, jclass loader_class, - jobject parent_loader) { + jobject parent_loader, + jobject shared_libraries) { CHECK(self->GetJniEnv()->IsSameObject(loader_class, WellKnownClasses::dalvik_system_PathClassLoader) || self->GetJniEnv()->IsSameObject(loader_class, @@ -9257,24 +9258,21 @@ jobject ClassLinker::CreateWellKnownClassLoader(Thread* self, ScopedObjectAccessUnchecked soa(self); // For now, create a libcore-level DexFile for each ART DexFile. This "explodes" multidex. - StackHandleScope<3> hs(self); + StackHandleScope<4> hs(self); Handle<mirror::Class> h_loader_class = hs.NewHandle<mirror::Class>(soa.Decode<mirror::Class>(loader_class)); - Handle<mirror::ClassLoader> parent = - hs.NewHandle<mirror::ClassLoader>(ObjPtr<mirror::ClassLoader>::DownCast( - (parent_loader != nullptr) - ? soa.Decode<mirror::ClassLoader>(parent_loader) - : nullptr)); - Handle<mirror::ObjectArray<mirror::ClassLoader>> shared_libraries = - hs.NewHandle<mirror::ObjectArray<mirror::ClassLoader>>(nullptr); + Handle<mirror::ClassLoader> h_parent = + hs.NewHandle<mirror::ClassLoader>(soa.Decode<mirror::ClassLoader>(parent_loader)); + Handle<mirror::ObjectArray<mirror::ClassLoader>> h_shared_libraries = + hs.NewHandle(soa.Decode<mirror::ObjectArray<mirror::ClassLoader>>(shared_libraries)); ObjPtr<mirror::ClassLoader> loader = CreateWellKnownClassLoader( self, dex_files, h_loader_class, - shared_libraries, - parent); + h_parent, + h_shared_libraries); // Make it a global ref and return. ScopedLocalRef<jobject> local_ref( |