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

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

Issue 643803003: Add UMA for testing whether device supports memory mapping APK files with executable permissions. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: UMA update for review feedback Created 6 years, 2 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/at_exit.h" 9 #include "base/at_exit.h"
10 #include "base/metrics/histogram.h" 10 #include "base/metrics/histogram.h"
(...skipping 28 matching lines...) Expand all
39 39
40 // Low-memory browser loads at fixed address, success or fail. 40 // Low-memory browser loads at fixed address, success or fail.
41 LOW_MEMORY_LFA_SUCCESS = 1, 41 LOW_MEMORY_LFA_SUCCESS = 1,
42 LOW_MEMORY_LFA_BACKOFF_USED = 2, 42 LOW_MEMORY_LFA_BACKOFF_USED = 2,
43 43
44 MAX_BROWSER_HISTOGRAM_CODE = 3, 44 MAX_BROWSER_HISTOGRAM_CODE = 3,
45 }; 45 };
46 46
47 RendererHistogramCode g_renderer_histogram_code = NO_PENDING_HISTOGRAM_CODE; 47 RendererHistogramCode g_renderer_histogram_code = NO_PENDING_HISTOGRAM_CODE;
48 48
49 enum LibraryLoadFromApkSupportCode {
50 // The device's support for loading a library directly from the APK file.
51 NOT_SUPPORTED = 0,
52 SUPPORTED = 1,
53
54 MAX_LIBRARY_LOAD_FROM_APK_SUPPORT_CODE = 2,
55 };
56
49 } // namespace 57 } // namespace
50 58
51 static void RegisterChromiumAndroidLinkerRendererHistogram( 59 static void RegisterChromiumAndroidLinkerRendererHistogram(
52 JNIEnv* env, 60 JNIEnv* env,
53 jclass clazz, 61 jclass clazz,
54 jboolean requested_shared_relro, 62 jboolean requested_shared_relro,
55 jboolean load_at_fixed_address_failed) { 63 jboolean load_at_fixed_address_failed) {
56 // Note a pending histogram value for later recording. 64 // Note a pending histogram value for later recording.
57 if (requested_shared_relro) { 65 if (requested_shared_relro) {
58 g_renderer_histogram_code = load_at_fixed_address_failed 66 g_renderer_histogram_code = load_at_fixed_address_failed
(...skipping 10 matching lines...) Expand all
69 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.RendererStates", 77 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.RendererStates",
70 g_renderer_histogram_code, 78 g_renderer_histogram_code,
71 MAX_RENDERER_HISTOGRAM_CODE); 79 MAX_RENDERER_HISTOGRAM_CODE);
72 g_renderer_histogram_code = NO_PENDING_HISTOGRAM_CODE; 80 g_renderer_histogram_code = NO_PENDING_HISTOGRAM_CODE;
73 } 81 }
74 82
75 static void RecordChromiumAndroidLinkerBrowserHistogram( 83 static void RecordChromiumAndroidLinkerBrowserHistogram(
76 JNIEnv* env, 84 JNIEnv* env,
77 jclass clazz, 85 jclass clazz,
78 jboolean is_using_browser_shared_relros, 86 jboolean is_using_browser_shared_relros,
79 jboolean load_at_fixed_address_failed) { 87 jboolean load_at_fixed_address_failed,
88 jboolean library_load_from_apk_supported) {
80 // For low-memory devices, record whether or not we successfully loaded the 89 // For low-memory devices, record whether or not we successfully loaded the
81 // browser at a fixed address. Otherwise just record a normal invocation. 90 // browser at a fixed address. Otherwise just record a normal invocation.
82 BrowserHistogramCode histogram_code; 91 BrowserHistogramCode histogram_code;
83 if (is_using_browser_shared_relros) { 92 if (is_using_browser_shared_relros) {
84 histogram_code = load_at_fixed_address_failed 93 histogram_code = load_at_fixed_address_failed
85 ? LOW_MEMORY_LFA_BACKOFF_USED : LOW_MEMORY_LFA_SUCCESS; 94 ? LOW_MEMORY_LFA_BACKOFF_USED : LOW_MEMORY_LFA_SUCCESS;
86 } else { 95 } else {
87 histogram_code = NORMAL_LRA_SUCCESS; 96 histogram_code = NORMAL_LRA_SUCCESS;
88 } 97 }
89 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.BrowserStates", 98 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.BrowserStates",
90 histogram_code, 99 histogram_code,
91 MAX_BROWSER_HISTOGRAM_CODE); 100 MAX_BROWSER_HISTOGRAM_CODE);
101
rmcilroy 2014/10/13 11:08:19 nit - remove newline
petrcermak 2014/10/13 12:12:46 I would prefer to keep it there to make it clear t
102 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.LibraryLoadFromApkSupported",
103 library_load_from_apk_supported ?
104 SUPPORTED : NOT_SUPPORTED,
105 MAX_LIBRARY_LOAD_FROM_APK_SUPPORT_CODE);
92 } 106 }
93 107
94 void SetLibraryLoadedHook(LibraryLoadedHook* func) { 108 void SetLibraryLoadedHook(LibraryLoadedHook* func) {
95 g_registration_callback = func; 109 g_registration_callback = func;
96 } 110 }
97 111
98 static void InitCommandLine(JNIEnv* env, jclass clazz, 112 static void InitCommandLine(JNIEnv* env, jclass clazz,
99 jobjectArray init_command_line) { 113 jobjectArray init_command_line) {
100 InitNativeCommandLineFromJavaArray(env, init_command_line); 114 InitNativeCommandLineFromJavaArray(env, init_command_line);
101 } 115 }
(...skipping 26 matching lines...) Expand all
128 jstring GetVersionNumber(JNIEnv* env, jclass clazz) { 142 jstring GetVersionNumber(JNIEnv* env, jclass clazz) {
129 return ConvertUTF8ToJavaString(env, g_library_version_number).Release(); 143 return ConvertUTF8ToJavaString(env, g_library_version_number).Release();
130 } 144 }
131 145
132 static void RecordNativeLibraryHack(JNIEnv*, jclass, jboolean usedHack) { 146 static void RecordNativeLibraryHack(JNIEnv*, jclass, jboolean usedHack) {
133 UMA_HISTOGRAM_BOOLEAN("LibraryLoader.NativeLibraryHack", usedHack); 147 UMA_HISTOGRAM_BOOLEAN("LibraryLoader.NativeLibraryHack", usedHack);
134 } 148 }
135 149
136 } // namespace android 150 } // namespace android
137 } // namespace base 151 } // namespace base
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698