blob: b8a60638ae2c4b5f328101cef5327e0222110d2e [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
Ana Krulec6ddd2612020-09-24 13:06:33 -070019#include <Scheduler/Scheduler.h>
Dominik Laskowski59db9562022-10-27 16:18:53 -040020#include <ftl/fake_guard.h>
Ana Krulecafb45842019-02-13 13:33:03 -080021#include <gmock/gmock.h>
Ady Abraham0f4a1b12019-06-04 16:04:04 -070022#include <gui/ISurfaceComposer.h>
Ana Krulecafb45842019-02-13 13:33:03 -080023
24#include "Scheduler/EventThread.h"
Dominik Laskowski49cea512019-11-12 14:13:23 -080025#include "Scheduler/LayerHistory.h"
Ana Krulecafb45842019-02-13 13:33:03 -080026#include "Scheduler/Scheduler.h"
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070027#include "Scheduler/VSyncTracker.h"
Ady Abraham8cb21882020-08-26 18:22:05 -070028#include "Scheduler/VsyncController.h"
29#include "mock/MockVSyncTracker.h"
30#include "mock/MockVsyncController.h"
Ana Krulecafb45842019-02-13 13:33:03 -080031
Dominik Laskowski068173d2021-08-11 17:22:59 -070032namespace android::scheduler {
Ana Krulecafb45842019-02-13 13:33:03 -080033
Dominik Laskowski756b7892021-08-04 12:53:59 -070034class TestableScheduler : public Scheduler, private ICompositor {
Ana Krulecafb45842019-02-13 13:33:03 -080035public:
Dominik Laskowskib5a094b2022-10-27 12:00:12 -040036 TestableScheduler(RefreshRateSelectorPtr selectorPtr, ISchedulerCallback& callback)
Ady Abraham8cb21882020-08-26 18:22:05 -070037 : TestableScheduler(std::make_unique<mock::VsyncController>(),
Dominik Laskowskid82e0f02022-10-26 15:23:04 -040038 std::make_unique<mock::VSyncTracker>(), std::move(selectorPtr),
Ady Abraham3efa3942021-06-24 19:01:25 -070039 callback) {}
Dominik Laskowski98041832019-08-01 18:35:59 -070040
Dominik Laskowski068173d2021-08-11 17:22:59 -070041 TestableScheduler(std::unique_ptr<VsyncController> controller,
Dominik Laskowskib5a094b2022-10-27 12:00:12 -040042 std::unique_ptr<VSyncTracker> tracker, RefreshRateSelectorPtr selectorPtr,
Dominik Laskowskid82e0f02022-10-26 15:23:04 -040043 ISchedulerCallback& callback)
Dominik Laskowski068173d2021-08-11 17:22:59 -070044 : Scheduler(*this, callback, Feature::kContentDetection) {
45 mVsyncSchedule.emplace(VsyncSchedule(std::move(tracker), nullptr, std::move(controller)));
Dominik Laskowski596a2562022-10-28 11:26:12 -040046
Ady Abrahamace3d052022-11-17 16:25:05 -080047 const auto displayId = selectorPtr->getActiveMode().modePtr->getPhysicalDisplayId();
Dominik Laskowski596a2562022-10-28 11:26:12 -040048 registerDisplay(displayId, std::move(selectorPtr));
Dominik Laskowski756b7892021-08-04 12:53:59 -070049
50 ON_CALL(*this, postMessage).WillByDefault([](sp<MessageHandler>&& handler) {
51 // Execute task to prevent broken promise exception on destruction.
52 handler->handleMessage(Message());
53 });
Dominik Laskowski9c93d602021-10-07 19:38:26 -070054 }
Ana Krulecafb45842019-02-13 13:33:03 -080055
Dominik Laskowskif11728a2022-07-28 13:07:42 -070056 MOCK_METHOD(void, scheduleConfigure, (), (override));
Dominik Laskowski46f3e3b2021-08-10 11:44:24 -070057 MOCK_METHOD(void, scheduleFrame, (), (override));
Dominik Laskowski756b7892021-08-04 12:53:59 -070058 MOCK_METHOD(void, postMessage, (sp<MessageHandler>&&), (override));
59
Dominik Laskowski98041832019-08-01 18:35:59 -070060 // Used to inject mock event thread.
61 ConnectionHandle createConnection(std::unique_ptr<EventThread> eventThread) {
Steven Thomas2bbaabe2019-08-28 16:08:35 -070062 return Scheduler::createConnection(std::move(eventThread));
Ana Krulecafb45842019-02-13 13:33:03 -080063 }
64
65 /* ------------------------------------------------------------------------
66 * Read-write access to private data to set up preconditions and assert
67 * post-conditions.
68 */
69 auto& mutablePrimaryHWVsyncEnabled() { return mPrimaryHWVsyncEnabled; }
Ana Krulecafb45842019-02-13 13:33:03 -080070 auto& mutableHWVsyncAvailable() { return mHWVsyncAvailable; }
Lais Andrade3a6e47d2020-04-02 11:20:16 +010071
Dominik Laskowski596a2562022-10-28 11:26:12 -040072 auto refreshRateSelector() { return leaderSelectorPtr(); }
Dominik Laskowski983f2b52020-06-25 16:54:06 -070073
Dominik Laskowski596a2562022-10-28 11:26:12 -040074 const auto& refreshRateSelectors() const NO_THREAD_SAFETY_ANALYSIS {
75 return mRefreshRateSelectors;
76 }
77
78 bool hasRefreshRateSelectors() const { return !refreshRateSelectors().empty(); }
79
80 void registerDisplay(PhysicalDisplayId displayId, RefreshRateSelectorPtr selectorPtr) {
Dominik Laskowski59db9562022-10-27 16:18:53 -040081 ftl::FakeGuard guard(kMainThreadContext);
Dominik Laskowski596a2562022-10-28 11:26:12 -040082 Scheduler::registerDisplay(displayId, std::move(selectorPtr));
83 }
84
85 void unregisterDisplay(PhysicalDisplayId displayId) {
86 ftl::FakeGuard guard(kMainThreadContext);
87 Scheduler::unregisterDisplay(displayId);
88 }
89
Dominik Laskowskic132a152022-11-30 15:44:52 -050090 std::optional<PhysicalDisplayId> leaderDisplayId() const NO_THREAD_SAFETY_ANALYSIS {
91 return mLeaderDisplayId;
92 }
93
Dominik Laskowski596a2562022-10-28 11:26:12 -040094 void setLeaderDisplay(PhysicalDisplayId displayId) {
95 ftl::FakeGuard guard(kMainThreadContext);
96 Scheduler::setLeaderDisplay(displayId);
Dominik Laskowski59db9562022-10-27 16:18:53 -040097 }
98
Dominik Laskowskib5a094b2022-10-27 12:00:12 -040099 auto& mutableLayerHistory() { return mLayerHistory; }
ramindani69b58e82022-09-26 16:48:36 -0700100
Nathaniel Nifong1303d912021-10-06 09:41:24 -0400101 size_t layerHistorySize() NO_THREAD_SAFETY_ANALYSIS {
102 return mLayerHistory.mActiveLayerInfos.size() + mLayerHistory.mInactiveLayerInfos.size();
103 }
Dominik Laskowski983f2b52020-06-25 16:54:06 -0700104
Nathaniel Nifong1303d912021-10-06 09:41:24 -0400105 size_t getNumActiveLayers() NO_THREAD_SAFETY_ANALYSIS {
106 return mLayerHistory.mActiveLayerInfos.size();
107 }
108
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100109 void replaceTouchTimer(int64_t millis) {
110 if (mTouchTimer) {
111 mTouchTimer.reset();
112 }
113 mTouchTimer.emplace(
Ady Abrahamdb3dfee2020-11-17 17:07:12 -0800114 "Testable Touch timer", std::chrono::milliseconds(millis),
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100115 [this] { touchTimerCallback(TimerState::Reset); },
116 [this] { touchTimerCallback(TimerState::Expired); });
117 mTouchTimer->start();
118 }
119
120 bool isTouchActive() {
Dominik Laskowski068173d2021-08-11 17:22:59 -0700121 std::lock_guard<std::mutex> lock(mPolicyLock);
122 return mPolicy.touch == Scheduler::TouchState::Active;
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100123 }
124
ramindani69b58e82022-09-26 16:48:36 -0700125 void setTouchStateAndIdleTimerPolicy(GlobalSignals globalSignals) {
126 std::lock_guard<std::mutex> lock(mPolicyLock);
127 mPolicy.touch = globalSignals.touch ? TouchState::Active : TouchState::Inactive;
128 mPolicy.idleTimer = globalSignals.idle ? TimerState::Expired : TimerState::Reset;
129 }
130
Dominik Laskowskid82e0f02022-10-26 15:23:04 -0400131 void setContentRequirements(std::vector<RefreshRateSelector::LayerRequirement> layers) {
ramindani69b58e82022-09-26 16:48:36 -0700132 std::lock_guard<std::mutex> lock(mPolicyLock);
133 mPolicy.contentRequirements = std::move(layers);
134 }
135
Dominik Laskowski530d6bd2022-10-10 16:55:54 -0400136 using Scheduler::DisplayModeChoice;
137 using Scheduler::DisplayModeChoiceMap;
138
Dominik Laskowski596a2562022-10-28 11:26:12 -0400139 DisplayModeChoiceMap chooseDisplayModes() NO_THREAD_SAFETY_ANALYSIS {
Dominik Laskowski530d6bd2022-10-10 16:55:54 -0400140 return Scheduler::chooseDisplayModes();
ramindani69b58e82022-09-26 16:48:36 -0700141 }
142
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100143 void dispatchCachedReportedMode() {
Dominik Laskowski068173d2021-08-11 17:22:59 -0700144 std::lock_guard<std::mutex> lock(mPolicyLock);
Dominik Laskowski596a2562022-10-28 11:26:12 -0400145 Scheduler::dispatchCachedReportedMode();
Ana Krulec6ddd2612020-09-24 13:06:33 -0700146 }
147
Dominik Laskowski068173d2021-08-11 17:22:59 -0700148 void clearCachedReportedMode() {
149 std::lock_guard<std::mutex> lock(mPolicyLock);
150 mPolicy.cachedModeChangedParams.reset();
Ana Krulec6ddd2612020-09-24 13:06:33 -0700151 }
152
Ady Abrahamace3d052022-11-17 16:25:05 -0800153 void onNonPrimaryDisplayModeChanged(ConnectionHandle handle, const FrameRateMode& mode) {
Dominik Laskowski596a2562022-10-28 11:26:12 -0400154 Scheduler::onNonPrimaryDisplayModeChanged(handle, mode);
Ana Krulec6ddd2612020-09-24 13:06:33 -0700155 }
156
Dominik Laskowski756b7892021-08-04 12:53:59 -0700157private:
158 // ICompositor overrides:
Dominik Laskowskif11728a2022-07-28 13:07:42 -0700159 void configure() override {}
Dominik Laskowski08fbd852022-07-14 08:53:42 -0700160 bool commit(TimePoint, VsyncId, TimePoint) override { return false; }
161 void composite(TimePoint, VsyncId) override {}
Dominik Laskowski756b7892021-08-04 12:53:59 -0700162 void sample() override {}
Ana Krulecafb45842019-02-13 13:33:03 -0800163};
164
Dominik Laskowski068173d2021-08-11 17:22:59 -0700165} // namespace android::scheduler