blob: 1c70d88f6cf3abb843dbbad4f7f17154ca096533 [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
109 optional int64 value = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -0700110
111 optional int64 bucket_num = 4;
112
113 optional int64 start_bucket_elapsed_millis = 5;
114
115 optional int64 end_bucket_elapsed_millis = 6;
Yangsterfa28aec2017-10-30 10:29:52 -0700116}
117
118message ValueMetricData {
Yangster-mac468ff042018-01-17 12:26:34 -0800119 optional DimensionsValue dimensions_in_what = 1;
120
Yangster-mac16fc72f2018-01-18 13:18:01 -0800121 optional DimensionsValue dimensions_in_condition = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700122
Yangster-mac16fc72f2018-01-18 13:18:01 -0800123 repeated ValueBucketInfo bucket_info = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -0700124
125 repeated DimensionsValue dimension_leaf_values_in_what = 4;
126
127 repeated DimensionsValue dimension_leaf_values_in_condition = 5;
Yangsterfa28aec2017-10-30 10:29:52 -0700128}
129
130message GaugeBucketInfo {
Yangster-mac15f6bbc2018-04-08 11:52:26 -0700131 optional int64 start_bucket_elapsed_nanos = 1;
Yangsterfa28aec2017-10-30 10:29:52 -0700132
Yangster-mac15f6bbc2018-04-08 11:52:26 -0700133 optional int64 end_bucket_elapsed_nanos = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700134
Yangster-mac34ea1102018-01-29 12:40:55 -0800135 repeated Atom atom = 3;
136
Yangster-mac330af582018-02-08 15:24:38 -0800137 repeated int64 elapsed_timestamp_nanos = 4;
Yangster-mac3fa5d7f2018-03-10 21:50:27 -0800138
139 repeated int64 wall_clock_timestamp_nanos = 5;
Yangster-mac9def8e32018-04-17 13:55:51 -0700140
141 optional int64 bucket_num = 6;
142
143 optional int64 start_bucket_elapsed_millis = 7;
144
145 optional int64 end_bucket_elapsed_millis = 8;
Yangsterfa28aec2017-10-30 10:29:52 -0700146}
147
148message GaugeMetricData {
Yangster-mac468ff042018-01-17 12:26:34 -0800149 optional DimensionsValue dimensions_in_what = 1;
150
Yangster-mac16fc72f2018-01-18 13:18:01 -0800151 optional DimensionsValue dimensions_in_condition = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700152
Yangster-mac16fc72f2018-01-18 13:18:01 -0800153 repeated GaugeBucketInfo bucket_info = 3;
Yangster-mac9def8e32018-04-17 13:55:51 -0700154
155 repeated DimensionsValue dimension_leaf_values_in_what = 4;
156
157 repeated DimensionsValue dimension_leaf_values_in_condition = 5;
Yangsterfa28aec2017-10-30 10:29:52 -0700158}
159
yro00698da2017-09-15 10:06:40 -0700160message StatsLogReport {
Yangster-mac94e197c2018-01-02 16:03:03 -0800161 optional int64 metric_id = 1;
Yao Chenab273e22017-09-06 12:53:50 -0700162
David Chen16049572018-02-01 18:27:51 -0800163 // Fields 2 and 3 are reserved.
yro00698da2017-09-15 10:06:40 -0700164
David Chen81245fd2018-04-12 14:33:37 -0700165 message SkippedBuckets {
Yangster-mac9def8e32018-04-17 13:55:51 -0700166 optional int64 start_bucket_elapsed_nanos = 1;
167 optional int64 end_bucket_elapsed_nanos = 2;
168 optional int64 start_bucket_elapsed_millis = 3;
169 optional int64 end_bucket_elapsed_millis = 4;
David Chen81245fd2018-04-12 14:33:37 -0700170 }
171
yro00698da2017-09-15 10:06:40 -0700172 message EventMetricDataWrapper {
173 repeated EventMetricData data = 1;
174 }
175 message CountMetricDataWrapper {
176 repeated CountMetricData data = 1;
177 }
Yao Chencaf339d2017-10-06 16:01:10 -0700178 message DurationMetricDataWrapper {
Yao Chen729093d2017-10-16 10:33:26 -0700179 repeated DurationMetricData data = 1;
Yao Chencaf339d2017-10-06 16:01:10 -0700180 }
Yangsterfa28aec2017-10-30 10:29:52 -0700181 message ValueMetricDataWrapper {
182 repeated ValueMetricData data = 1;
David Chen81245fd2018-04-12 14:33:37 -0700183 repeated SkippedBuckets skipped = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700184 }
Chenjie Yub3dda412017-10-24 13:41:59 -0700185
Yangsterfa28aec2017-10-30 10:29:52 -0700186 message GaugeMetricDataWrapper {
187 repeated GaugeMetricData data = 1;
David Chen81245fd2018-04-12 14:33:37 -0700188 repeated SkippedBuckets skipped = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700189 }
Chenjie Yub3dda412017-10-24 13:41:59 -0700190
yro00698da2017-09-15 10:06:40 -0700191 oneof data {
192 EventMetricDataWrapper event_metrics = 4;
193 CountMetricDataWrapper count_metrics = 5;
Yao Chencaf339d2017-10-06 16:01:10 -0700194 DurationMetricDataWrapper duration_metrics = 6;
Yangsterfa28aec2017-10-30 10:29:52 -0700195 ValueMetricDataWrapper value_metrics = 7;
196 GaugeMetricDataWrapper gauge_metrics = 8;
yro00698da2017-09-15 10:06:40 -0700197 }
Yangster-mac9def8e32018-04-17 13:55:51 -0700198
199 optional int64 time_base_elapsed_nano_seconds = 9;
200
201 optional int64 bucket_size_nano_seconds = 10;
202
203 optional DimensionsValue dimensions_path_in_what = 11;
204
205 optional DimensionsValue dimensions_path_in_condition = 12;
Yao Chenab273e22017-09-06 12:53:50 -0700206}
Yangsterfa28aec2017-10-30 10:29:52 -0700207
David Chenf384b902018-03-14 18:36:45 -0700208message UidMapping {
209 message PackageInfoSnapshot {
210 message PackageInfo {
211 optional string name = 1;
212
213 optional int64 version = 2;
214
215 optional int32 uid = 3;
David Chenbd125272018-04-04 19:02:50 -0700216
217 optional bool deleted = 4;
Yangster-mac9def8e32018-04-17 13:55:51 -0700218
219 optional uint64 name_hash = 5;
David Chenf384b902018-03-14 18:36:45 -0700220 }
221 optional int64 elapsed_timestamp_nanos = 1;
222
223 repeated PackageInfo package_info = 2;
224 }
225 repeated PackageInfoSnapshot snapshots = 1;
226
227 message Change {
228 optional bool deletion = 1;
229
230 optional int64 elapsed_timestamp_nanos = 2;
231 optional string app = 3;
232 optional int32 uid = 4;
233
David Chenbd125272018-04-04 19:02:50 -0700234 optional int64 new_version = 5;
235 optional int64 prev_version = 6;
Yangster-mac9def8e32018-04-17 13:55:51 -0700236 optional uint64 app_hash = 7;
David Chenf384b902018-03-14 18:36:45 -0700237 }
238 repeated Change changes = 2;
239}
240
Yangsterfa28aec2017-10-30 10:29:52 -0700241message ConfigMetricsReport {
yro947fbce2017-11-15 22:50:23 -0800242 repeated StatsLogReport metrics = 1;
243
244 optional UidMapping uid_map = 2;
David Chen16049572018-02-01 18:27:51 -0800245
Yangster-mac330af582018-02-08 15:24:38 -0800246 optional int64 last_report_elapsed_nanos = 3;
David Chen16049572018-02-01 18:27:51 -0800247
Yangster-mac330af582018-02-08 15:24:38 -0800248 optional int64 current_report_elapsed_nanos = 4;
Yangster-mac3fa5d7f2018-03-10 21:50:27 -0800249
250 optional int64 last_report_wall_clock_nanos = 5;
251
252 optional int64 current_report_wall_clock_nanos = 6;
David Chenfaa1af52018-03-30 15:14:04 -0700253
Yangster-mac9def8e32018-04-17 13:55:51 -0700254 message Annotation {
255 optional int64 field_int64 = 1;
256 optional int32 field_int32 = 2;
257 }
258 repeated Annotation annotation = 7;
259
Chenjie Yue36018b2018-04-16 15:18:30 -0700260 enum DumpReportReason {
261 DEVICE_SHUTDOWN = 1;
262 CONFIG_UPDATED = 2;
263 CONFIG_REMOVED = 3;
264 GET_DATA_CALLED = 4;
265 ADB_DUMP = 5;
266 CONFIG_RESET = 6;
267 STATSCOMPANION_DIED = 7;
Yang Lu658bc0e2018-10-19 09:03:51 -0700268 TERMINATION_SIGNAL_RECEIVED = 8;
Chenjie Yue36018b2018-04-16 15:18:30 -0700269 }
270 optional DumpReportReason dump_report_reason = 8;
271
Yangster-mac9def8e32018-04-17 13:55:51 -0700272 repeated string strings = 9;
yro947fbce2017-11-15 22:50:23 -0800273}
274
275message ConfigMetricsReportList {
Yangsterfa28aec2017-10-30 10:29:52 -0700276 message ConfigKey {
277 optional int32 uid = 1;
Yangster-mac94e197c2018-01-02 16:03:03 -0800278 optional int64 id = 2;
Yangsterfa28aec2017-10-30 10:29:52 -0700279 }
280 optional ConfigKey config_key = 1;
281
yro947fbce2017-11-15 22:50:23 -0800282 repeated ConfigMetricsReport reports = 2;
Chenjie Yue36018b2018-04-16 15:18:30 -0700283
284 reserved 10;
Yangster-mac932ecec2018-02-01 10:23:52 -0800285}
Yao Chen20e9e622018-02-28 11:18:51 -0800286
287message StatsdStatsReport {
288 optional int32 stats_begin_time_sec = 1;
289
290 optional int32 stats_end_time_sec = 2;
291
292 message MatcherStats {
293 optional int64 id = 1;
294 optional int32 matched_times = 2;
295 }
296
297 message ConditionStats {
298 optional int64 id = 1;
299 optional int32 max_tuple_counts = 2;
300 }
301
302 message MetricStats {
303 optional int64 id = 1;
304 optional int32 max_tuple_counts = 2;
305 }
306
307 message AlertStats {
308 optional int64 id = 1;
309 optional int32 alerted_times = 2;
310 }
311
312 message ConfigStats {
313 optional int32 uid = 1;
314 optional int64 id = 2;
315 optional int32 creation_time_sec = 3;
316 optional int32 deletion_time_sec = 4;
Yangster-macb142cc82018-03-30 15:22:08 -0700317 optional int32 reset_time_sec = 19;
Yao Chen20e9e622018-02-28 11:18:51 -0800318 optional int32 metric_count = 5;
319 optional int32 condition_count = 6;
320 optional int32 matcher_count = 7;
321 optional int32 alert_count = 8;
322 optional bool is_valid = 9;
Yao Chen20e9e622018-02-28 11:18:51 -0800323 repeated int32 broadcast_sent_time_sec = 10;
324 repeated int32 data_drop_time_sec = 11;
325 repeated int32 dump_report_time_sec = 12;
Yangster-mace68f3a52018-04-04 00:01:43 -0700326 repeated int32 dump_report_data_size = 20;
Yao Chen20e9e622018-02-28 11:18:51 -0800327 repeated MatcherStats matcher_stats = 13;
328 repeated ConditionStats condition_stats = 14;
329 repeated MetricStats metric_stats = 15;
330 repeated AlertStats alert_stats = 16;
Yangster-mac306ccc22018-03-24 15:03:40 -0700331 repeated MetricStats metric_dimension_in_condition_stats = 17;
David Chenfaa1af52018-03-30 15:14:04 -0700332 message Annotation {
333 optional int64 field_int64 = 1;
334 optional int32 field_int32 = 2;
335 }
336 repeated Annotation annotation = 18;
Yao Chen20e9e622018-02-28 11:18:51 -0800337 }
338
339 repeated ConfigStats config_stats = 3;
340
341 message AtomStats {
342 optional int32 tag = 1;
343 optional int32 count = 2;
344 }
345
346 repeated AtomStats atom_stats = 7;
347
348 message UidMapStats {
David Chenbd125272018-04-04 19:02:50 -0700349 optional int32 changes = 1;
350 optional int32 bytes_used = 2;
351 optional int32 dropped_changes = 3;
352 optional int32 deleted_apps = 4;
Yao Chen20e9e622018-02-28 11:18:51 -0800353 }
354 optional UidMapStats uidmap_stats = 8;
355
356 message AnomalyAlarmStats {
357 optional int32 alarms_registered = 1;
358 }
359 optional AnomalyAlarmStats anomaly_alarm_stats = 9;
360
361 message PulledAtomStats {
362 optional int32 atom_id = 1;
363 optional int64 total_pull = 2;
364 optional int64 total_pull_from_cache = 3;
365 optional int64 min_pull_interval_sec = 4;
366 }
367 repeated PulledAtomStats pulled_atom_stats = 10;
368
369 message LoggerErrorStats {
370 optional int32 logger_disconnection_sec = 1;
371 optional int32 error_code = 2;
372 }
373 repeated LoggerErrorStats logger_error_stats = 11;
Yangster-macb8382a12018-04-04 10:39:12 -0700374
375 message PeriodicAlarmStats {
376 optional int32 alarms_registered = 1;
377 }
378 optional PeriodicAlarmStats periodic_alarm_stats = 12;
379
380 message SkippedLogEventStats {
381 optional int32 tag = 1;
382 optional int64 elapsed_timestamp_nanos = 2;
383 }
384 repeated SkippedLogEventStats skipped_log_event_stats = 13;
Yao Chen163d2602018-04-10 10:39:53 -0700385
386 repeated int64 log_loss_stats = 14;
Yangster-mac892f3d32018-05-02 14:16:48 -0700387
388 repeated int32 system_restart_sec = 15;
Yao Chen20e9e622018-02-28 11:18:51 -0800389}