diff options
Diffstat (limited to 'libnativeloader/native_loader.cpp')
-rw-r--r-- | libnativeloader/native_loader.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/libnativeloader/native_loader.cpp b/libnativeloader/native_loader.cpp index a64b9720c..f8bb5fdd1 100644 --- a/libnativeloader/native_loader.cpp +++ b/libnativeloader/native_loader.cpp @@ -57,9 +57,7 @@ static const char* kPublicNativeLibraries = "libandroid.so:" class LibraryNamespaces { public: - LibraryNamespaces() : initialized_(false) { - PreloadPublicLibraries(); - } + LibraryNamespaces() : initialized_(false) { } android_namespace_t* GetOrCreate(JNIEnv* env, jobject class_loader, bool is_shared, @@ -111,7 +109,6 @@ class LibraryNamespaces { return it != namespaces_.end() ? it->second : nullptr; } - private: void PreloadPublicLibraries() { // android_init_namespaces() expects all the public libraries // to be loaded so that they can be found by soname alone. @@ -121,6 +118,7 @@ class LibraryNamespaces { } } + private: bool InitPublicNamespace(const char* library_path) { // Some apps call dlopen from generated code unknown to linker in which // case linker uses anonymous namespace. See b/25844435 for details. @@ -139,6 +137,12 @@ class LibraryNamespaces { static LibraryNamespaces* g_namespaces = new LibraryNamespaces; #endif +void PreloadPublicNativeLibraries() { +#if defined(__ANDROID__) + g_namespaces->PreloadPublicLibraries(); +#endif +} + void* OpenNativeLibrary(JNIEnv* env, int32_t target_sdk_version, const char* path, jobject class_loader, bool is_shared, jstring java_library_path, |