blob: 0cbfa633545f888a2ac246ebe53c17f4091515ee [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"
Ady Abraham011f8ba2022-11-22 15:09:07 -080029#include "mock/MockVSyncDispatch.h"
Ady Abraham8cb21882020-08-26 18:22:05 -070030#include "mock/MockVSyncTracker.h"
31#include "mock/MockVsyncController.h"
Ana Krulecafb45842019-02-13 13:33:03 -080032
Dominik Laskowski068173d2021-08-11 17:22:59 -070033namespace android::scheduler {
Ana Krulecafb45842019-02-13 13:33:03 -080034
Dominik Laskowski756b7892021-08-04 12:53:59 -070035class TestableScheduler : public Scheduler, private ICompositor {
Ana Krulecafb45842019-02-13 13:33:03 -080036public:
Dominik Laskowskib5a094b2022-10-27 12:00:12 -040037 TestableScheduler(RefreshRateSelectorPtr selectorPtr, ISchedulerCallback& callback)
Ady Abraham8cb21882020-08-26 18:22:05 -070038 : TestableScheduler(std::make_unique<mock::VsyncController>(),
Dominik Laskowskid82e0f02022-10-26 15:23:04 -040039 std::make_unique<mock::VSyncTracker>(), std::move(selectorPtr),
Dominik Laskowski1c99a002023-01-20 17:10:36 -050040 /* modulatorPtr */ nullptr, callback) {}
Dominik Laskowski98041832019-08-01 18:35:59 -070041
Dominik Laskowski068173d2021-08-11 17:22:59 -070042 TestableScheduler(std::unique_ptr<VsyncController> controller,
Dominik Laskowskib5a094b2022-10-27 12:00:12 -040043 std::unique_ptr<VSyncTracker> tracker, RefreshRateSelectorPtr selectorPtr,
Dominik Laskowski1c99a002023-01-20 17:10:36 -050044 sp<VsyncModulator> modulatorPtr, ISchedulerCallback& callback)
45 : Scheduler(*this, callback, Feature::kContentDetection, std::move(modulatorPtr)) {
Ady Abraham011f8ba2022-11-22 15:09:07 -080046 mVsyncSchedule.emplace(VsyncSchedule(std::move(tracker),
47 std::make_unique<mock::VSyncDispatch>(),
48 std::move(controller)));
Dominik Laskowski596a2562022-10-28 11:26:12 -040049
Ady Abrahamace3d052022-11-17 16:25:05 -080050 const auto displayId = selectorPtr->getActiveMode().modePtr->getPhysicalDisplayId();
Dominik Laskowski596a2562022-10-28 11:26:12 -040051 registerDisplay(displayId, std::move(selectorPtr));
Dominik Laskowski756b7892021-08-04 12:53:59 -070052
53 ON_CALL(*this, postMessage).WillByDefault([](sp<MessageHandler>&& handler) {
54 // Execute task to prevent broken promise exception on destruction.
55 handler->handleMessage(Message());
56 });
Dominik Laskowski9c93d602021-10-07 19:38:26 -070057 }
Ana Krulecafb45842019-02-13 13:33:03 -080058
Dominik Laskowskif11728a2022-07-28 13:07:42 -070059 MOCK_METHOD(void, scheduleConfigure, (), (override));
Dominik Laskowski46f3e3b2021-08-10 11:44:24 -070060 MOCK_METHOD(void, scheduleFrame, (), (override));
Dominik Laskowski756b7892021-08-04 12:53:59 -070061 MOCK_METHOD(void, postMessage, (sp<MessageHandler>&&), (override));
62
Dominik Laskowski98041832019-08-01 18:35:59 -070063 // Used to inject mock event thread.
64 ConnectionHandle createConnection(std::unique_ptr<EventThread> eventThread) {
Steven Thomas2bbaabe2019-08-28 16:08:35 -070065 return Scheduler::createConnection(std::move(eventThread));
Ana Krulecafb45842019-02-13 13:33:03 -080066 }
67
68 /* ------------------------------------------------------------------------
69 * Read-write access to private data to set up preconditions and assert
70 * post-conditions.
71 */
72 auto& mutablePrimaryHWVsyncEnabled() { return mPrimaryHWVsyncEnabled; }
Ana Krulecafb45842019-02-13 13:33:03 -080073 auto& mutableHWVsyncAvailable() { return mHWVsyncAvailable; }
Lais Andrade3a6e47d2020-04-02 11:20:16 +010074
Dominik Laskowski596a2562022-10-28 11:26:12 -040075 auto refreshRateSelector() { return leaderSelectorPtr(); }
Dominik Laskowski983f2b52020-06-25 16:54:06 -070076
Dominik Laskowski596a2562022-10-28 11:26:12 -040077 const auto& refreshRateSelectors() const NO_THREAD_SAFETY_ANALYSIS {
78 return mRefreshRateSelectors;
79 }
80
81 bool hasRefreshRateSelectors() const { return !refreshRateSelectors().empty(); }
82
83 void registerDisplay(PhysicalDisplayId displayId, RefreshRateSelectorPtr selectorPtr) {
Dominik Laskowski59db9562022-10-27 16:18:53 -040084 ftl::FakeGuard guard(kMainThreadContext);
Dominik Laskowski596a2562022-10-28 11:26:12 -040085 Scheduler::registerDisplay(displayId, std::move(selectorPtr));
86 }
87
88 void unregisterDisplay(PhysicalDisplayId displayId) {
89 ftl::FakeGuard guard(kMainThreadContext);
90 Scheduler::unregisterDisplay(displayId);
91 }
92
Dominik Laskowskic132a152022-11-30 15:44:52 -050093 std::optional<PhysicalDisplayId> leaderDisplayId() const NO_THREAD_SAFETY_ANALYSIS {
94 return mLeaderDisplayId;
95 }
96
Dominik Laskowski596a2562022-10-28 11:26:12 -040097 void setLeaderDisplay(PhysicalDisplayId displayId) {
98 ftl::FakeGuard guard(kMainThreadContext);
99 Scheduler::setLeaderDisplay(displayId);
Dominik Laskowski59db9562022-10-27 16:18:53 -0400100 }
101
Dominik Laskowski1c99a002023-01-20 17:10:36 -0500102 auto& mutableVsyncModulator() { return *mVsyncModulator; }
Dominik Laskowskib5a094b2022-10-27 12:00:12 -0400103 auto& mutableLayerHistory() { return mLayerHistory; }
ramindani69b58e82022-09-26 16:48:36 -0700104
Nathaniel Nifong1303d912021-10-06 09:41:24 -0400105 size_t layerHistorySize() NO_THREAD_SAFETY_ANALYSIS {
106 return mLayerHistory.mActiveLayerInfos.size() + mLayerHistory.mInactiveLayerInfos.size();
107 }
Dominik Laskowski983f2b52020-06-25 16:54:06 -0700108
Nathaniel Nifong1303d912021-10-06 09:41:24 -0400109 size_t getNumActiveLayers() NO_THREAD_SAFETY_ANALYSIS {
110 return mLayerHistory.mActiveLayerInfos.size();
111 }
112
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100113 void replaceTouchTimer(int64_t millis) {
114 if (mTouchTimer) {
115 mTouchTimer.reset();
116 }
117 mTouchTimer.emplace(
Ady Abrahamdb3dfee2020-11-17 17:07:12 -0800118 "Testable Touch timer", std::chrono::milliseconds(millis),
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100119 [this] { touchTimerCallback(TimerState::Reset); },
120 [this] { touchTimerCallback(TimerState::Expired); });
121 mTouchTimer->start();
122 }
123
124 bool isTouchActive() {
Dominik Laskowski068173d2021-08-11 17:22:59 -0700125 std::lock_guard<std::mutex> lock(mPolicyLock);
126 return mPolicy.touch == Scheduler::TouchState::Active;
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100127 }
128
ramindani69b58e82022-09-26 16:48:36 -0700129 void setTouchStateAndIdleTimerPolicy(GlobalSignals globalSignals) {
130 std::lock_guard<std::mutex> lock(mPolicyLock);
131 mPolicy.touch = globalSignals.touch ? TouchState::Active : TouchState::Inactive;
132 mPolicy.idleTimer = globalSignals.idle ? TimerState::Expired : TimerState::Reset;
133 }
134
Dominik Laskowskid82e0f02022-10-26 15:23:04 -0400135 void setContentRequirements(std::vector<RefreshRateSelector::LayerRequirement> layers) {
ramindani69b58e82022-09-26 16:48:36 -0700136 std::lock_guard<std::mutex> lock(mPolicyLock);
137 mPolicy.contentRequirements = std::move(layers);
138 }
139
Dominik Laskowski530d6bd2022-10-10 16:55:54 -0400140 using Scheduler::DisplayModeChoice;
141 using Scheduler::DisplayModeChoiceMap;
142
Dominik Laskowski596a2562022-10-28 11:26:12 -0400143 DisplayModeChoiceMap chooseDisplayModes() NO_THREAD_SAFETY_ANALYSIS {
Dominik Laskowski530d6bd2022-10-10 16:55:54 -0400144 return Scheduler::chooseDisplayModes();
ramindani69b58e82022-09-26 16:48:36 -0700145 }
146
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100147 void dispatchCachedReportedMode() {
Dominik Laskowski068173d2021-08-11 17:22:59 -0700148 std::lock_guard<std::mutex> lock(mPolicyLock);
Dominik Laskowski596a2562022-10-28 11:26:12 -0400149 Scheduler::dispatchCachedReportedMode();
Ana Krulec6ddd2612020-09-24 13:06:33 -0700150 }
151
Dominik Laskowski068173d2021-08-11 17:22:59 -0700152 void clearCachedReportedMode() {
153 std::lock_guard<std::mutex> lock(mPolicyLock);
154 mPolicy.cachedModeChangedParams.reset();
Ana Krulec6ddd2612020-09-24 13:06:33 -0700155 }
156
Ady Abrahamace3d052022-11-17 16:25:05 -0800157 void onNonPrimaryDisplayModeChanged(ConnectionHandle handle, const FrameRateMode& mode) {
Dominik Laskowski596a2562022-10-28 11:26:12 -0400158 Scheduler::onNonPrimaryDisplayModeChanged(handle, mode);
Ana Krulec6ddd2612020-09-24 13:06:33 -0700159 }
160
Dominik Laskowski756b7892021-08-04 12:53:59 -0700161private:
162 // ICompositor overrides:
Dominik Laskowskif11728a2022-07-28 13:07:42 -0700163 void configure() override {}
Dominik Laskowski08fbd852022-07-14 08:53:42 -0700164 bool commit(TimePoint, VsyncId, TimePoint) override { return false; }
165 void composite(TimePoint, VsyncId) override {}
Dominik Laskowski756b7892021-08-04 12:53:59 -0700166 void sample() override {}
Ana Krulecafb45842019-02-13 13:33:03 -0800167};
168
Dominik Laskowski068173d2021-08-11 17:22:59 -0700169} // namespace android::scheduler