Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 55bbb0d8 authored by Dimitry Ivanov's avatar Dimitry Ivanov
Browse files

Preload public native libraries

Preload libraries needed by the public namespace
at the earlier stage. This saves time on
InitPublicNamespace and saves memory because
the libraries are linked before zygote fork.

Bug: http://b/26409579
Change-Id: I59153a4180b930f31b542d8d2cb17b5d63c36774
(cherry picked from commit d68c8e9f)
parent 71862501
Loading
Loading
Loading
Loading
+9 −6
Original line number Diff line number Diff line
@@ -57,7 +57,9 @@ static const char* kPublicNativeLibraries = "libandroid.so:"

class LibraryNamespaces {
 public:
  LibraryNamespaces() : initialized_(false) { }
  LibraryNamespaces() : initialized_(false) {
    PreloadPublicLibraries();
  }

  android_namespace_t* GetOrCreate(JNIEnv* env, jobject class_loader,
                                   bool is_shared,
@@ -103,15 +105,16 @@ class LibraryNamespaces {
  }

 private:
  bool InitPublicNamespace(const char* library_path) {
    // Make sure all the public libraries are loaded
  void PreloadPublicLibraries() {
    // android_init_namespaces() expects all the public libraries
    // to be loaded so that they can be found by soname alone.
    std::vector<std::string> sonames = android::base::Split(kPublicNativeLibraries, ":");
    for (const auto& soname : sonames) {
      if (dlopen(soname.c_str(), RTLD_NOW | RTLD_NODELETE) == nullptr) {
        return false;
      dlopen(soname.c_str(), RTLD_NOW | RTLD_NODELETE);
    }
  }

  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.
    initialized_ = android_init_namespaces(kPublicNativeLibraries, library_path);