Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(547)

Side by Side Diff: base/android/library_loader/library_loader_hooks.cc

Issue 1312153003: jni_generator: Pass object parameters as JavaParamRef. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/android/library_loader/library_loader_hooks.h" 5 #include "base/android/library_loader/library_loader_hooks.h"
6 6
7 #include "base/android/command_line_android.h" 7 #include "base/android/command_line_android.h"
8 #include "base/android/jni_string.h" 8 #include "base/android/jni_string.h"
9 #include "base/android/library_loader/library_load_from_apk_status_codes.h" 9 #include "base/android/library_loader/library_load_from_apk_status_codes.h"
10 #include "base/android/library_loader/library_prefetcher.h" 10 #include "base/android/library_loader/library_prefetcher.h"
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
50 50
51 // The amount of time, in milliseconds, that it took to load the shared 51 // The amount of time, in milliseconds, that it took to load the shared
52 // libraries in the renderer. Set in 52 // libraries in the renderer. Set in
53 // RegisterChromiumAndroidLinkerRendererHistogram. 53 // RegisterChromiumAndroidLinkerRendererHistogram.
54 long g_renderer_library_load_time_ms = 0; 54 long g_renderer_library_load_time_ms = 0;
55 55
56 } // namespace 56 } // namespace
57 57
58 static void RegisterChromiumAndroidLinkerRendererHistogram( 58 static void RegisterChromiumAndroidLinkerRendererHistogram(
59 JNIEnv* env, 59 JNIEnv* env,
60 jobject jcaller, 60 const JavaParamRef<jobject>& jcaller,
61 jboolean requested_shared_relro, 61 jboolean requested_shared_relro,
62 jboolean load_at_fixed_address_failed, 62 jboolean load_at_fixed_address_failed,
63 jlong library_load_time_ms) { 63 jlong library_load_time_ms) {
64 // Note a pending histogram value for later recording. 64 // Note a pending histogram value for later recording.
65 if (requested_shared_relro) { 65 if (requested_shared_relro) {
66 g_renderer_histogram_code = load_at_fixed_address_failed 66 g_renderer_histogram_code = load_at_fixed_address_failed
67 ? LFA_BACKOFF_USED : LFA_SUCCESS; 67 ? LFA_BACKOFF_USED : LFA_SUCCESS;
68 } else { 68 } else {
69 g_renderer_histogram_code = LFA_NOT_ATTEMPTED; 69 g_renderer_histogram_code = LFA_NOT_ATTEMPTED;
70 } 70 }
(...skipping 10 matching lines...) Expand all
81 MAX_RENDERER_HISTOGRAM_CODE); 81 MAX_RENDERER_HISTOGRAM_CODE);
82 g_renderer_histogram_code = NO_PENDING_HISTOGRAM_CODE; 82 g_renderer_histogram_code = NO_PENDING_HISTOGRAM_CODE;
83 83
84 // Record how long it took to load the shared libraries. 84 // Record how long it took to load the shared libraries.
85 UMA_HISTOGRAM_TIMES("ChromiumAndroidLinker.RendererLoadTime", 85 UMA_HISTOGRAM_TIMES("ChromiumAndroidLinker.RendererLoadTime",
86 base::TimeDelta::FromMilliseconds(g_renderer_library_load_time_ms)); 86 base::TimeDelta::FromMilliseconds(g_renderer_library_load_time_ms));
87 } 87 }
88 88
89 static void RecordChromiumAndroidLinkerBrowserHistogram( 89 static void RecordChromiumAndroidLinkerBrowserHistogram(
90 JNIEnv* env, 90 JNIEnv* env,
91 jobject jcaller, 91 const JavaParamRef<jobject>& jcaller,
92 jboolean is_using_browser_shared_relros, 92 jboolean is_using_browser_shared_relros,
93 jboolean load_at_fixed_address_failed, 93 jboolean load_at_fixed_address_failed,
94 jint library_load_from_apk_status, 94 jint library_load_from_apk_status,
95 jlong library_load_time_ms) { 95 jlong library_load_time_ms) {
96 // For low-memory devices, record whether or not we successfully loaded the 96 // For low-memory devices, record whether or not we successfully loaded the
97 // browser at a fixed address. Otherwise just record a normal invocation. 97 // browser at a fixed address. Otherwise just record a normal invocation.
98 BrowserHistogramCode histogram_code; 98 BrowserHistogramCode histogram_code;
99 if (is_using_browser_shared_relros) { 99 if (is_using_browser_shared_relros) {
100 histogram_code = load_at_fixed_address_failed 100 histogram_code = load_at_fixed_address_failed
101 ? LOW_MEMORY_LFA_BACKOFF_USED : LOW_MEMORY_LFA_SUCCESS; 101 ? LOW_MEMORY_LFA_BACKOFF_USED : LOW_MEMORY_LFA_SUCCESS;
(...skipping 11 matching lines...) Expand all
113 113
114 // Record how long it took to load the shared libraries. 114 // Record how long it took to load the shared libraries.
115 UMA_HISTOGRAM_TIMES("ChromiumAndroidLinker.BrowserLoadTime", 115 UMA_HISTOGRAM_TIMES("ChromiumAndroidLinker.BrowserLoadTime",
116 base::TimeDelta::FromMilliseconds(library_load_time_ms)); 116 base::TimeDelta::FromMilliseconds(library_load_time_ms));
117 } 117 }
118 118
119 void SetLibraryLoadedHook(LibraryLoadedHook* func) { 119 void SetLibraryLoadedHook(LibraryLoadedHook* func) {
120 g_registration_callback = func; 120 g_registration_callback = func;
121 } 121 }
122 122
123 static void InitCommandLine(JNIEnv* env, 123 static void InitCommandLine(
124 jobject jcaller, 124 JNIEnv* env,
125 jobjectArray init_command_line) { 125 const JavaParamRef<jobject>& jcaller,
126 const JavaParamRef<jobjectArray>& init_command_line) {
126 InitNativeCommandLineFromJavaArray(env, init_command_line); 127 InitNativeCommandLineFromJavaArray(env, init_command_line);
127 } 128 }
128 129
129 static jboolean LibraryLoaded(JNIEnv* env, jobject jcaller) { 130 static jboolean LibraryLoaded(JNIEnv* env,
131 const JavaParamRef<jobject>& jcaller) {
130 if (g_registration_callback == NULL) { 132 if (g_registration_callback == NULL) {
131 return true; 133 return true;
132 } 134 }
133 return g_registration_callback(env, NULL); 135 return g_registration_callback(env, NULL);
134 } 136 }
135 137
136 void LibraryLoaderExitHook() { 138 void LibraryLoaderExitHook() {
137 if (g_at_exit_manager) { 139 if (g_at_exit_manager) {
138 delete g_at_exit_manager; 140 delete g_at_exit_manager;
139 g_at_exit_manager = NULL; 141 g_at_exit_manager = NULL;
140 } 142 }
141 } 143 }
142 144
143 static jboolean ForkAndPrefetchNativeLibrary(JNIEnv* env, jclass clazz) { 145 static jboolean ForkAndPrefetchNativeLibrary(
146 JNIEnv* env,
147 const JavaParamRef<jclass>& clazz) {
144 return NativeLibraryPrefetcher::ForkAndPrefetchNativeLibrary(); 148 return NativeLibraryPrefetcher::ForkAndPrefetchNativeLibrary();
145 } 149 }
146 150
147 bool RegisterLibraryLoaderEntryHook(JNIEnv* env) { 151 bool RegisterLibraryLoaderEntryHook(JNIEnv* env) {
148 return RegisterNativesImpl(env); 152 return RegisterNativesImpl(env);
149 } 153 }
150 154
151 void SetVersionNumber(const char* version_number) { 155 void SetVersionNumber(const char* version_number) {
152 g_library_version_number = strdup(version_number); 156 g_library_version_number = strdup(version_number);
153 } 157 }
154 158
155 ScopedJavaLocalRef<jstring> GetVersionNumber(JNIEnv* env, jobject jcaller) { 159 ScopedJavaLocalRef<jstring> GetVersionNumber(
160 JNIEnv* env,
161 const JavaParamRef<jobject>& jcaller) {
156 return ConvertUTF8ToJavaString(env, g_library_version_number); 162 return ConvertUTF8ToJavaString(env, g_library_version_number);
157 } 163 }
158 164
159 LibraryProcessType GetLibraryProcessType(JNIEnv* env) { 165 LibraryProcessType GetLibraryProcessType(JNIEnv* env) {
160 return static_cast<LibraryProcessType>( 166 return static_cast<LibraryProcessType>(
161 Java_LibraryLoader_getLibraryProcessType(env)); 167 Java_LibraryLoader_getLibraryProcessType(env));
162 } 168 }
163 169
164 void InitAtExitManager() { 170 void InitAtExitManager() {
165 g_at_exit_manager = new base::AtExitManager(); 171 g_at_exit_manager = new base::AtExitManager();
166 } 172 }
167 173
168 } // namespace android 174 } // namespace android
169 } // namespace base 175 } // namespace base
OLDNEW
« no previous file with comments | « base/android/jni_generator/testSingleJNIAdditionalImport.golden ('k') | base/android/memory_pressure_listener_android.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698