1 /**
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
17 #include "GraphicsComposerCallback.h"
18 #include <log/log_main.h>
19 #include <utils/Timers.h>
20
21 #pragma push_macro("LOG_TAG")
22 #undef LOG_TAG
23 #define LOG_TAG "GraphicsComposerCallback"
24
25 namespace aidl::android::hardware::graphics::composer3::vts {
26
setVsyncAllowed(bool allowed)27 void GraphicsComposerCallback::setVsyncAllowed(bool allowed) {
28 std::scoped_lock lock(mMutex);
29 mVsyncAllowed = allowed;
30 }
31
setRefreshRateChangedDebugDataEnabledCallbackAllowed(bool allowed)32 void GraphicsComposerCallback::setRefreshRateChangedDebugDataEnabledCallbackAllowed(bool allowed) {
33 std::scoped_lock lock(mMutex);
34 mRefreshRateChangedDebugDataEnabledCallbackAllowed = allowed;
35 }
36
getDisplays() const37 std::vector<int64_t> GraphicsComposerCallback::getDisplays() const {
38 std::scoped_lock lock(mMutex);
39 return mDisplays;
40 }
41
getInvalidHotplugCount() const42 int32_t GraphicsComposerCallback::getInvalidHotplugCount() const {
43 std::scoped_lock lock(mMutex);
44 return mInvalidHotplugCount;
45 }
46
getInvalidRefreshCount() const47 int32_t GraphicsComposerCallback::getInvalidRefreshCount() const {
48 std::scoped_lock lock(mMutex);
49 return mInvalidRefreshCount;
50 }
51
getInvalidVsyncCount() const52 int32_t GraphicsComposerCallback::getInvalidVsyncCount() const {
53 std::scoped_lock lock(mMutex);
54 return mInvalidVsyncCount;
55 }
56
getInvalidVsyncPeriodChangeCount() const57 int32_t GraphicsComposerCallback::getInvalidVsyncPeriodChangeCount() const {
58 std::scoped_lock lock(mMutex);
59 return mInvalidVsyncPeriodChangeCount;
60 }
61
getInvalidSeamlessPossibleCount() const62 int32_t GraphicsComposerCallback::getInvalidSeamlessPossibleCount() const {
63 std::scoped_lock lock(mMutex);
64 return mInvalidSeamlessPossibleCount;
65 }
66
getVsyncIdleCount() const67 int32_t GraphicsComposerCallback::getVsyncIdleCount() const {
68 std::scoped_lock lock(mMutex);
69 return mVsyncIdleCount;
70 }
71
getVsyncIdleTime() const72 int64_t GraphicsComposerCallback::getVsyncIdleTime() const {
73 std::scoped_lock lock(mMutex);
74 return mVsyncIdleTime;
75 }
76
77 std::optional<VsyncPeriodChangeTimeline>
takeLastVsyncPeriodChangeTimeline()78 GraphicsComposerCallback::takeLastVsyncPeriodChangeTimeline() {
79 std::scoped_lock lock(mMutex);
80
81 std::optional<VsyncPeriodChangeTimeline> ret;
82 ret.swap(mTimeline);
83
84 return ret;
85 }
86
87 std::vector<RefreshRateChangedDebugData>
takeListOfRefreshRateChangedDebugData()88 GraphicsComposerCallback::takeListOfRefreshRateChangedDebugData() {
89 std::scoped_lock lock(mMutex);
90
91 std::vector<RefreshRateChangedDebugData> ret;
92 ret.swap(mRefreshRateChangedDebugData);
93
94 return ret;
95 }
96
getInvalidRefreshRateDebugEnabledCallbackCount() const97 int32_t GraphicsComposerCallback::getInvalidRefreshRateDebugEnabledCallbackCount() const {
98 std::scoped_lock lock(mMutex);
99 return mInvalidRefreshRateDebugEnabledCallbackCount;
100 }
101
onHotplug(int64_t in_display,bool in_connected)102 ::ndk::ScopedAStatus GraphicsComposerCallback::onHotplug(int64_t in_display, bool in_connected) {
103 std::scoped_lock lock(mMutex);
104
105 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
106 if (in_connected) {
107 if (it == mDisplays.end()) {
108 mDisplays.push_back(in_display);
109 } else {
110 mInvalidHotplugCount++;
111 }
112 } else {
113 if (it != mDisplays.end()) {
114 mDisplays.erase(it);
115 } else {
116 mInvalidHotplugCount++;
117 }
118 }
119 return ::ndk::ScopedAStatus::ok();
120 }
121
onRefresh(int64_t in_display)122 ::ndk::ScopedAStatus GraphicsComposerCallback::onRefresh(int64_t in_display) {
123 std::scoped_lock lock(mMutex);
124
125 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
126 if (it == mDisplays.end()) {
127 mInvalidRefreshCount++;
128 }
129
130 return ::ndk::ScopedAStatus::ok();
131 }
132
onVsync(int64_t in_display,int64_t in_timestamp,int32_t in_vsyncPeriodNanos)133 ::ndk::ScopedAStatus GraphicsComposerCallback::onVsync(int64_t in_display, int64_t in_timestamp,
134 int32_t in_vsyncPeriodNanos) {
135 std::scoped_lock lock(mMutex);
136
137 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
138 if (!mVsyncAllowed || it == mDisplays.end()) {
139 mInvalidVsyncCount++;
140 }
141
142 ALOGV("%ld, %d", static_cast<long>(in_timestamp), in_vsyncPeriodNanos);
143
144 return ::ndk::ScopedAStatus::ok();
145 }
146
onRefreshRateChangedDebug(const RefreshRateChangedDebugData & data)147 ::ndk::ScopedAStatus GraphicsComposerCallback::onRefreshRateChangedDebug(
148 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();
158 }
159
onVsyncPeriodTimingChanged(int64_t in_display,const::aidl::android::hardware::graphics::composer3::VsyncPeriodChangeTimeline & in_updatedTimeline)160 ::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);
165
166 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
167 if (it == mDisplays.end()) {
168 mInvalidVsyncPeriodChangeCount++;
169 }
170 mTimeline = in_updatedTimeline;
171
172 return ::ndk::ScopedAStatus::ok();
173 }
174
onSeamlessPossible(int64_t in_display)175 ::ndk::ScopedAStatus GraphicsComposerCallback::onSeamlessPossible(int64_t in_display) {
176 std::scoped_lock lock(mMutex);
177
178 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
179 if (it != mDisplays.end()) {
180 mInvalidSeamlessPossibleCount++;
181 }
182 return ::ndk::ScopedAStatus::ok();
183 }
184
onVsyncIdle(int64_t in_display)185 ::ndk::ScopedAStatus GraphicsComposerCallback::onVsyncIdle(int64_t in_display) {
186 std::scoped_lock lock(mMutex);
187
188 const auto it = std::find(mDisplays.begin(), mDisplays.end(), in_display);
189 if (it != mDisplays.end()) {
190 mVsyncIdleCount++;
191 mVsyncIdleTime = systemTime();
192 }
193 return ::ndk::ScopedAStatus::ok();
194 }
195
196 } // namespace aidl::android::hardware::graphics::composer3::vts
197