blob: 0f53eb69f3ba2628f2d07d1fecde02551245a09c [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),
Ady Abraham3efa3942021-06-24 19:01:25 -070040 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 Laskowskid82e0f02022-10-26 15:23:04 -040044 ISchedulerCallback& callback)
Dominik Laskowski068173d2021-08-11 17:22:59 -070045 : Scheduler(*this, callback, Feature::kContentDetection) {
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 Laskowskib5a094b2022-10-27 12:00:12 -0400102 auto& mutableLayerHistory() { return mLayerHistory; }
ramindani69b58e82022-09-26 16:48:36 -0700103
Nathaniel Nifong1303d912021-10-06 09:41:24 -0400104 size_t layerHistorySize() NO_THREAD_SAFETY_ANALYSIS {
105 return mLayerHistory.mActiveLayerInfos.size() + mLayerHistory.mInactiveLayerInfos.size();
106 }
Dominik Laskowski983f2b52020-06-25 16:54:06 -0700107
Nathaniel Nifong1303d912021-10-06 09:41:24 -0400108 size_t getNumActiveLayers() NO_THREAD_SAFETY_ANALYSIS {
109 return mLayerHistory.mActiveLayerInfos.size();
110 }
111
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100112 void replaceTouchTimer(int64_t millis) {
113 if (mTouchTimer) {
114 mTouchTimer.reset();
115 }
116 mTouchTimer.emplace(
Ady Abrahamdb3dfee2020-11-17 17:07:12 -0800117 "Testable Touch timer", std::chrono::milliseconds(millis),
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100118 [this] { touchTimerCallback(TimerState::Reset); },
119 [this] { touchTimerCallback(TimerState::Expired); });
120 mTouchTimer->start();
121 }
122
123 bool isTouchActive() {
Dominik Laskowski068173d2021-08-11 17:22:59 -0700124 std::lock_guard<std::mutex> lock(mPolicyLock);
125 return mPolicy.touch == Scheduler::TouchState::Active;
Lais Andrade3a6e47d2020-04-02 11:20:16 +0100126 }
127
ramindani69b58e82022-09-26 16:48:36 -0700128 void setTouchStateAndIdleTimerPolicy(GlobalSignals globalSignals) {
129 std::lock_guard<std::mutex> lock(mPolicyLock);
130 mPolicy.touch = globalSignals.touch ? TouchState::Active : TouchState::Inactive;
131 mPolicy.idleTimer = globalSignals.idle ? TimerState::Expired : TimerState::Reset;
132 }
133
Dominik Laskowskid82e0f02022-10-26 15:23:04 -0400134 void setContentRequirements(std::vector<RefreshRateSelector::LayerRequirement> layers) {
ramindani69b58e82022-09-26 16:48:36 -0700135 std::lock_guard<std::mutex> lock(mPolicyLock);
136 mPolicy.contentRequirements = std::move(layers);
137 }
138
Dominik Laskowski530d6bd2022-10-10 16:55:54 -0400139 using Scheduler::DisplayModeChoice;
140 using Scheduler::DisplayModeChoiceMap;
141
Dominik Laskowski596a2562022-10-28 11:26:12 -0400142 DisplayModeChoiceMap chooseDisplayModes() NO_THREAD_SAFETY_ANALYSIS {
Dominik Laskowski530d6bd2022-10-10 16:55:54 -0400143 return Scheduler::chooseDisplayModes();
ramindani69b58e82022-09-26 16:48:36 -0700144 }
145
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100146 void dispatchCachedReportedMode() {
Dominik Laskowski068173d2021-08-11 17:22:59 -0700147 std::lock_guard<std::mutex> lock(mPolicyLock);
Dominik Laskowski596a2562022-10-28 11:26:12 -0400148 Scheduler::dispatchCachedReportedMode();
Ana Krulec6ddd2612020-09-24 13:06:33 -0700149 }
150
Dominik Laskowski068173d2021-08-11 17:22:59 -0700151 void clearCachedReportedMode() {
152 std::lock_guard<std::mutex> lock(mPolicyLock);
153 mPolicy.cachedModeChangedParams.reset();
Ana Krulec6ddd2612020-09-24 13:06:33 -0700154 }
155
Ady Abrahamace3d052022-11-17 16:25:05 -0800156 void onNonPrimaryDisplayModeChanged(ConnectionHandle handle, const FrameRateMode& mode) {
Dominik Laskowski596a2562022-10-28 11:26:12 -0400157 Scheduler::onNonPrimaryDisplayModeChanged(handle, mode);
Ana Krulec6ddd2612020-09-24 13:06:33 -0700158 }
159
Dominik Laskowski756b7892021-08-04 12:53:59 -0700160private:
161 // ICompositor overrides:
Dominik Laskowskif11728a2022-07-28 13:07:42 -0700162 void configure() override {}
Dominik Laskowski08fbd852022-07-14 08:53:42 -0700163 bool commit(TimePoint, VsyncId, TimePoint) override { return false; }
164 void composite(TimePoint, VsyncId) override {}
Dominik Laskowski756b7892021-08-04 12:53:59 -0700165 void sample() override {}
Ana Krulecafb45842019-02-13 13:33:03 -0800166};
167
Dominik Laskowski068173d2021-08-11 17:22:59 -0700168} // namespace android::scheduler