• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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