1/*
2 * Copyright (C) 2018 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 */
16
17syntax = "proto2";
18
19// C++ namespace: bluetooth::metrics::BluetoothMetricsProto
20package bluetooth.metrics.BluetoothMetricsProto;
21
22option java_package = "com.android.bluetooth";
23option java_outer_classname = "BluetoothMetricsProto";
24
25message BluetoothLog {
26  // Session information that gets logged for every BT connection.
27  repeated BluetoothSession session = 1;
28
29  // Session information that gets logged for every Pair event.
30  repeated PairEvent pair_event = 2;
31
32  // Information for Wake locks.
33  repeated WakeEvent wake_event = 3;
34
35  // Scan event information.
36  repeated ScanEvent scan_event = 4;
37
38  // Number of bonded devices.
39  optional int32 num_bonded_devices = 5;
40
41  // Number of BluetoothSession including discarded ones beyond capacity
42  optional int64 num_bluetooth_session = 6;
43
44  // Number of PairEvent including discarded ones beyond capacity
45  optional int64 num_pair_event = 7;
46
47  // Number of WakeEvent including discarded ones beyond capacity
48  optional int64 num_wake_event = 8;
49
50  // Number of ScanEvent including discarded ones beyond capacity
51  optional int64 num_scan_event = 9;
52
53  // Statistics about Bluetooth profile connections
54  repeated ProfileConnectionStats profile_connection_stats = 10;
55
56  // Statistics about Headset profile connections
57  repeated HeadsetProfileConnectionStats headset_profile_connection_stats = 11;
58}
59
60// The information about the device.
61message DeviceInfo {
62  // Device type.
63  enum DeviceType {
64    // Type is unknown.
65    DEVICE_TYPE_UNKNOWN = 0;
66
67    DEVICE_TYPE_BREDR = 1;
68
69    DEVICE_TYPE_LE = 2;
70
71    DEVICE_TYPE_DUMO = 3;
72  }
73
74  // Device class
75  // https://cs.corp.google.com/#android/packages/modules/Bluetooth/system/stack/include/btm_api.h&q=major_computer.
76  optional int32 device_class = 1;
77
78  // Device type.
79  optional DeviceType device_type = 2;
80}
81
82// Information that gets logged for every Bluetooth connection.
83message BluetoothSession {
84  // Type of technology used in the connection.
85  enum ConnectionTechnologyType {
86    CONNECTION_TECHNOLOGY_TYPE_UNKNOWN = 0;
87
88    CONNECTION_TECHNOLOGY_TYPE_LE = 1;
89
90    CONNECTION_TECHNOLOGY_TYPE_BREDR = 2;
91  }
92
93  enum DisconnectReasonType {
94    UNKNOWN = 0;
95
96    // A metrics dump takes a snapshot of current Bluetooth session and thus
97    // is not a real disconnect, but a discontinuation in metrics logging.
98    // This enum indicates this situation.
99    METRICS_DUMP = 1;
100
101    NEXT_START_WITHOUT_END_PREVIOUS = 2;
102  }
103
104  // Duration of the session.
105  optional int64 session_duration_sec = 2;
106
107  // Technology type.
108  optional ConnectionTechnologyType connection_technology_type = 3;
109
110  // Reason for disconnecting.
111  optional string disconnect_reason = 4 [deprecated = true];
112
113  // The information about the device which it is connected to.
114  optional DeviceInfo device_connected_to = 5;
115
116  // The information about the RFComm session.
117  optional RFCommSession rfcomm_session = 6;
118
119  // The information about the A2DP audio session.
120  optional A2DPSession a2dp_session = 7;
121
122  // Numeric reason for disconnecting as defined in metrics.h
123  optional DisconnectReasonType disconnect_reason_type = 8;
124}
125
126message RFCommSession {
127  // bytes transmitted.
128  optional int32 rx_bytes = 1;
129
130  // bytes transmitted.
131  optional int32 tx_bytes = 2;
132}
133
134enum A2dpSourceCodec {
135  A2DP_SOURCE_CODEC_UNKNOWN = 0;
136  A2DP_SOURCE_CODEC_SBC = 1;
137  A2DP_SOURCE_CODEC_AAC = 2;
138  A2DP_SOURCE_CODEC_APTX = 3;
139  A2DP_SOURCE_CODEC_APTX_HD = 4;
140  A2DP_SOURCE_CODEC_LDAC = 5;
141}
142
143// Session information that gets logged for A2DP session.
144message A2DPSession {
145  // Media timer in milliseconds.
146  optional int32 media_timer_min_millis = 1;
147
148  // Media timer in milliseconds.
149  optional int32 media_timer_max_millis = 2;
150
151  // Media timer in milliseconds.
152  optional int32 media_timer_avg_millis = 3;
153
154  // Buffer overruns count.
155  optional int32 buffer_overruns_max_count = 4;
156
157  // Buffer overruns total.
158  optional int32 buffer_overruns_total = 5;
159
160  // Buffer underruns average.
161  optional float buffer_underruns_average = 6;
162
163  // Buffer underruns count.
164  optional int32 buffer_underruns_count = 7;
165
166  // Total audio time in this A2DP session
167  optional int64 audio_duration_millis = 8;
168
169  // Audio codec used in this A2DP session in A2DP source role
170  optional A2dpSourceCodec source_codec = 9;
171
172  // Whether A2DP offload is enabled in this A2DP session
173  optional bool is_a2dp_offload = 10;
174}
175
176message PairEvent {
177  // The reason for disconnecting
178  // See: packages/modules/Bluetooth/system/stack/include/hcidefs.h, HCI_ERR_CONN_FAILED_ESTABLISHMENT
179  optional int32 disconnect_reason = 1;
180
181  // Pair event time
182  optional int64 event_time_millis = 2;  // [(datapol.semantic_type) = ST_TIMESTAMP];
183
184  // The information about the device which it is paired to.
185  optional DeviceInfo device_paired_with = 3;
186}
187
188message WakeEvent {
189  // Information about the wake event type.
190  enum WakeEventType {
191    UNKNOWN = 0;
192    // WakeLock was acquired.
193    ACQUIRED = 1;
194    // WakeLock was released.
195    RELEASED = 2;
196  }
197
198  // Information about the wake event type.
199  optional WakeEventType wake_event_type = 1;
200
201  // Initiator of the scan. Only the first three names will be stored.
202  // e.g. com.company.app
203  optional string requestor = 2;
204
205  // Name of the wakelock (e.g. bluedroid_timer).
206  optional string name = 3;
207
208  // Time of the event.
209  optional int64 event_time_millis = 4;  // [(datapol.semantic_type) = ST_TIMESTAMP];
210}
211
212message ScanEvent {
213  // Scan type.
214  enum ScanTechnologyType {
215    SCAN_TYPE_UNKNOWN = 0;
216
217    SCAN_TECH_TYPE_LE = 1;
218
219    SCAN_TECH_TYPE_BREDR = 2;
220
221    SCAN_TECH_TYPE_BOTH = 3;
222  }
223
224  // Scan event type.
225  enum ScanEventType {
226    // Scan started.
227    SCAN_EVENT_START = 0;
228    // Scan stopped.
229    SCAN_EVENT_STOP = 1;
230  }
231
232  // Scan event type.
233  optional ScanEventType scan_event_type = 1;
234
235  // Initiator of the scan. Only the first three names will be stored.
236  // e.g. com.company.app
237  optional string initiator = 2;
238
239  // Technology used for scanning.
240  optional ScanTechnologyType scan_technology_type = 3;
241
242  // Number of results returned.
243  optional int32 number_results = 4;
244
245  // Time of the event.
246  optional int64 event_time_millis = 5;  // [(datapol.semantic_type) = ST_TIMESTAMP];
247}
248
249// Profile IDs defined in BluetoothProfile API class
250// Values must match API class values
251enum ProfileId {
252  PROFILE_UNKNOWN = 0;
253  HEADSET = 1;
254  A2DP = 2;
255  HEALTH = 3;
256  HID_HOST = 4;
257  PAN = 5;
258  PBAP = 6;
259  GATT = 7;
260  GATT_SERVER = 8;
261  MAP = 9;
262  SAP = 10;
263  A2DP_SINK = 11;
264  AVRCP_CONTROLLER = 12;
265  AVRCP = 13;
266  HEADSET_CLIENT = 16;
267  PBAP_CLIENT = 17;
268  MAP_CLIENT = 18;
269  HID_DEVICE = 19;
270  OPP = 20;
271  HEARING_AID = 21;
272}
273
274// Statistics about Bluetooth profile connections
275message ProfileConnectionStats {
276  // Profile id defined in BluetoothProfile.java
277  optional ProfileId profile_id = 1;
278
279  // Number of times that this profile is connected since last metrics dump
280  optional int32 num_times_connected = 2;
281}
282
283enum HeadsetProfileType {
284  HEADSET_PROFILE_UNKNOWN = 0;
285  HSP = 1;
286  HFP = 2;
287}
288
289// Statistics about headset profile connections
290message HeadsetProfileConnectionStats {
291  // Type of headset profile connected
292  optional HeadsetProfileType headset_profile_type = 1;
293
294  // Number of times this type of headset profile is connected
295  optional int32 num_times_connected = 2;
296}
297
298/**
299* Encapsulates Remote Device Information. Needs to be kept consistent with
300* BluetoothRemoteDeviceInformation
301* in frameworks/proto_logging/stats/atoms/bluetooth/bluetooth_extension_atoms.proto
302*
303* Logged from:
304*    packages/modules/Bluetooth
305*/
306message BluetoothRemoteDeviceInformation {
307  // SHA256 hashed Bluetooth device name.
308  optional string allowlisted_device_name_hash = 1;
309
310  // Class of Device
311  optional int32 class_of_device = 2;
312
313  // The first three bytes of MAC address
314  optional int32 oui = 3;
315}
316