blob: 2a8edb67288dfcc44c10558124626ade20a8e043 [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.tv;
import "frameworks/proto_logging/stats/atom_field_options.proto";
import "frameworks/proto_logging/stats/atoms.proto";
option java_package = "com.android.os.tv";
option java_multiple_files = true;
extend Atom {
optional TvLowPowerStandbyPolicy tv_low_power_standby_policy = 679 [(module) = "tv_settings"];
optional ExternalTvInputEvent external_tv_input_event = 717 [(module) = "framework"];
}
/**
* Logs available LowPowerStandby policies.
*/
message TvLowPowerStandbyPolicy {
optional string policy_name = 1;
repeated int32 exempt_uids = 2 [(is_uid) = true];
optional int32 allowed_reasons = 3;
repeated string allowed_features = 4;
optional bool is_selected = 5;
}
/**
* Logs external TV input events.
*/
message ExternalTvInputEvent {
enum EventType {
UNKNOWN = 0;
// a specific input is selected by user/TV App to be displayed on the screen.
TUNED = 1;
// the currently tuned input is released from the screen by selecting a
// new input, TV powering off, going to Home screen, etc.
RELEASED = 2;
// connection state of the current input is changed,
// e.g. connecting/disconnecting the cable.
CONNECTION_STATE_CHANGED = 3;
// device info is updated for the currently selected HDMI-CEC input.
DEVICE_INFO_UPDATED = 4;
}
enum InputState {
// keep in sync with TvInputManager.InputState.
CONNECTED = 0;
CONNECTED_STANDBY = 1;
DISCONNECTED = 2;
}
enum InputType {
// keep in sync with TvinputInfo.Type.
TUNER = 0;
OTHER = 1000;
COMPOSITE = 1001;
SVIDEO = 1002;
SCART = 1003;
COMPONENT = 1004;
VGA = 1005;
DVI = 1006;
HDMI = 1007;
DISPLAY_PORT = 1008;
}
// Type of the event.
optional EventType event_type = 1;
// Connection state of this input.
optional InputState input_state = 2;
// type of the input.
optional InputType input_type = 3;
// Vendor id of the external device for HDMI-CEC input.
// For non-CEC input, the value is 0xFFFFFF (16777215 in decimal).
optional int32 device_vendor_id = 4;
// HDMI port number on TV for HDMI input.
// For non-HDMI input, the value is -1.
optional int32 hdmi_port = 5;
// ID of this TIF (TV Input Framework) session.
optional string tif_session_id = 6;
// OSD display name of the external device for HDMI-CEC input,
// or user-displayed label for other TV inputs.
optional string display_name = 7;
}