blob: cfd62690dd1c832695193b0928b75d24038cc61a [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
Yangster-mac3fa5d7f2018-03-10 21:50:27 -080049 optional int64 wall_clock_timestamp_nanos = 3;
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 Yua0f02242018-07-06 16:14:34 -0700109 oneof values {
110 int64 value_long = 3;
111
112 double value_double = 7;
113 }
Yangster-mac9def8e32018-04-17 13:55:51 -0700114
115 optional int64 bucket_num = 4;
116
117 optional int64 start_bucket_elapsed_millis = 5;
118
119 optional int64 end_bucket_elapsed_millis = 6;
Yangsterfa28aec2017-10-30 10:29:52 -0700120}
121
122message ValueMetricData {
Yangster-mac468ff042018-01-17 12:26:34 -0800123 optional DimensionsValue dimensions_in_what = 1;
124
Yangster-mac16fc72f2018-01-18 13:18:01 -0800125 optional DimensionsValue dimensions_in_condition = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700126
Yangster-mac16fc72f2018-01-18 13:18:01 -0800127 repeated ValueBucketInfo bucket_info = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -0700128
129 repeated DimensionsValue dimension_leaf_values_in_what = 4;
130
131 repeated DimensionsValue dimension_leaf_values_in_condition = 5;
Yangsterfa28aec2017-10-30 10:29:52 -0700132}
133
134message GaugeBucketInfo {
Yangster-mac15f6bbc2018-04-08 11:52:26 -0700135 optional int64 start_bucket_elapsed_nanos = 1;
Yangsterfa28aec2017-10-30 10:29:52 -0700136
Yangster-mac15f6bbc2018-04-08 11:52:26 -0700137 optional int64 end_bucket_elapsed_nanos = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700138
Yangster-mac34ea1102018-01-29 12:40:55 -0800139 repeated Atom atom = 3;
140
Yangster-mac330af582018-02-08 15:24:38 -0800141 repeated int64 elapsed_timestamp_nanos = 4;
Yangster-mac3fa5d7f2018-03-10 21:50:27 -0800142
143 repeated int64 wall_clock_timestamp_nanos = 5;
Yangster-mac9def8e32018-04-17 13:55:51 -0700144
145 optional int64 bucket_num = 6;
146
147 optional int64 start_bucket_elapsed_millis = 7;
148
149 optional int64 end_bucket_elapsed_millis = 8;
Yangsterfa28aec2017-10-30 10:29:52 -0700150}
151
152message GaugeMetricData {
Yangster-mac468ff042018-01-17 12:26:34 -0800153 optional DimensionsValue dimensions_in_what = 1;
154
Yangster-mac16fc72f2018-01-18 13:18:01 -0800155 optional DimensionsValue dimensions_in_condition = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700156
Yangster-mac16fc72f2018-01-18 13:18:01 -0800157 repeated GaugeBucketInfo bucket_info = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -0700158
159 repeated DimensionsValue dimension_leaf_values_in_what = 4;
160
161 repeated DimensionsValue dimension_leaf_values_in_condition = 5;
Yangsterfa28aec2017-10-30 10:29:52 -0700162}
163
yro00698da2017-09-15 10:06:40 -0700164message StatsLogReport {
Yangster-mac94e197c2018-01-02 16:03:03 -0800165 optional int64 metric_id = 1;
Yao Chenab273e22017-09-06 12:53:50 -0700166
David Chen16049572018-02-01 18:27:51 -0800167 // Fields 2 and 3 are reserved.
yro00698da2017-09-15 10:06:40 -0700168
David Chen81245fd2018-04-12 14:33:37 -0700169 message SkippedBuckets {
Yangster-mac9def8e32018-04-17 13:55:51 -0700170 optional int64 start_bucket_elapsed_nanos = 1;
171 optional int64 end_bucket_elapsed_nanos = 2;
172 optional int64 start_bucket_elapsed_millis = 3;
173 optional int64 end_bucket_elapsed_millis = 4;
David Chen81245fd2018-04-12 14:33:37 -0700174 }
175
yro00698da2017-09-15 10:06:40 -0700176 message EventMetricDataWrapper {
177 repeated EventMetricData data = 1;
178 }
179 message CountMetricDataWrapper {
180 repeated CountMetricData data = 1;
181 }
Yao Chencaf339d2017-10-06 16:01:10 -0700182 message DurationMetricDataWrapper {
Yao Chen729093d2017-10-16 10:33:26 -0700183 repeated DurationMetricData data = 1;
Yao Chencaf339d2017-10-06 16:01:10 -0700184 }
Yangsterfa28aec2017-10-30 10:29:52 -0700185 message ValueMetricDataWrapper {
186 repeated ValueMetricData data = 1;
David Chen81245fd2018-04-12 14:33:37 -0700187 repeated SkippedBuckets skipped = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700188 }
Chenjie Yub3dda412017-10-24 13:41:59 -0700189
Yangsterfa28aec2017-10-30 10:29:52 -0700190 message GaugeMetricDataWrapper {
191 repeated GaugeMetricData data = 1;
David Chen81245fd2018-04-12 14:33:37 -0700192 repeated SkippedBuckets skipped = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700193 }
Chenjie Yub3dda412017-10-24 13:41:59 -0700194
yro00698da2017-09-15 10:06:40 -0700195 oneof data {
196 EventMetricDataWrapper event_metrics = 4;
197 CountMetricDataWrapper count_metrics = 5;
Yao Chencaf339d2017-10-06 16:01:10 -0700198 DurationMetricDataWrapper duration_metrics = 6;
Yangsterfa28aec2017-10-30 10:29:52 -0700199 ValueMetricDataWrapper value_metrics = 7;
200 GaugeMetricDataWrapper gauge_metrics = 8;
yro00698da2017-09-15 10:06:40 -0700201 }
Yangster-mac9def8e32018-04-17 13:55:51 -0700202
203 optional int64 time_base_elapsed_nano_seconds = 9;
204
205 optional int64 bucket_size_nano_seconds = 10;
206
207 optional DimensionsValue dimensions_path_in_what = 11;
208
209 optional DimensionsValue dimensions_path_in_condition = 12;
Yao Chenab273e22017-09-06 12:53:50 -0700210}
Yangsterfa28aec2017-10-30 10:29:52 -0700211
David Chenf384b902018-03-14 18:36:45 -0700212message UidMapping {
213 message PackageInfoSnapshot {
214 message PackageInfo {
215 optional string name = 1;
216
217 optional int64 version = 2;
218
219 optional int32 uid = 3;
David Chenbd125272018-04-04 19:02:50 -0700220
221 optional bool deleted = 4;
Yangster-mac9def8e32018-04-17 13:55:51 -0700222
223 optional uint64 name_hash = 5;
David Chenf384b902018-03-14 18:36:45 -0700224 }
225 optional int64 elapsed_timestamp_nanos = 1;
226
227 repeated PackageInfo package_info = 2;
228 }
229 repeated PackageInfoSnapshot snapshots = 1;
230
231 message Change {
232 optional bool deletion = 1;
233
234 optional int64 elapsed_timestamp_nanos = 2;
235 optional string app = 3;
236 optional int32 uid = 4;
237
David Chenbd125272018-04-04 19:02:50 -0700238 optional int64 new_version = 5;
239 optional int64 prev_version = 6;
Yangster-mac9def8e32018-04-17 13:55:51 -0700240 optional uint64 app_hash = 7;
David Chenf384b902018-03-14 18:36:45 -0700241 }
242 repeated Change changes = 2;
243}
244
Yangsterfa28aec2017-10-30 10:29:52 -0700245message ConfigMetricsReport {
yro947fbce2017-11-15 22:50:23 -0800246 repeated StatsLogReport metrics = 1;
247
248 optional UidMapping uid_map = 2;
David Chen16049572018-02-01 18:27:51 -0800249
Yangster-mac330af582018-02-08 15:24:38 -0800250 optional int64 last_report_elapsed_nanos = 3;
David Chen16049572018-02-01 18:27:51 -0800251
Yangster-mac330af582018-02-08 15:24:38 -0800252 optional int64 current_report_elapsed_nanos = 4;
Yangster-mac3fa5d7f2018-03-10 21:50:27 -0800253
254 optional int64 last_report_wall_clock_nanos = 5;
255
256 optional int64 current_report_wall_clock_nanos = 6;
David Chenfaa1af52018-03-30 15:14:04 -0700257
Yangster-mac9def8e32018-04-17 13:55:51 -0700258 message Annotation {
259 optional int64 field_int64 = 1;
260 optional int32 field_int32 = 2;
261 }
262 repeated Annotation annotation = 7;
263
Chenjie Yue36018b2018-04-16 15:18:30 -0700264 enum DumpReportReason {
265 DEVICE_SHUTDOWN = 1;
266 CONFIG_UPDATED = 2;
267 CONFIG_REMOVED = 3;
268 GET_DATA_CALLED = 4;
269 ADB_DUMP = 5;
270 CONFIG_RESET = 6;
271 STATSCOMPANION_DIED = 7;
272 }
273 optional DumpReportReason dump_report_reason = 8;
274
Yangster-mac9def8e32018-04-17 13:55:51 -0700275 repeated string strings = 9;
yro947fbce2017-11-15 22:50:23 -0800276}
277
278message ConfigMetricsReportList {
Yangsterfa28aec2017-10-30 10:29:52 -0700279 message ConfigKey {
280 optional int32 uid = 1;
Yangster-mac94e197c2018-01-02 16:03:03 -0800281 optional int64 id = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700282 }
283 optional ConfigKey config_key = 1;
284
yro947fbce2017-11-15 22:50:23 -0800285 repeated ConfigMetricsReport reports = 2;
Chenjie Yue36018b2018-04-16 15:18:30 -0700286
287 reserved 10;
Yangster-mac932ecec2018-02-01 10:23:52 -0800288}
Yao Chen20e9e622018-02-28 11:18:51 -0800289
290message StatsdStatsReport {
291 optional int32 stats_begin_time_sec = 1;
292
293 optional int32 stats_end_time_sec = 2;
294
295 message MatcherStats {
296 optional int64 id = 1;
297 optional int32 matched_times = 2;
298 }
299
300 message ConditionStats {
301 optional int64 id = 1;
302 optional int32 max_tuple_counts = 2;
303 }
304
305 message MetricStats {
306 optional int64 id = 1;
307 optional int32 max_tuple_counts = 2;
308 }
309
310 message AlertStats {
311 optional int64 id = 1;
312 optional int32 alerted_times = 2;
313 }
314
315 message ConfigStats {
316 optional int32 uid = 1;
317 optional int64 id = 2;
318 optional int32 creation_time_sec = 3;
319 optional int32 deletion_time_sec = 4;
Yangster-macb142cc82018-03-30 15:22:08 -0700320 optional int32 reset_time_sec = 19;
Yao Chen20e9e622018-02-28 11:18:51 -0800321 optional int32 metric_count = 5;
322 optional int32 condition_count = 6;
323 optional int32 matcher_count = 7;
324 optional int32 alert_count = 8;
325 optional bool is_valid = 9;
Yao Chen20e9e622018-02-28 11:18:51 -0800326 repeated int32 broadcast_sent_time_sec = 10;
327 repeated int32 data_drop_time_sec = 11;
328 repeated int32 dump_report_time_sec = 12;
Yangster-mace68f3a52018-04-04 00:01:43 -0700329 repeated int32 dump_report_data_size = 20;
Yao Chen20e9e622018-02-28 11:18:51 -0800330 repeated MatcherStats matcher_stats = 13;
331 repeated ConditionStats condition_stats = 14;
332 repeated MetricStats metric_stats = 15;
333 repeated AlertStats alert_stats = 16;
Yangster-mac306ccc22018-03-24 15:03:40 -0700334 repeated MetricStats metric_dimension_in_condition_stats = 17;
David Chenfaa1af52018-03-30 15:14:04 -0700335 message Annotation {
336 optional int64 field_int64 = 1;
337 optional int32 field_int32 = 2;
338 }
339 repeated Annotation annotation = 18;
Yao Chen20e9e622018-02-28 11:18:51 -0800340 }
341
342 repeated ConfigStats config_stats = 3;
343
344 message AtomStats {
345 optional int32 tag = 1;
346 optional int32 count = 2;
347 }
348
349 repeated AtomStats atom_stats = 7;
350
351 message UidMapStats {
David Chenbd125272018-04-04 19:02:50 -0700352 optional int32 changes = 1;
353 optional int32 bytes_used = 2;
354 optional int32 dropped_changes = 3;
355 optional int32 deleted_apps = 4;
Yao Chen20e9e622018-02-28 11:18:51 -0800356 }
357 optional UidMapStats uidmap_stats = 8;
358
359 message AnomalyAlarmStats {
360 optional int32 alarms_registered = 1;
361 }
362 optional AnomalyAlarmStats anomaly_alarm_stats = 9;
363
364 message PulledAtomStats {
365 optional int32 atom_id = 1;
366 optional int64 total_pull = 2;
367 optional int64 total_pull_from_cache = 3;
368 optional int64 min_pull_interval_sec = 4;
369 }
370 repeated PulledAtomStats pulled_atom_stats = 10;
371
372 message LoggerErrorStats {
373 optional int32 logger_disconnection_sec = 1;
374 optional int32 error_code = 2;
375 }
376 repeated LoggerErrorStats logger_error_stats = 11;
Yangster-macb8382a12018-04-04 10:39:12 -0700377
378 message PeriodicAlarmStats {
379 optional int32 alarms_registered = 1;
380 }
381 optional PeriodicAlarmStats periodic_alarm_stats = 12;
382
383 message SkippedLogEventStats {
384 optional int32 tag = 1;
385 optional int64 elapsed_timestamp_nanos = 2;
386 }
387 repeated SkippedLogEventStats skipped_log_event_stats = 13;
Yao Chen163d2602018-04-10 10:39:53 -0700388
389 repeated int64 log_loss_stats = 14;
Yangster-mac892f3d32018-05-02 14:16:48 -0700390
391 repeated int32 system_restart_sec = 15;
Yao Chen20e9e622018-02-28 11:18:51 -0800392}