blob: 7b3a2b431f27a4c033bc2c36eab9c8c700744d71 [file] [log] [blame]
ramindani1cb794e2021-10-13 20:45:23 +00001/**
2 * Copyright (c) 2021, 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
ramindani458e53e2022-02-23 17:30:16 +000017#include "GraphicsComposerCallback.h"
ramindani1cb794e2021-10-13 20:45:23 +000018#include <log/log_main.h>
Midas Chiena0b56bd2022-01-13 23:27:33 +080019#include <utils/Timers.h>
ramindani1cb794e2021-10-13 20:45:23 +000020
21#pragma push_macro("LOG_TAG")
22#undef LOG_TAG
23#define LOG_TAG "GraphicsComposerCallback"
24
25namespace aidl::android::hardware::graphics::composer3::vts {
26
27void GraphicsComposerCallback::setVsyncAllowed(bool allowed) {
28 std::scoped_lock lock(mMutex);
29 mVsyncAllowed = allowed;
30}
31
ramindani9dd8c482023-02-21 18:07:56 -080032void GraphicsComposerCallback::setRefreshRateChangedDebugDataEnabledCallbackAllowed(bool allowed) {
33 std::scoped_lock lock(mMutex);
34 mRefreshRateChangedDebugDataEnabledCallbackAllowed = allowed;
35}
36
ramindani1cb794e2021-10-13 20:45:23 +000037std::vector<int64_t> GraphicsComposerCallback::getDisplays() const {
38 std::scoped_lock lock(mMutex);
ramindani7ce70fe2022-02-10 18:08:09 +000039 return mDisplays;
ramindani1cb794e2021-10-13 20:45:23 +000040}
41
42int32_t GraphicsComposerCallback::getInvalidHotplugCount() const {
43 std::scoped_lock lock(mMutex);
44 return mInvalidHotplugCount;
45}
46
47int32_t GraphicsComposerCallback::getInvalidRefreshCount() const {
48 std::scoped_lock lock(mMutex);
49 return mInvalidRefreshCount;
50}
51
52int32_t GraphicsComposerCallback::getInvalidVsyncCount() const {
53 std::scoped_lock lock(mMutex);
54 return mInvalidVsyncCount;
55}
56
57int32_t GraphicsComposerCallback::getInvalidVsyncPeriodChangeCount() const {
58 std::scoped_lock lock(mMutex);
59 return mInvalidVsyncPeriodChangeCount;
60}
61
62int32_t GraphicsComposerCallback::getInvalidSeamlessPossibleCount() const {
63 std::scoped_lock lock(mMutex);
64 return mInvalidSeamlessPossibleCount;
65}
66
Midas Chiena0b56bd2022-01-13 23:27:33 +080067int32_t GraphicsComposerCallback::getVsyncIdleCount() const {
68 std::scoped_lock lock(mMutex);
69 return mVsyncIdleCount;
70}
71
72int64_t GraphicsComposerCallback::getVsyncIdleTime() const {
73 std::scoped_lock lock(mMutex);
74 return mVsyncIdleTime;
75}
76
ramindani1cb794e2021-10-13 20:45:23 +000077std::optional<VsyncPeriodChangeTimeline>
78GraphicsComposerCallback::takeLastVsyncPeriodChangeTimeline() {
79 std::scoped_lock lock(mMutex);
80
81 std::optional<VsyncPeriodChangeTimeline> ret;
82 ret.swap(mTimeline);
83
84 return ret;
85}
86
ramindani9dd8c482023-02-21 18:07:56 -080087std::vector<RefreshRateChangedDebugData>
88GraphicsComposerCallback::takeListOfRefreshRateChangedDebugData() {
89 std::scoped_lock lock(mMutex);
90
91 std::vector<RefreshRateChangedDebugData> ret;
92 ret.swap(mRefreshRateChangedDebugData);
93
94 return ret;
95}
96
97int32_t GraphicsComposerCallback::getInvalidRefreshRateDebugEnabledCallbackCount() const {
98 std::scoped_lock lock(mMutex);
99 return mInvalidRefreshRateDebugEnabledCallbackCount;
100}
101
ramindani1cb794e2021-10-13 20:45:23 +0000102::ndk::ScopedAStatus GraphicsComposerCallback::onHotplug(int64_t in_display, bool in_connected) {
103 std::scoped_lock lock(mMutex);
ramindani7ce70fe2022-02-10 18:08:09 +0000104
105 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
ramindani1cb794e2021-10-13 20:45:23 +0000106 if (in_connected) {
ramindani7ce70fe2022-02-10 18:08:09 +0000107 if (it == mDisplays.end()) {
108 mDisplays.push_back(in_display);
109 } else {
ramindani1cb794e2021-10-13 20:45:23 +0000110 mInvalidHotplugCount++;
111 }
112 } else {
ramindani7ce70fe2022-02-10 18:08:09 +0000113 if (it != mDisplays.end()) {
114 mDisplays.erase(it);
115 } else {
ramindani1cb794e2021-10-13 20:45:23 +0000116 mInvalidHotplugCount++;
117 }
118 }
119 return ::ndk::ScopedAStatus::ok();
120}
121
ramindani7ce70fe2022-02-10 18:08:09 +0000122::ndk::ScopedAStatus GraphicsComposerCallback::onRefresh(int64_t in_display) {
ramindani1cb794e2021-10-13 20:45:23 +0000123 std::scoped_lock lock(mMutex);
124
ramindani7ce70fe2022-02-10 18:08:09 +0000125 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
126 if (it == mDisplays.end()) {
ramindani1cb794e2021-10-13 20:45:23 +0000127 mInvalidRefreshCount++;
128 }
129
130 return ::ndk::ScopedAStatus::ok();
131}
132
133::ndk::ScopedAStatus GraphicsComposerCallback::onVsync(int64_t in_display, int64_t in_timestamp,
134 int32_t in_vsyncPeriodNanos) {
135 std::scoped_lock lock(mMutex);
ramindani7ce70fe2022-02-10 18:08:09 +0000136
137 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
138 if (!mVsyncAllowed || it == mDisplays.end()) {
ramindani1cb794e2021-10-13 20:45:23 +0000139 mInvalidVsyncCount++;
140 }
141
142 ALOGV("%ld, %d", static_cast<long>(in_timestamp), in_vsyncPeriodNanos);
143
144 return ::ndk::ScopedAStatus::ok();
145}
146
ramindani83450342023-02-03 12:52:08 -0800147::ndk::ScopedAStatus GraphicsComposerCallback::onRefreshRateChangedDebug(
ramindani9dd8c482023-02-21 18:07:56 -0800148 const RefreshRateChangedDebugData& data) {
149 std::scoped_lock lock(mMutex);
150
151 const auto it = std::find(mDisplays.begin(), mDisplays.end(), data.display);
152 if (mRefreshRateChangedDebugDataEnabledCallbackAllowed && it != mDisplays.end()) {
153 mRefreshRateChangedDebugData.push_back(data);
154 } else {
155 mInvalidRefreshRateDebugEnabledCallbackCount++;
156 }
157 return ::ndk::ScopedAStatus::ok();
ramindani83450342023-02-03 12:52:08 -0800158}
159
ramindani1cb794e2021-10-13 20:45:23 +0000160::ndk::ScopedAStatus GraphicsComposerCallback::onVsyncPeriodTimingChanged(
161 int64_t in_display,
162 const ::aidl::android::hardware::graphics::composer3::VsyncPeriodChangeTimeline&
163 in_updatedTimeline) {
164 std::scoped_lock lock(mMutex);
ramindani7ce70fe2022-02-10 18:08:09 +0000165
166 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
167 if (it == mDisplays.end()) {
ramindani1cb794e2021-10-13 20:45:23 +0000168 mInvalidVsyncPeriodChangeCount++;
169 }
170 mTimeline = in_updatedTimeline;
171
172 return ::ndk::ScopedAStatus::ok();
173}
174
175::ndk::ScopedAStatus GraphicsComposerCallback::onSeamlessPossible(int64_t in_display) {
176 std::scoped_lock lock(mMutex);
ramindani7ce70fe2022-02-10 18:08:09 +0000177
178 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
179 if (it != mDisplays.end()) {
ramindani1cb794e2021-10-13 20:45:23 +0000180 mInvalidSeamlessPossibleCount++;
181 }
182 return ::ndk::ScopedAStatus::ok();
183}
184
Midas Chiena0b56bd2022-01-13 23:27:33 +0800185::ndk::ScopedAStatus GraphicsComposerCallback::onVsyncIdle(int64_t in_display) {
186 std::scoped_lock lock(mMutex);
ramindani7ce70fe2022-02-10 18:08:09 +0000187
188 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
189 if (it != mDisplays.end()) {
Midas Chiena0b56bd2022-01-13 23:27:33 +0800190 mVsyncIdleCount++;
191 mVsyncIdleTime = systemTime();
192 }
193 return ::ndk::ScopedAStatus::ok();
194}
195
ramindani1cb794e2021-10-13 20:45:23 +0000196} // namespace aidl::android::hardware::graphics::composer3::vts