blob: bd3f3cae98902ab8f5b82cf72d0eb017d760fd10 [file] [log] [blame]
Ana Krulecafb45842019-02-13 13:33:03 -08001/*
2 * Copyright 2019 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#pragma once
18
Dominik Laskowski59db9562022-10-27 16:18:53 -040019#include <ftl/fake_guard.h>
Ana Krulecafb45842019-02-13 13:33:03 -080020#include <gmock/gmock.h>
Ady Abraham0f4a1b12019-06-04 16:04:04 -070021#include <gui/ISurfaceComposer.h>
Ana Krulecafb45842019-02-13 13:33:03 -080022
Dominik Laskowski63f12792023-01-21 16:58:22 -050023#include <scheduler/interface/ICompositor.h>
24
Ana Krulecafb45842019-02-13 13:33:03 -080025#include "Scheduler/EventThread.h"
Dominik Laskowski49cea512019-11-12 14:13:23 -080026#include "Scheduler/LayerHistory.h"
Ana Krulecafb45842019-02-13 13:33:03 -080027#include "Scheduler/Scheduler.h"
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070028#include "Scheduler/VSyncTracker.h"
Ady Abraham8cb21882020-08-26 18:22:05 -070029#include "Scheduler/VsyncController.h"
Ady Abraham011f8ba2022-11-22 15:09:07 -080030#include "mock/MockVSyncDispatch.h"
Ady Abraham8cb21882020-08-26 18:22:05 -070031#include "mock/MockVSyncTracker.h"
32#include "mock/MockVsyncController.h"
Ana Krulecafb45842019-02-13 13:33:03 -080033
Dominik Laskowski068173d2021-08-11 17:22:59 -070034namespace android::scheduler {
Ana Krulecafb45842019-02-13 13:33:03 -080035
Dominik Laskowski756b7892021-08-04 12:53:59 -070036class TestableScheduler : public Scheduler, private ICompositor {
Ana Krulecafb45842019-02-13 13:33:03 -080037public:
Dominik Laskowskib5a094b2022-10-27 12:00:12 -040038 TestableScheduler(RefreshRateSelectorPtr selectorPtr, ISchedulerCallback& callback)
Ady Abraham8cb21882020-08-26 18:22:05 -070039 : TestableScheduler(std::make_unique<mock::VsyncController>(),
Leon Scroggins IIIdb16a2b2023-02-06 17:50:05 -050040 std::make_unique<mock::VSyncTracker>(), std::move(selectorPtr),
Dominik Laskowski1c99a002023-01-20 17:10:36 -050041 /* modulatorPtr */ nullptr, callback) {}
Dominik Laskowski98041832019-08-01 18:35:59 -070042
Dominik Laskowski068173d2021-08-11 17:22:59 -070043 TestableScheduler(std::unique_ptr<VsyncController> controller,
Leon Scroggins IIIdb16a2b2023-02-06 17:50:05 -050044 std::unique_ptr<VSyncTracker> tracker, RefreshRateSelectorPtr selectorPtr,
Dominik Laskowski1c99a002023-01-20 17:10:36 -050045 sp<VsyncModulator> modulatorPtr, ISchedulerCallback& callback)
46 : Scheduler(*this, callback, Feature::kContentDetection, std::move(modulatorPtr)) {
Leon Scroggins IIIc275df42023-02-07 16:40:21 -050047 mVsyncSchedule = std::unique_ptr<VsyncSchedule>(
48 new VsyncSchedule(std::move(tracker), std::make_unique<mock::VSyncDispatch>(),
49 std::move(controller)));
Leon Scroggins IIIdb16a2b2023-02-06 17:50:05 -050050
Ady Abrahamace3d052022-11-17 16:25:05 -080051 const auto displayId = selectorPtr->getActiveMode().modePtr->getPhysicalDisplayId();
Leon Scroggins IIIdb16a2b2023-02-06 17:50:05 -050052 registerDisplay(displayId, std::move(selectorPtr));
Dominik Laskowski756b7892021-08-04 12:53:59 -070053
54 ON_CALL(*this, postMessage).WillByDefault([](sp<MessageHandler>&& handler) {
55 // Execute task to prevent broken promise exception on destruction.
56 handler->handleMessage(Message());
57 });
Dominik Laskowski9c93d602021-10-07 19:38:26 -070058 }
Ana Krulecafb45842019-02-13 13:33:03 -080059
Dominik Laskowskif11728a2022-07-28 13:07:42 -070060 MOCK_METHOD(void, scheduleConfigure, (), (override));
Dominik Laskowski46f3e3b2021-08-10 11:44:24 -070061 MOCK_METHOD(void, scheduleFrame, (), (override));
Dominik Laskowski756b7892021-08-04 12:53:59 -070062 MOCK_METHOD(void, postMessage, (sp<MessageHandler>&&), (override));
63
Dominik Laskowski98041832019-08-01 18:35:59 -070064 // Used to inject mock event thread.
65 ConnectionHandle createConnection(std::unique_ptr<EventThread> eventThread) {
Steven Thomas2bbaabe2019-08-28 16:08:35 -070066 return Scheduler::createConnection(std::move(eventThread));
Ana Krulecafb45842019-02-13 13:33:03 -080067 }
68
Dominik Laskowski596a2562022-10-28 11:26:12 -040069 auto refreshRateSelector() { return leaderSelectorPtr(); }
Dominik Laskowski983f2b52020-06-25 16:54:06 -070070
Dominik Laskowski596a2562022-10-28 11:26:12 -040071 const auto& refreshRateSelectors() const NO_THREAD_SAFETY_ANALYSIS {
72 return mRefreshRateSelectors;
73 }
74
Dominik Laskowski596a2562022-10-28 11:26:12 -040075 void registerDisplay(PhysicalDisplayId displayId, RefreshRateSelectorPtr selectorPtr) {
Dominik Laskowski59db9562022-10-27 16:18:53 -040076 ftl::FakeGuard guard(kMainThreadContext);
Leon Scroggins IIIdb16a2b2023-02-06 17:50:05 -050077 Scheduler::registerDisplay(displayId, std::move(selectorPtr));
Dominik Laskowski596a2562022-10-28 11:26:12 -040078 }
79
80 void unregisterDisplay(PhysicalDisplayId displayId) {
81 ftl::FakeGuard guard(kMainThreadContext);
82 Scheduler::unregisterDisplay(displayId);
83 }
84
Dominik Laskowskic132a152022-11-30 15:44:52 -050085 std::optional<PhysicalDisplayId> leaderDisplayId() const NO_THREAD_SAFETY_ANALYSIS {
86 return mLeaderDisplayId;
87 }
88
Dominik Laskowski596a2562022-10-28 11:26:12 -040089 void setLeaderDisplay(PhysicalDisplayId displayId) {
90 ftl::FakeGuard guard(kMainThreadContext);
91 Scheduler::setLeaderDisplay(displayId);
Dominik Laskowski59db9562022-10-27 16:18:53 -040092 }
93
Dominik Laskowski1c99a002023-01-20 17:10:36 -050094 auto& mutableVsyncModulator() { return *mVsyncModulator; }
Dominik Laskowskib5a094b2022-10-27 12:00:12 -040095 auto& mutableLayerHistory() { return mLayerHistory; }
ramindani69b58e82022-09-26 16:48:36 -070096
Nathaniel Nifong1303d912021-10-06 09:41:24 -040097 size_t layerHistorySize() NO_THREAD_SAFETY_ANALYSIS {
98 return mLayerHistory.mActiveLayerInfos.size() + mLayerHistory.mInactiveLayerInfos.size();
99 }
Dominik Laskowski983f2b52020-06-25 16:54:06 -0700100
Nathaniel Nifong1303d912021-10-06 09:41:24 -0400101 size_t getNumActiveLayers() NO_THREAD_SAFETY_ANALYSIS {
102 return mLayerHistory.mActiveLayerInfos.size();
103 }
104
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100105 void replaceTouchTimer(int64_t millis) {
106 if (mTouchTimer) {
107 mTouchTimer.reset();
108 }
109 mTouchTimer.emplace(
Ady Abrahamdb3dfee2020-11-17 17:07:12 -0800110 "Testable Touch timer", std::chrono::milliseconds(millis),
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100111 [this] { touchTimerCallback(TimerState::Reset); },
112 [this] { touchTimerCallback(TimerState::Expired); });
113 mTouchTimer->start();
114 }
115
116 bool isTouchActive() {
Dominik Laskowski068173d2021-08-11 17:22:59 -0700117 std::lock_guard<std::mutex> lock(mPolicyLock);
118 return mPolicy.touch == Scheduler::TouchState::Active;
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100119 }
120
ramindani69b58e82022-09-26 16:48:36 -0700121 void setTouchStateAndIdleTimerPolicy(GlobalSignals globalSignals) {
122 std::lock_guard<std::mutex> lock(mPolicyLock);
123 mPolicy.touch = globalSignals.touch ? TouchState::Active : TouchState::Inactive;
124 mPolicy.idleTimer = globalSignals.idle ? TimerState::Expired : TimerState::Reset;
125 }
126
Dominik Laskowskid82e0f02022-10-26 15:23:04 -0400127 void setContentRequirements(std::vector<RefreshRateSelector::LayerRequirement> layers) {
ramindani69b58e82022-09-26 16:48:36 -0700128 std::lock_guard<std::mutex> lock(mPolicyLock);
129 mPolicy.contentRequirements = std::move(layers);
130 }
131
Dominik Laskowski530d6bd2022-10-10 16:55:54 -0400132 using Scheduler::DisplayModeChoice;
133 using Scheduler::DisplayModeChoiceMap;
134
Dominik Laskowski596a2562022-10-28 11:26:12 -0400135 DisplayModeChoiceMap chooseDisplayModes() NO_THREAD_SAFETY_ANALYSIS {
Dominik Laskowski530d6bd2022-10-10 16:55:54 -0400136 return Scheduler::chooseDisplayModes();
ramindani69b58e82022-09-26 16:48:36 -0700137 }
138
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100139 void dispatchCachedReportedMode() {
Dominik Laskowski068173d2021-08-11 17:22:59 -0700140 std::lock_guard<std::mutex> lock(mPolicyLock);
Dominik Laskowski596a2562022-10-28 11:26:12 -0400141 Scheduler::dispatchCachedReportedMode();
Ana Krulec6ddd2612020-09-24 13:06:33 -0700142 }
143
Dominik Laskowski068173d2021-08-11 17:22:59 -0700144 void clearCachedReportedMode() {
145 std::lock_guard<std::mutex> lock(mPolicyLock);
146 mPolicy.cachedModeChangedParams.reset();
Ana Krulec6ddd2612020-09-24 13:06:33 -0700147 }
148
Ady Abrahamace3d052022-11-17 16:25:05 -0800149 void onNonPrimaryDisplayModeChanged(ConnectionHandle handle, const FrameRateMode& mode) {
Dominik Laskowski596a2562022-10-28 11:26:12 -0400150 Scheduler::onNonPrimaryDisplayModeChanged(handle, mode);
Ana Krulec6ddd2612020-09-24 13:06:33 -0700151 }
152
Leon Scroggins IIIc275df42023-02-07 16:40:21 -0500153 void setInitialHwVsyncEnabled(bool enabled) {
154 std::lock_guard<std::mutex> lock(mVsyncSchedule->mHwVsyncLock);
155 mVsyncSchedule->mHwVsyncState = enabled ? VsyncSchedule::HwVsyncState::Enabled
156 : VsyncSchedule::HwVsyncState::Disabled;
157 }
158
Dominik Laskowski756b7892021-08-04 12:53:59 -0700159private:
160 // ICompositor overrides:
Dominik Laskowskif11728a2022-07-28 13:07:42 -0700161 void configure() override {}
Dominik Laskowski08fbd852022-07-14 08:53:42 -0700162 bool commit(TimePoint, VsyncId, TimePoint) override { return false; }
163 void composite(TimePoint, VsyncId) override {}
Dominik Laskowski756b7892021-08-04 12:53:59 -0700164 void sample() override {}
Ana Krulecafb45842019-02-13 13:33:03 -0800165};
166
Dominik Laskowski068173d2021-08-11 17:22:59 -0700167} // namespace android::scheduler