blob: 5d0f3d1db8c9b5bab935e6a7caea3e4a875949f4 [file] [log] [blame]
Yao Chenab273e22017-09-06 12:53:50 -07001/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Stefan Lafoncdb1a0e2017-09-27 20:24:15 -070016
Yao Chenab273e22017-09-06 12:53:50 -070017syntax = "proto2";
18
19package android.os.statsd;
20
Yao Chenab273e22017-09-06 12:53:50 -070021option java_package = "com.android.os";
22option java_outer_classname = "StatsLog";
23
Joe Onorato62c220b2017-11-18 20:32:56 -080024import "frameworks/base/cmds/statsd/src/atoms.proto";
Yao Chenab273e22017-09-06 12:53:50 -070025
Yangster-mac20877162017-12-22 17:19:39 -080026message DimensionsValue {
27 optional int32 field = 1;
Yao Chenab273e22017-09-06 12:53:50 -070028
yro00698da2017-09-15 10:06:40 -070029 oneof value {
30 string value_str = 2;
Chenjie Yud9dfda72017-12-11 17:41:20 -080031 int32 value_int = 3;
32 int64 value_long = 4;
33 bool value_bool = 5;
34 float value_float = 6;
Yangster-mac20877162017-12-22 17:19:39 -080035 DimensionsValueTuple value_tuple = 7;
Yangster-mac9def8e32018-04-17 13:55:51 -070036 uint64 value_str_hash = 8;
Yao Chenab273e22017-09-06 12:53:50 -070037 }
Yao Chenab273e22017-09-06 12:53:50 -070038}
39
Yangster-mac20877162017-12-22 17:19:39 -080040message DimensionsValueTuple {
41 repeated DimensionsValue dimensions_value = 1;
42}
43
yro00698da2017-09-15 10:06:40 -070044message EventMetricData {
Yangster-mac330af582018-02-08 15:24:38 -080045 optional int64 elapsed_timestamp_nanos = 1;
yro00698da2017-09-15 10:06:40 -070046
Stefan Lafonae2df012017-11-14 09:17:21 -080047 optional Atom atom = 2;
Yangster-mac330af582018-02-08 15:24:38 -080048
Bookatzfe2dde82018-08-28 13:24:40 -070049 optional int64 wall_clock_timestamp_nanos = 3 [deprecated = true];
yro00698da2017-09-15 10:06:40 -070050}
51
52message CountBucketInfo {
Yangster-mac330af582018-02-08 15:24:38 -080053 optional int64 start_bucket_elapsed_nanos = 1;
yro00698da2017-09-15 10:06:40 -070054
Yangster-mac330af582018-02-08 15:24:38 -080055 optional int64 end_bucket_elapsed_nanos = 2;
yro00698da2017-09-15 10:06:40 -070056
57 optional int64 count = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -070058
59 optional int64 bucket_num = 4;
60
61 optional int64 start_bucket_elapsed_millis = 5;
62
63 optional int64 end_bucket_elapsed_millis = 6;
yro00698da2017-09-15 10:06:40 -070064}
65
66message CountMetricData {
Yangster-mac468ff042018-01-17 12:26:34 -080067 optional DimensionsValue dimensions_in_what = 1;
68
Yangster-mac16fc72f2018-01-18 13:18:01 -080069 optional DimensionsValue dimensions_in_condition = 2;
yro00698da2017-09-15 10:06:40 -070070
Yangster-mac16fc72f2018-01-18 13:18:01 -080071 repeated CountBucketInfo bucket_info = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -070072
73 repeated DimensionsValue dimension_leaf_values_in_what = 4;
74
75 repeated DimensionsValue dimension_leaf_values_in_condition = 5;
yro00698da2017-09-15 10:06:40 -070076}
77
Yao Chencaf339d2017-10-06 16:01:10 -070078message DurationBucketInfo {
Yangster-mac330af582018-02-08 15:24:38 -080079 optional int64 start_bucket_elapsed_nanos = 1;
Yao Chencaf339d2017-10-06 16:01:10 -070080
Yangster-mac330af582018-02-08 15:24:38 -080081 optional int64 end_bucket_elapsed_nanos = 2;
Yao Chencaf339d2017-10-06 16:01:10 -070082
83 optional int64 duration_nanos = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -070084
85 optional int64 bucket_num = 4;
86
87 optional int64 start_bucket_elapsed_millis = 5;
88
89 optional int64 end_bucket_elapsed_millis = 6;
Yao Chencaf339d2017-10-06 16:01:10 -070090}
91
92message DurationMetricData {
Yangster-mac468ff042018-01-17 12:26:34 -080093 optional DimensionsValue dimensions_in_what = 1;
94
Yangster-mac16fc72f2018-01-18 13:18:01 -080095 optional DimensionsValue dimensions_in_condition = 2;
Yao Chencaf339d2017-10-06 16:01:10 -070096
Yangster-mac16fc72f2018-01-18 13:18:01 -080097 repeated DurationBucketInfo bucket_info = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -070098
99 repeated DimensionsValue dimension_leaf_values_in_what = 4;
100
101 repeated DimensionsValue dimension_leaf_values_in_condition = 5;
Yao Chencaf339d2017-10-06 16:01:10 -0700102}
103
Yangsterfa28aec2017-10-30 10:29:52 -0700104message ValueBucketInfo {
Yangster-mac330af582018-02-08 15:24:38 -0800105 optional int64 start_bucket_elapsed_nanos = 1;
Yangsterfa28aec2017-10-30 10:29:52 -0700106
Yangster-mac330af582018-02-08 15:24:38 -0800107 optional int64 end_bucket_elapsed_nanos = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700108
Chenjie Yuc3f00772018-07-26 13:50:58 -0700109 optional int64 value = 3 [deprecated = true];
Chenjie Yua0f02242018-07-06 16:14:34 -0700110
Chenjie Yu32717c32018-10-20 23:54:48 -0700111 oneof single_value {
112 int64 value_long = 7 [deprecated = true];
Chenjie Yuc3f00772018-07-26 13:50:58 -0700113
Chenjie Yu32717c32018-10-20 23:54:48 -0700114 double value_double = 8 [deprecated = true];
Chenjie Yua0f02242018-07-06 16:14:34 -0700115 }
Yangster-mac9def8e32018-04-17 13:55:51 -0700116
Chenjie Yu32717c32018-10-20 23:54:48 -0700117 message Value {
118 optional int32 index = 1;
119 oneof value {
120 int64 value_long = 2;
121 double value_double = 3;
122 }
123 }
124
125 repeated Value values = 9;
126
Yangster-mac9def8e32018-04-17 13:55:51 -0700127 optional int64 bucket_num = 4;
128
129 optional int64 start_bucket_elapsed_millis = 5;
130
131 optional int64 end_bucket_elapsed_millis = 6;
Yangsterfa28aec2017-10-30 10:29:52 -0700132}
133
134message ValueMetricData {
Yangster-mac468ff042018-01-17 12:26:34 -0800135 optional DimensionsValue dimensions_in_what = 1;
136
Yangster-mac16fc72f2018-01-18 13:18:01 -0800137 optional DimensionsValue dimensions_in_condition = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700138
Yangster-mac16fc72f2018-01-18 13:18:01 -0800139 repeated ValueBucketInfo bucket_info = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -0700140
141 repeated DimensionsValue dimension_leaf_values_in_what = 4;
142
143 repeated DimensionsValue dimension_leaf_values_in_condition = 5;
Yangsterfa28aec2017-10-30 10:29:52 -0700144}
145
146message GaugeBucketInfo {
Yangster-mac15f6bbc2018-04-08 11:52:26 -0700147 optional int64 start_bucket_elapsed_nanos = 1;
Yangsterfa28aec2017-10-30 10:29:52 -0700148
Yangster-mac15f6bbc2018-04-08 11:52:26 -0700149 optional int64 end_bucket_elapsed_nanos = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700150
Yangster-mac34ea1102018-01-29 12:40:55 -0800151 repeated Atom atom = 3;
152
Yangster-mac330af582018-02-08 15:24:38 -0800153 repeated int64 elapsed_timestamp_nanos = 4;
Yangster-mac3fa5d7f2018-03-10 21:50:27 -0800154
Bookatzfe2dde82018-08-28 13:24:40 -0700155 repeated int64 wall_clock_timestamp_nanos = 5 [deprecated = true];
Yangster-mac9def8e32018-04-17 13:55:51 -0700156
157 optional int64 bucket_num = 6;
158
159 optional int64 start_bucket_elapsed_millis = 7;
160
161 optional int64 end_bucket_elapsed_millis = 8;
Yangsterfa28aec2017-10-30 10:29:52 -0700162}
163
164message GaugeMetricData {
Yangster-mac468ff042018-01-17 12:26:34 -0800165 optional DimensionsValue dimensions_in_what = 1;
166
Yangster-mac16fc72f2018-01-18 13:18:01 -0800167 optional DimensionsValue dimensions_in_condition = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700168
Yangster-mac16fc72f2018-01-18 13:18:01 -0800169 repeated GaugeBucketInfo bucket_info = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -0700170
171 repeated DimensionsValue dimension_leaf_values_in_what = 4;
172
173 repeated DimensionsValue dimension_leaf_values_in_condition = 5;
Yangsterfa28aec2017-10-30 10:29:52 -0700174}
175
yro00698da2017-09-15 10:06:40 -0700176message StatsLogReport {
Yangster-mac94e197c2018-01-02 16:03:03 -0800177 optional int64 metric_id = 1;
Yao Chenab273e22017-09-06 12:53:50 -0700178
David Chen16049572018-02-01 18:27:51 -0800179 // Fields 2 and 3 are reserved.
yro00698da2017-09-15 10:06:40 -0700180
David Chen81245fd2018-04-12 14:33:37 -0700181 message SkippedBuckets {
Yangster-mac9def8e32018-04-17 13:55:51 -0700182 optional int64 start_bucket_elapsed_nanos = 1;
183 optional int64 end_bucket_elapsed_nanos = 2;
184 optional int64 start_bucket_elapsed_millis = 3;
185 optional int64 end_bucket_elapsed_millis = 4;
David Chen81245fd2018-04-12 14:33:37 -0700186 }
187
yro00698da2017-09-15 10:06:40 -0700188 message EventMetricDataWrapper {
189 repeated EventMetricData data = 1;
190 }
191 message CountMetricDataWrapper {
192 repeated CountMetricData data = 1;
193 }
Yao Chencaf339d2017-10-06 16:01:10 -0700194 message DurationMetricDataWrapper {
Yao Chen729093d2017-10-16 10:33:26 -0700195 repeated DurationMetricData data = 1;
Yao Chencaf339d2017-10-06 16:01:10 -0700196 }
Yangsterfa28aec2017-10-30 10:29:52 -0700197 message ValueMetricDataWrapper {
198 repeated ValueMetricData data = 1;
David Chen81245fd2018-04-12 14:33:37 -0700199 repeated SkippedBuckets skipped = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700200 }
Chenjie Yub3dda412017-10-24 13:41:59 -0700201
Yangsterfa28aec2017-10-30 10:29:52 -0700202 message GaugeMetricDataWrapper {
203 repeated GaugeMetricData data = 1;
David Chen81245fd2018-04-12 14:33:37 -0700204 repeated SkippedBuckets skipped = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700205 }
Chenjie Yub3dda412017-10-24 13:41:59 -0700206
yro00698da2017-09-15 10:06:40 -0700207 oneof data {
208 EventMetricDataWrapper event_metrics = 4;
209 CountMetricDataWrapper count_metrics = 5;
Yao Chencaf339d2017-10-06 16:01:10 -0700210 DurationMetricDataWrapper duration_metrics = 6;
Yangsterfa28aec2017-10-30 10:29:52 -0700211 ValueMetricDataWrapper value_metrics = 7;
212 GaugeMetricDataWrapper gauge_metrics = 8;
yro00698da2017-09-15 10:06:40 -0700213 }
Yangster-mac9def8e32018-04-17 13:55:51 -0700214
215 optional int64 time_base_elapsed_nano_seconds = 9;
216
217 optional int64 bucket_size_nano_seconds = 10;
218
219 optional DimensionsValue dimensions_path_in_what = 11;
220
221 optional DimensionsValue dimensions_path_in_condition = 12;
Yao Chenab273e22017-09-06 12:53:50 -0700222}
Yangsterfa28aec2017-10-30 10:29:52 -0700223
David Chenf384b902018-03-14 18:36:45 -0700224message UidMapping {
225 message PackageInfoSnapshot {
226 message PackageInfo {
227 optional string name = 1;
228
229 optional int64 version = 2;
230
231 optional int32 uid = 3;
David Chenbd125272018-04-04 19:02:50 -0700232
233 optional bool deleted = 4;
Yangster-mac9def8e32018-04-17 13:55:51 -0700234
235 optional uint64 name_hash = 5;
David Chenf384b902018-03-14 18:36:45 -0700236 }
237 optional int64 elapsed_timestamp_nanos = 1;
238
239 repeated PackageInfo package_info = 2;
240 }
241 repeated PackageInfoSnapshot snapshots = 1;
242
243 message Change {
244 optional bool deletion = 1;
245
246 optional int64 elapsed_timestamp_nanos = 2;
247 optional string app = 3;
248 optional int32 uid = 4;
249
David Chenbd125272018-04-04 19:02:50 -0700250 optional int64 new_version = 5;
251 optional int64 prev_version = 6;
Yangster-mac9def8e32018-04-17 13:55:51 -0700252 optional uint64 app_hash = 7;
David Chenf384b902018-03-14 18:36:45 -0700253 }
254 repeated Change changes = 2;
255}
256
Yangsterfa28aec2017-10-30 10:29:52 -0700257message ConfigMetricsReport {
yro947fbce2017-11-15 22:50:23 -0800258 repeated StatsLogReport metrics = 1;
259
260 optional UidMapping uid_map = 2;
David Chen16049572018-02-01 18:27:51 -0800261
Yangster-mac330af582018-02-08 15:24:38 -0800262 optional int64 last_report_elapsed_nanos = 3;
David Chen16049572018-02-01 18:27:51 -0800263
Yangster-mac330af582018-02-08 15:24:38 -0800264 optional int64 current_report_elapsed_nanos = 4;
Yangster-mac3fa5d7f2018-03-10 21:50:27 -0800265
266 optional int64 last_report_wall_clock_nanos = 5;
267
268 optional int64 current_report_wall_clock_nanos = 6;
David Chenfaa1af52018-03-30 15:14:04 -0700269
Yangster-mac9def8e32018-04-17 13:55:51 -0700270 message Annotation {
271 optional int64 field_int64 = 1;
272 optional int32 field_int32 = 2;
273 }
274 repeated Annotation annotation = 7;
275
Chenjie Yue36018b2018-04-16 15:18:30 -0700276 enum DumpReportReason {
277 DEVICE_SHUTDOWN = 1;
278 CONFIG_UPDATED = 2;
279 CONFIG_REMOVED = 3;
280 GET_DATA_CALLED = 4;
281 ADB_DUMP = 5;
282 CONFIG_RESET = 6;
283 STATSCOMPANION_DIED = 7;
Yangster-mac97e7d202018-10-09 11:05:39 -0700284 TERMINATION_SIGNAL_RECEIVED = 8;
Chenjie Yue36018b2018-04-16 15:18:30 -0700285 }
286 optional DumpReportReason dump_report_reason = 8;
287
Yangster-mac9def8e32018-04-17 13:55:51 -0700288 repeated string strings = 9;
yro947fbce2017-11-15 22:50:23 -0800289}
290
291message ConfigMetricsReportList {
Yangsterfa28aec2017-10-30 10:29:52 -0700292 message ConfigKey {
293 optional int32 uid = 1;
Yangster-mac94e197c2018-01-02 16:03:03 -0800294 optional int64 id = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700295 }
296 optional ConfigKey config_key = 1;
297
yro947fbce2017-11-15 22:50:23 -0800298 repeated ConfigMetricsReport reports = 2;
Chenjie Yue36018b2018-04-16 15:18:30 -0700299
300 reserved 10;
Yangster-mac932ecec2018-02-01 10:23:52 -0800301}
Yao Chen20e9e622018-02-28 11:18:51 -0800302
303message StatsdStatsReport {
304 optional int32 stats_begin_time_sec = 1;
305
306 optional int32 stats_end_time_sec = 2;
307
308 message MatcherStats {
309 optional int64 id = 1;
310 optional int32 matched_times = 2;
311 }
312
313 message ConditionStats {
314 optional int64 id = 1;
315 optional int32 max_tuple_counts = 2;
316 }
317
318 message MetricStats {
319 optional int64 id = 1;
320 optional int32 max_tuple_counts = 2;
321 }
322
323 message AlertStats {
324 optional int64 id = 1;
325 optional int32 alerted_times = 2;
326 }
327
328 message ConfigStats {
329 optional int32 uid = 1;
330 optional int64 id = 2;
331 optional int32 creation_time_sec = 3;
332 optional int32 deletion_time_sec = 4;
Yangster-macb142cc82018-03-30 15:22:08 -0700333 optional int32 reset_time_sec = 19;
Yao Chen20e9e622018-02-28 11:18:51 -0800334 optional int32 metric_count = 5;
335 optional int32 condition_count = 6;
336 optional int32 matcher_count = 7;
337 optional int32 alert_count = 8;
338 optional bool is_valid = 9;
Yao Chen20e9e622018-02-28 11:18:51 -0800339 repeated int32 broadcast_sent_time_sec = 10;
340 repeated int32 data_drop_time_sec = 11;
Chenjie Yuc3c30c02018-10-26 09:48:07 -0700341 repeated int64 data_drop_bytes = 21;
Yao Chen20e9e622018-02-28 11:18:51 -0800342 repeated int32 dump_report_time_sec = 12;
Yangster-mace68f3a52018-04-04 00:01:43 -0700343 repeated int32 dump_report_data_size = 20;
Yao Chen20e9e622018-02-28 11:18:51 -0800344 repeated MatcherStats matcher_stats = 13;
345 repeated ConditionStats condition_stats = 14;
346 repeated MetricStats metric_stats = 15;
347 repeated AlertStats alert_stats = 16;
Yangster-mac306ccc22018-03-24 15:03:40 -0700348 repeated MetricStats metric_dimension_in_condition_stats = 17;
David Chenfaa1af52018-03-30 15:14:04 -0700349 message Annotation {
350 optional int64 field_int64 = 1;
351 optional int32 field_int32 = 2;
352 }
353 repeated Annotation annotation = 18;
Yao Chen20e9e622018-02-28 11:18:51 -0800354 }
355
356 repeated ConfigStats config_stats = 3;
357
358 message AtomStats {
359 optional int32 tag = 1;
360 optional int32 count = 2;
361 }
362
363 repeated AtomStats atom_stats = 7;
364
365 message UidMapStats {
David Chenbd125272018-04-04 19:02:50 -0700366 optional int32 changes = 1;
367 optional int32 bytes_used = 2;
368 optional int32 dropped_changes = 3;
369 optional int32 deleted_apps = 4;
Yao Chen20e9e622018-02-28 11:18:51 -0800370 }
371 optional UidMapStats uidmap_stats = 8;
372
373 message AnomalyAlarmStats {
374 optional int32 alarms_registered = 1;
375 }
376 optional AnomalyAlarmStats anomaly_alarm_stats = 9;
377
378 message PulledAtomStats {
379 optional int32 atom_id = 1;
380 optional int64 total_pull = 2;
381 optional int64 total_pull_from_cache = 3;
382 optional int64 min_pull_interval_sec = 4;
Chenjie Yu48ed1cc2018-10-31 17:36:38 -0700383 optional int64 average_pull_time_nanos = 5;
384 optional int64 max_pull_time_nanos = 6;
385 optional int64 average_pull_delay_nanos = 7;
386 optional int64 max_pull_delay_nanos = 8;
Chenjie Yuc715b9e2018-10-19 07:52:12 -0700387 optional int64 data_error = 9;
Yao Chen20e9e622018-02-28 11:18:51 -0800388 }
389 repeated PulledAtomStats pulled_atom_stats = 10;
390
391 message LoggerErrorStats {
392 optional int32 logger_disconnection_sec = 1;
393 optional int32 error_code = 2;
394 }
395 repeated LoggerErrorStats logger_error_stats = 11;
Yangster-macb8382a12018-04-04 10:39:12 -0700396
397 message PeriodicAlarmStats {
398 optional int32 alarms_registered = 1;
399 }
400 optional PeriodicAlarmStats periodic_alarm_stats = 12;
401
402 message SkippedLogEventStats {
403 optional int32 tag = 1;
404 optional int64 elapsed_timestamp_nanos = 2;
405 }
406 repeated SkippedLogEventStats skipped_log_event_stats = 13;
Yao Chen163d2602018-04-10 10:39:53 -0700407
408 repeated int64 log_loss_stats = 14;
Yangster-mac892f3d32018-05-02 14:16:48 -0700409
410 repeated int32 system_restart_sec = 15;
Yao Chen39b67992018-11-08 15:32:17 -0800411
412 message LogLossStats {
413 optional int32 detected_time_sec = 1;
414 optional int32 count = 2;
415 optional int32 last_error = 3;
416 }
417 repeated LogLossStats detected_log_loss = 16;
Yao Chen20e9e622018-02-28 11:18:51 -0800418}