// Copyright 2015 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef BASE_ANDROID_LIBRARY_LOADER_LIBRARY_PREFETCHER_H_ #define BASE_ANDROID_LIBRARY_LOADER_LIBRARY_PREFETCHER_H_ #include #include #include #include "base/android/library_loader/anchor_functions_buildflags.h" #include "base/base_export.h" #include "base/gtest_prod_util.h" #include "base/macros.h" #if BUILDFLAG(SUPPORTS_CODE_ORDERING) namespace base { namespace android { // Forks and waits for a process prefetching the native library. This is done in // a forked process for the following reasons: // - Isolating the main process from mistakes in getting the address range, only // crashing the forked process in case of mistake. // - Not inflating the memory used by the main process uselessly, which could // increase its likelihood to be killed. // The forked process has background priority and, since it is not declared to // the Android runtime, can be killed at any time, which is not an issue here. class BASE_EXPORT NativeLibraryPrefetcher { public: // Finds the executable code range, forks a low priority process pre-fetching // it wait()s for the process to exit or die. If ordered_only is true, only // the ordered section is prefetched. See GetOrdrderedTextRange() in // library_prefetcher.cc. static void ForkAndPrefetchNativeLibrary(bool ordered_only); // Returns the percentage of the native library code currently resident in // memory, or -1 in case of error. static int PercentageOfResidentNativeLibraryCode(); // Collects residency for the native library executable multiple times, then // dumps it to disk. static void PeriodicallyCollectResidency(); // Calls madvise() on the native library executable, using orderfile // information to decide how to advise each part of the library. static void MadviseForOrderfile(); // Calls madvise() on the native library executable so that residency // collection is accurate. static void MadviseForResidencyCollection(); private: // Returns the percentage of [start, end] currently resident in // memory, or -1 in case of error. static int PercentageOfResidentCode(size_t start, size_t end); FRIEND_TEST_ALL_PREFIXES(NativeLibraryPrefetcherTest, TestPercentageOfResidentCode); DISALLOW_IMPLICIT_CONSTRUCTORS(NativeLibraryPrefetcher); }; } // namespace android } // namespace base #endif // BUILDFLAG(SUPPORTS_CODE_ORDERING) #endif // BASE_ANDROID_LIBRARY_LOADER_LIBRARY_PREFETCHER_H_