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/record_histogram.h" | 5 #include "base/android/record_histogram.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 | 8 |
9 #include "base/android/jni_android.h" | 9 #include "base/android/jni_android.h" |
10 #include "base/android/jni_string.h" | 10 #include "base/android/jni_string.h" |
11 #include "base/lazy_instance.h" | 11 #include "base/lazy_instance.h" |
12 #include "base/metrics/histogram.h" | 12 #include "base/metrics/histogram.h" |
| 13 #include "base/metrics/sparse_histogram.h" |
13 #include "base/metrics/statistics_recorder.h" | 14 #include "base/metrics/statistics_recorder.h" |
14 #include "base/synchronization/lock.h" | 15 #include "base/synchronization/lock.h" |
15 #include "base/time/time.h" | 16 #include "base/time/time.h" |
16 #include "jni/RecordHistogram_jni.h" | 17 #include "jni/RecordHistogram_jni.h" |
17 | 18 |
18 namespace base { | 19 namespace base { |
19 namespace android { | 20 namespace android { |
20 namespace { | 21 namespace { |
21 | 22 |
22 // Simple thread-safe wrapper for caching histograms. This avoids | 23 // Simple thread-safe wrapper for caching histograms. This avoids |
(...skipping 30 matching lines...) Expand all Loading... |
53 return histogram; | 54 return histogram; |
54 } | 55 } |
55 | 56 |
56 std::string histogram_name = ConvertJavaStringToUTF8(env, j_histogram_name); | 57 std::string histogram_name = ConvertJavaStringToUTF8(env, j_histogram_name); |
57 histogram = | 58 histogram = |
58 LinearHistogram::FactoryGet(histogram_name, 1, boundary, boundary + 1, | 59 LinearHistogram::FactoryGet(histogram_name, 1, boundary, boundary + 1, |
59 HistogramBase::kUmaTargetedHistogramFlag); | 60 HistogramBase::kUmaTargetedHistogramFlag); |
60 return InsertLocked(j_histogram_key, histogram); | 61 return InsertLocked(j_histogram_key, histogram); |
61 } | 62 } |
62 | 63 |
63 HistogramBase* CountHistogram(JNIEnv* env, | 64 HistogramBase* CustomCountHistogram(JNIEnv* env, |
64 jstring j_histogram_name, | 65 jstring j_histogram_name, |
65 jint j_histogram_key) { | 66 jint j_histogram_key, |
66 // These values are based on the hard-coded constants in the | 67 jint j_min, |
67 // UMA_HISTOGRAM_COUNTS macro from base/metrics/histogram_macros.h. | 68 jint j_max, |
68 const int histogram_min = 1; | 69 jint j_num_buckets) { |
69 const int histogram_max = 1000000; | |
70 const int histogram_num_buckets = 50; | |
71 | |
72 DCHECK(j_histogram_name); | 70 DCHECK(j_histogram_name); |
73 DCHECK(j_histogram_key); | 71 DCHECK(j_histogram_key); |
| 72 int64 min = static_cast<int64>(j_min); |
| 73 int64 max = static_cast<int64>(j_max); |
| 74 int num_buckets = static_cast<int>(j_num_buckets); |
74 HistogramBase* histogram = FindLocked(j_histogram_key); | 75 HistogramBase* histogram = FindLocked(j_histogram_key); |
75 if (histogram) { | 76 if (histogram) { |
76 DCHECK(histogram->HasConstructionArguments(histogram_min, histogram_max, | 77 DCHECK(histogram->HasConstructionArguments(min, max, num_buckets)); |
77 histogram_num_buckets)); | |
78 return histogram; | 78 return histogram; |
79 } | 79 } |
80 | 80 |
81 std::string histogram_name = ConvertJavaStringToUTF8(env, j_histogram_name); | 81 std::string histogram_name = ConvertJavaStringToUTF8(env, j_histogram_name); |
82 histogram = Histogram::FactoryGet(histogram_name, histogram_min, | 82 histogram = |
83 histogram_max, histogram_num_buckets, | 83 Histogram::FactoryGet(histogram_name, min, max, num_buckets, |
84 HistogramBase::kUmaTargetedHistogramFlag); | 84 HistogramBase::kUmaTargetedHistogramFlag); |
85 return InsertLocked(j_histogram_key, histogram); | 85 return InsertLocked(j_histogram_key, histogram); |
86 } | 86 } |
87 | 87 |
| 88 HistogramBase* SparseHistogram(JNIEnv* env, |
| 89 jstring j_histogram_name, |
| 90 jint j_histogram_key) { |
| 91 DCHECK(j_histogram_name); |
| 92 DCHECK(j_histogram_key); |
| 93 HistogramBase* histogram = FindLocked(j_histogram_key); |
| 94 if (histogram) |
| 95 return histogram; |
| 96 |
| 97 std::string histogram_name = ConvertJavaStringToUTF8(env, j_histogram_name); |
| 98 histogram = SparseHistogram::FactoryGet( |
| 99 histogram_name, HistogramBase::kUmaTargetedHistogramFlag); |
| 100 return InsertLocked(j_histogram_key, histogram); |
| 101 } |
| 102 |
88 HistogramBase* CustomTimesHistogram(JNIEnv* env, | 103 HistogramBase* CustomTimesHistogram(JNIEnv* env, |
89 jstring j_histogram_name, | 104 jstring j_histogram_name, |
90 jint j_histogram_key, | 105 jint j_histogram_key, |
91 jlong j_min, | 106 jlong j_min, |
92 jlong j_max, | 107 jlong j_max, |
93 jint j_bucket_count) { | 108 jint j_bucket_count) { |
94 DCHECK(j_histogram_name); | 109 DCHECK(j_histogram_name); |
95 DCHECK(j_histogram_key); | 110 DCHECK(j_histogram_key); |
96 HistogramBase* histogram = FindLocked(j_histogram_key); | 111 HistogramBase* histogram = FindLocked(j_histogram_key); |
97 int64 min = static_cast<int64>(j_min); | 112 int64 min = static_cast<int64>(j_min); |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
151 jint j_histogram_key, | 166 jint j_histogram_key, |
152 jint j_sample, | 167 jint j_sample, |
153 jint j_boundary) { | 168 jint j_boundary) { |
154 int sample = static_cast<int>(j_sample); | 169 int sample = static_cast<int>(j_sample); |
155 | 170 |
156 g_histograms.Get() | 171 g_histograms.Get() |
157 .EnumeratedHistogram(env, j_histogram_name, j_histogram_key, j_boundary) | 172 .EnumeratedHistogram(env, j_histogram_name, j_histogram_key, j_boundary) |
158 ->Add(sample); | 173 ->Add(sample); |
159 } | 174 } |
160 | 175 |
161 void RecordCountHistogram(JNIEnv* env, | 176 void RecordCustomCountHistogram(JNIEnv* env, |
162 jclass clazz, | 177 jclass clazz, |
163 jstring j_histogram_name, | 178 jstring j_histogram_name, |
164 jint j_histogram_key, | 179 jint j_histogram_key, |
165 jint j_sample) { | 180 jint j_sample, |
| 181 jint j_min, |
| 182 jint j_max, |
| 183 jint j_num_buckets) { |
166 int sample = static_cast<int>(j_sample); | 184 int sample = static_cast<int>(j_sample); |
167 | 185 |
168 g_histograms.Get() | 186 g_histograms.Get() |
169 .CountHistogram(env, j_histogram_name, j_histogram_key) | 187 .CustomCountHistogram(env, j_histogram_name, j_histogram_key, j_min, |
| 188 j_max, j_num_buckets) |
170 ->Add(sample); | 189 ->Add(sample); |
171 } | 190 } |
172 | 191 |
| 192 void RecordSparseHistogram(JNIEnv* env, |
| 193 jclass clazz, |
| 194 jstring j_histogram_name, |
| 195 jint j_histogram_key, |
| 196 jint j_sample) { |
| 197 int sample = static_cast<int>(j_sample); |
| 198 g_histograms.Get() |
| 199 .SparseHistogram(env, j_histogram_name, j_histogram_key) |
| 200 ->Add(sample); |
| 201 } |
| 202 |
173 void RecordCustomTimesHistogramMilliseconds(JNIEnv* env, | 203 void RecordCustomTimesHistogramMilliseconds(JNIEnv* env, |
174 jclass clazz, | 204 jclass clazz, |
175 jstring j_histogram_name, | 205 jstring j_histogram_name, |
176 jint j_histogram_key, | 206 jint j_histogram_key, |
177 jlong j_duration, | 207 jlong j_duration, |
178 jlong j_min, | 208 jlong j_min, |
179 jlong j_max, | 209 jlong j_max, |
180 jint j_num_buckets) { | 210 jint j_num_buckets) { |
181 g_histograms.Get() | 211 g_histograms.Get() |
182 .CustomTimesHistogram(env, j_histogram_name, j_histogram_key, j_min, | 212 .CustomTimesHistogram(env, j_histogram_name, j_histogram_key, j_min, |
(...skipping 23 matching lines...) Expand all Loading... |
206 scoped_ptr<HistogramSamples> samples = histogram->SnapshotSamples(); | 236 scoped_ptr<HistogramSamples> samples = histogram->SnapshotSamples(); |
207 return samples->GetCount(static_cast<int>(sample)); | 237 return samples->GetCount(static_cast<int>(sample)); |
208 } | 238 } |
209 | 239 |
210 bool RegisterRecordHistogram(JNIEnv* env) { | 240 bool RegisterRecordHistogram(JNIEnv* env) { |
211 return RegisterNativesImpl(env); | 241 return RegisterNativesImpl(env); |
212 } | 242 } |
213 | 243 |
214 } // namespace android | 244 } // namespace android |
215 } // namespace base | 245 } // namespace base |
OLD | NEW |