| // Copyright 2015 The Chromium Authors | 
 | // 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 <jni.h> | 
 | #include <stdint.h> | 
 |  | 
 | #include "base/android/library_loader/anchor_functions_buildflags.h" | 
 | #include "base/base_export.h" | 
 |  | 
 | #if BUILDFLAG(SUPPORTS_CODE_ORDERING) | 
 |  | 
 | namespace base { | 
 | namespace android { | 
 |  | 
 | // Prefetches the native library. This may be 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. | 
 | // | 
 | // An alternative in-process madvise prefetch can be used if the | 
 | // "LibraryPrefetcherMadvise" feature is enabled. | 
 | class BASE_EXPORT NativeLibraryPrefetcher { | 
 |  public: | 
 |   NativeLibraryPrefetcher() = delete; | 
 |   NativeLibraryPrefetcher(const NativeLibraryPrefetcher&) = delete; | 
 |   NativeLibraryPrefetcher& operator=(const NativeLibraryPrefetcher&) = delete; | 
 |  | 
 |   // Finds the executable code range and prefetches it. It fetches any ordered | 
 |   // section first. | 
 |   static void PrefetchNativeLibrary(); | 
 | }; | 
 |  | 
 | }  // namespace android | 
 | }  // namespace base | 
 |  | 
 | #endif  // BUILDFLAG(SUPPORTS_CODE_ORDERING) | 
 |  | 
 | #endif  // BASE_ANDROID_LIBRARY_LOADER_LIBRARY_PREFETCHER_H_ |