OLD | NEW |
---|---|
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 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
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 { | 49 enum LibraryLoadFromApkSupportCode { |
50 // The device's support for loading a library directly from the APK file. | 50 // The device's support for loading a library directly from the APK file. |
51 NOT_SUPPORTED = 0, | 51 NOT_SUPPORTED = 0, |
52 SUPPORTED = 1, | 52 SUPPORTED = 1, |
53 | 53 |
54 MAX_LIBRARY_LOAD_FROM_APK_SUPPORT_CODE = 2, | 54 // The loader was unable to determine whether the funcionality is supported. |
Ilya Sherman
2014/10/16 19:00:30
nit: "funcionality" -> "functionality"
petrcermak
2014/10/17 14:51:28
Done.
| |
55 UNKNOWN = 2, | |
Ilya Sherman
2014/10/16 19:00:30
nit: I'd recommend moving this to be the first ite
petrcermak
2014/10/17 14:51:28
Done. It is very likely that more values will inde
| |
56 | |
57 MAX_LIBRARY_LOAD_FROM_APK_SUPPORT_CODE = 3, | |
55 }; | 58 }; |
picksi1
2014/10/17 08:23:24
You should probably have the enums named the same
petrcermak
2014/10/17 14:51:28
Done.
| |
56 | 59 |
57 } // namespace | 60 } // namespace |
58 | 61 |
59 static void RegisterChromiumAndroidLinkerRendererHistogram( | 62 static void RegisterChromiumAndroidLinkerRendererHistogram( |
60 JNIEnv* env, | 63 JNIEnv* env, |
61 jclass clazz, | 64 jclass clazz, |
62 jboolean requested_shared_relro, | 65 jboolean requested_shared_relro, |
63 jboolean load_at_fixed_address_failed) { | 66 jboolean load_at_fixed_address_failed) { |
64 // Note a pending histogram value for later recording. | 67 // Note a pending histogram value for later recording. |
65 if (requested_shared_relro) { | 68 if (requested_shared_relro) { |
(...skipping 12 matching lines...) Expand all Loading... | |
78 g_renderer_histogram_code, | 81 g_renderer_histogram_code, |
79 MAX_RENDERER_HISTOGRAM_CODE); | 82 MAX_RENDERER_HISTOGRAM_CODE); |
80 g_renderer_histogram_code = NO_PENDING_HISTOGRAM_CODE; | 83 g_renderer_histogram_code = NO_PENDING_HISTOGRAM_CODE; |
81 } | 84 } |
82 | 85 |
83 static void RecordChromiumAndroidLinkerBrowserHistogram( | 86 static void RecordChromiumAndroidLinkerBrowserHistogram( |
84 JNIEnv* env, | 87 JNIEnv* env, |
85 jclass clazz, | 88 jclass clazz, |
86 jboolean is_using_browser_shared_relros, | 89 jboolean is_using_browser_shared_relros, |
87 jboolean load_at_fixed_address_failed, | 90 jboolean load_at_fixed_address_failed, |
88 jboolean library_load_from_apk_supported) { | 91 jint library_load_from_apk_support) { |
89 // For low-memory devices, record whether or not we successfully loaded the | 92 // For low-memory devices, record whether or not we successfully loaded the |
90 // browser at a fixed address. Otherwise just record a normal invocation. | 93 // browser at a fixed address. Otherwise just record a normal invocation. |
91 BrowserHistogramCode histogram_code; | 94 BrowserHistogramCode histogram_code; |
92 if (is_using_browser_shared_relros) { | 95 if (is_using_browser_shared_relros) { |
93 histogram_code = load_at_fixed_address_failed | 96 histogram_code = load_at_fixed_address_failed |
94 ? LOW_MEMORY_LFA_BACKOFF_USED : LOW_MEMORY_LFA_SUCCESS; | 97 ? LOW_MEMORY_LFA_BACKOFF_USED : LOW_MEMORY_LFA_SUCCESS; |
95 } else { | 98 } else { |
96 histogram_code = NORMAL_LRA_SUCCESS; | 99 histogram_code = NORMAL_LRA_SUCCESS; |
97 } | 100 } |
98 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.BrowserStates", | 101 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.BrowserStates", |
99 histogram_code, | 102 histogram_code, |
100 MAX_BROWSER_HISTOGRAM_CODE); | 103 MAX_BROWSER_HISTOGRAM_CODE); |
101 | 104 |
102 // Record whether the device supports loading a library directly from the APK | 105 // Record the device support for loading a library directly from the APK file. |
103 // file. | 106 if (library_load_from_apk_support < 0 || |
104 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.LibraryLoadFromApkSupported", | 107 library_load_from_apk_support >= MAX_LIBRARY_LOAD_FROM_APK_SUPPORT_CODE) { |
105 library_load_from_apk_supported ? | 108 library_load_from_apk_support = UNKNOWN; |
picksi1
2014/10/17 08:23:24
Definitely replace the '0' with NOT_SUPPORTED enum
rmcilroy
2014/10/17 09:12:59
I actually think that might be more error prone si
picksi1
2014/10/17 09:23:51
If we ditched the default entry in the case statem
rmcilroy
2014/10/17 09:54:45
+1 this sounds good.
petrcermak
2014/10/17 14:51:28
Done.
petrcermak
2014/10/17 14:51:28
After a discussion with simonb, we concluded that
| |
106 SUPPORTED : NOT_SUPPORTED, | 109 } |
110 UMA_HISTOGRAM_ENUMERATION("ChromiumAndroidLinker.LibraryLoadFromApkSupport", | |
111 library_load_from_apk_support, | |
107 MAX_LIBRARY_LOAD_FROM_APK_SUPPORT_CODE); | 112 MAX_LIBRARY_LOAD_FROM_APK_SUPPORT_CODE); |
108 } | 113 } |
109 | 114 |
110 void SetLibraryLoadedHook(LibraryLoadedHook* func) { | 115 void SetLibraryLoadedHook(LibraryLoadedHook* func) { |
111 g_registration_callback = func; | 116 g_registration_callback = func; |
112 } | 117 } |
113 | 118 |
114 static void InitCommandLine(JNIEnv* env, jclass clazz, | 119 static void InitCommandLine(JNIEnv* env, jclass clazz, |
115 jobjectArray init_command_line) { | 120 jobjectArray init_command_line) { |
116 InitNativeCommandLineFromJavaArray(env, init_command_line); | 121 InitNativeCommandLineFromJavaArray(env, init_command_line); |
(...skipping 27 matching lines...) Expand all Loading... | |
144 jstring GetVersionNumber(JNIEnv* env, jclass clazz) { | 149 jstring GetVersionNumber(JNIEnv* env, jclass clazz) { |
145 return ConvertUTF8ToJavaString(env, g_library_version_number).Release(); | 150 return ConvertUTF8ToJavaString(env, g_library_version_number).Release(); |
146 } | 151 } |
147 | 152 |
148 static void RecordNativeLibraryHack(JNIEnv*, jclass, jboolean usedHack) { | 153 static void RecordNativeLibraryHack(JNIEnv*, jclass, jboolean usedHack) { |
149 UMA_HISTOGRAM_BOOLEAN("LibraryLoader.NativeLibraryHack", usedHack); | 154 UMA_HISTOGRAM_BOOLEAN("LibraryLoader.NativeLibraryHack", usedHack); |
150 } | 155 } |
151 | 156 |
152 } // namespace android | 157 } // namespace android |
153 } // namespace base | 158 } // namespace base |
OLD | NEW |