blob: ed7ecb42d8e2e31ff638ce6b09c7929fbf17795d [file] [log] [blame]
/*
* Copyright (C) 2023 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
syntax = "proto2";
package android.os.statsd.bluetooth;
import "frameworks/proto_logging/stats/atom_field_options.proto";
import "frameworks/proto_logging/stats/atoms.proto";
import "frameworks/proto_logging/stats/enums/bluetooth/enums.proto";
import "frameworks/proto_logging/stats/enums/bluetooth/hci/enums.proto";
import "frameworks/proto_logging/stats/enums/bluetooth/le/enums.proto";
import "frameworks/proto_logging/stats/enums/bluetooth/rfcomm/enums.proto";
option java_package = "com.android.os.bluetooth";
option java_multiple_files = true;
extend Atom {
optional BluetoothHashedDeviceNameReported bluetooth_hashed_device_name_reported
= 613 [(module) = "bluetooth"];
optional BluetoothL2capCocClientConnection bluetooth_l2cap_coc_client_connection
= 614 [(module) = "bluetooth"];
optional BluetoothL2capCocServerConnection bluetooth_l2cap_coc_server_connection
= 615 [(module) = "bluetooth"];
optional BluetoothLeSessionConnected bluetooth_le_session_connected
= 656 [(module) = "bluetooth"];
optional RestrictedBluetoothDeviceNameReported
restricted_bluetooth_device_name_reported = 666 [
(module) = "bt_restricted",
(restriction_category) = RESTRICTION_DIAGNOSTIC
];
optional BluetoothProfileConnectionAttempted bluetooth_profile_connection_attempted
= 696 [(module) = "bluetooth"];
optional BluetoothContentProfileErrorReported bluetooth_content_profile_error_reported
= 781 [(module) = "bluetooth"];
optional BluetoothRfcommConnectionAttempted bluetooth_rfcomm_connection_attempted
= 782 [(module) = "bluetooth"];
}
/**
* Logs hashed Bluetooth device names
*
* Logged from:
* packages/modules/Bluetooth
*/
message BluetoothHashedDeviceNameReported {
// An identifier that can be used to match events for this device.
// The incremental identifier is locally generated and guaranteed not derived
// from any globally unique hardware id.
// For paired devices, it stays consistent between Bluetooth toggling for the
// same remote device.
// For unpaired devices, it stays consistent within the same Bluetooth adapter
// session for the same remote device.
// Default: 0 if the device's metric id is unknown.
optional int32 metric_id = 1;
// SHA256 hashed Bluetooth device name.
optional string device_name_hash = 2;
}
/**
* Logs when L2CAP CoC on a Bluetooth device connects and disconnects.
*/
message BluetoothL2capCocClientConnection {
// An identifier that can be used to match events for this device.
// The incremental identifier is locally generated and guaranteed not derived
// from any globally unique hardware id.
// For paired devices, it stays consistent between Bluetooth toggling for the
// same remote device.
// For unpaired devices, it stays consistent within the same Bluetooth adapter
// session for the same remote device.
// Default: 0 if the device's metric id is unknown.
optional int32 metric_id = 1;
// Port used for the connection session
optional int32 port = 2;
// Flag to show if the connection is secured or not
optional bool is_secured = 3;
// Result of L2CAP CoC connection
optional android.bluetooth.L2capCocConnectionResult result = 4;
// Latency between connection start and end
optional int64 connection_latency_millis = 5;
// Uid of the app who calls l2cap coc connection API
optional int32 uid = 6 [(is_uid) = true];
// Latency of BluetoothSocket constructor
optional int64 socket_creation_latency_millis = 7;
// Latency of BluetoothSocket.connect
optional int64 socket_connection_latency_millis = 8;
}
/**
* Logs when L2CAP CoC on a Bluetooth device connects and disconnects.
*/
message BluetoothL2capCocServerConnection {
// An identifier that can be used to match events for this device.
// The incremental identifier is locally generated and guaranteed not derived
// from any globally unique hardware id.
// For paired devices, it stays consistent between Bluetooth toggling for the
// same remote device.
// For unpaired devices, it stays consistent within the same Bluetooth adapter
// session for the same remote device.
// Default: 0 if the device's metric id is unknown.
optional int32 metric_id = 1;
// Port used for the connection session
optional int32 port = 2;
// Flag to show if the connection is secured or not
optional bool is_secured = 3;
// Result of L2CAP CoC connection
optional android.bluetooth.L2capCocConnectionResult result = 4;
// Latency between connection start and end
optional int64 latency_since_listening_millis = 5;
// Timeout for connection acceptance. -1 if not timeout.
optional int64 timeout_millis = 6;
// Uid of the app who calls l2cap coc connection API
optional int32 uid = 7 [(is_uid) = true];
// Latency of BluetoothServerSocket constructor
optional int64 socket_creation_latency_millis = 8;
// Latency of BluetoothServerSocket.accept
optional int64 socket_acceptance_latency_millis = 9;
}
/**
* Logs when Bluetooth LE Connection Session is made
*
* Logged from: system/bt
*/
message BluetoothLeSessionConnected {
// Contains the state of the LE Connection Session
// Default: LE_ACL_ABSENT
optional android.bluetooth.le.LeAclConnectionState acl_state = 1;
// Origin type of the connection whether it was from the ORIGIN_JAVA
// or the ORIGIN_NATIVE layer
// Default: ORIGIN_NATIVE
optional android.bluetooth.le.LeConnectionOriginType connection_origin = 2;
// Contains the connection type whether it was CONNECTION_TYPE_GATT
// ,CONNECTION_TYPE_LE_ACL
// Default: CONNECTION_TYPE_LE_ACL
optional android.bluetooth.le.LeConnectionType connection_type = 3;
// Connection State which contain the last state associated with the
// event
// Default: STATE_UNSPECIFIED
optional android.bluetooth.le.LeConnectionState state = 4;
// Contains the latency of the transaction from the beginning till
// the end:
// Default: 0
optional int64 latency_nanos = 5;
// Contains the metric id associated with the remote device
// Default: 0
optional int32 metric_id = 6;
// Contains the UID which is associated with the app
// Default: 0
optional int32 app_uid = 7 [(is_uid) = true];
// Contains the latency of the ACL Connection, which if made will be
// greater than 0
// Default: 0
optional int64 acl_latency_nanos = 8;
// Contains the status of the ACL Transactions, which if made will be
// something other than STATUS_UNKNOWN Default: STATUS_UNKNOWN
optional android.bluetooth.hci.StatusEnum acl_connection_state = 9;
// Identifies whether the LE-ACL Connection failed due to cancellation
// Default: false
optional bool is_cancelled = 10;
}
/**
* Logs the user created Bluetooth device's name.
* It is pushed at Bluetooth pairing and connection.
*
* Logged from:
* packages/modules/Bluetooth
*/
message RestrictedBluetoothDeviceNameReported {
// Name of the Bluetooth device. It is created by the user.
optional string device_name = 1
[(field_restriction_option).peripheral_device_info = true];
}
/**
* Logs profile connection known completions.
*
* Logged from:
* packages/modules/Bluetooth
*/
message BluetoothProfileConnectionAttempted {
// The profile that is connected. Eg. GATT, A2DP, HEADSET.
// From android.bluetooth.BluetoothAdapter.java
// Default: 0 when not used
optional int32 bt_profile = 1;
// Result of Profile connection
optional android.bluetooth.ProfileConnectionResult result = 2;
// Previous connection state
optional android.bluetooth.ConnectionStateEnum previous_state = 3;
// Terminating connection state
optional android.bluetooth.ConnectionStateEnum current_state = 4;
// Reason for the connection result
optional android.bluetooth.ProfileConnectionReason reason = 5;
}
/**
* Logs content profiles' caught exceptions or logs (ERROR, WARN)
*
* Logged from:
* packages/modules/Bluetooth
*/
message BluetoothContentProfileErrorReported {
enum ErrorType {
UNKNOWN = 0;
EXCEPTION = 1;
LOG_ERROR = 2;
LOG_WARN = 3;
}
// The content profile where the error happened. (E.g. PBAP, MAP, OPP)
// From android.bluetooth.BluetoothProfile.java
// Default: 0 when not used
optional int32 bt_profile = 1;
// The file name where the error is reported from
optional android.bluetooth.ContentProfileFileName file_name = 2;
// The type of error (exception, Log.e, Log.w)
optional ErrorType type = 3;
// Integer tag associated with the error
optional int32 tag = 4;
}
message BluetoothRemoteDeviceInformation {
// SHA256 hashed Bluetooth device name.
optional string allowlisted_device_name_hash = 1;
// Class of Device
optional int32 class_of_device = 2;
// The first three bytes of MAC address
optional int32 oui = 3;
}
/**
* Logs RFCOMM connection attempts
*
* Logged from:
* packages/modules/Bluetooth
*/
message BluetoothRfcommConnectionAttempted {
// Locally generated id for event matching
optional int32 metric_id = 1;
// Latency of the connection
optional int64 latency_nanos = 2;
// Whether or not the connection is secured
optional android.bluetooth.rfcomm.SocketConnectionSecurity security = 3;
// Result of Rfcomm connection
optional android.bluetooth.rfcomm.RfcommConnectionResult status = 4;
// is_serial_port is true if the service class UUID is 0x1101
optional bool is_serial_port = 5;
// Uid of the app that calls RFCOMM connection API
optional int32 uid = 6 [(is_uid) = true]; // [(datapol.semantic_type) = ST_SOFTWARE_ID]
// Remote Device Information
optional BluetoothRemoteDeviceInformation remote_device_information = 7 [(log_mode) = MODE_BYTES];
}