blob: 6d45b5d69bfc8701da5d6034e49744187c1caeb3 [file] [log] [blame]
Ana Krulec98b5b242018-08-10 15:03:23 -07001/*
2 * Copyright 2018 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 Laskowski98041832019-08-01 18:35:59 -070019#include <atomic>
Kevin DuBois413287f2019-02-25 08:46:47 -080020#include <functional>
Dominik Laskowski756b7892021-08-04 12:53:59 -070021#include <future>
Ana Krulec98b5b242018-08-10 15:03:23 -070022#include <memory>
Dominik Laskowski98041832019-08-01 18:35:59 -070023#include <mutex>
24#include <optional>
25#include <unordered_map>
Ana Krulec98b5b242018-08-10 15:03:23 -070026
Ady Abrahamdec1a412020-01-24 10:23:50 -080027// TODO(b/129481165): remove the #pragma below and fix conversion issues
28#pragma clang diagnostic push
29#pragma clang diagnostic ignored "-Wconversion"
Marin Shalamanovbed7fd32020-12-21 20:02:20 +010030#pragma clang diagnostic ignored "-Wextra"
Dominik Laskowskidcb38bb2019-01-25 02:35:50 -080031#include <ui/GraphicTypes.h>
Marin Shalamanovbed7fd32020-12-21 20:02:20 +010032#pragma clang diagnostic pop // ignored "-Wconversion -Wextra"
Ana Krulec98b5b242018-08-10 15:03:23 -070033
Ana Krulec98b5b242018-08-10 15:03:23 -070034#include "EventThread.h"
Ana Krulec3084c052018-11-21 20:27:17 +010035#include "LayerHistory.h"
Dominik Laskowski756b7892021-08-04 12:53:59 -070036#include "MessageQueue.h"
Ana Krulecf2c006d2019-06-21 15:37:07 -070037#include "OneShotTimer.h"
Ana Krulec8d3e4f32019-03-05 10:40:33 -080038#include "RefreshRateConfigs.h"
Ana Krulec434c22d2018-11-28 13:48:36 +010039#include "SchedulerUtils.h"
Ana Krulec98b5b242018-08-10 15:03:23 -070040
41namespace android {
42
Ady Abraham2139f732019-11-13 18:56:40 -080043using namespace std::chrono_literals;
Ady Abraham5def7332020-05-29 16:13:47 -070044using scheduler::LayerHistory;
Ady Abraham2139f732019-11-13 18:56:40 -080045
Dominik Laskowski98041832019-08-01 18:35:59 -070046class FenceTime;
Dominik Laskowski6505f792019-09-18 11:10:05 -070047class InjectVSyncSource;
Ady Abraham8735eac2020-08-12 16:35:04 -070048class PredictedVsyncTracer;
Ady Abraham5a858552020-03-31 17:54:56 -070049
50namespace scheduler {
Ady Abraham8cb21882020-08-26 18:22:05 -070051class VsyncController;
Ady Abraham5a858552020-03-31 17:54:56 -070052class VSyncDispatch;
53class VSyncTracker;
54} // namespace scheduler
Ana Krulece588e312018-09-18 12:32:24 -070055
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -070056namespace frametimeline {
57class TokenManager;
58} // namespace frametimeline
59
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070060struct ISchedulerCallback {
Dominik Laskowski8da6b0e2021-05-12 15:34:13 -070061 // Indicates frame activity, i.e. whether commit and/or composite is taking place.
62 enum class FrameHint { kNone, kActive };
63
Dominik Laskowskie0e0cde2021-07-30 10:42:05 -070064 virtual void scheduleComposite(FrameHint) = 0;
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070065 virtual void setVsyncEnabled(bool) = 0;
Ady Abraham3a77a7b2019-12-02 18:46:59 -080066 virtual void changeRefreshRate(const scheduler::RefreshRateConfigs::RefreshRate&,
67 scheduler::RefreshRateConfigEvent) = 0;
Ady Abrahama09852a2020-02-20 14:23:42 -080068 virtual void kernelTimerChanged(bool expired) = 0;
Ady Abraham62a0be22020-12-08 16:54:10 -080069 virtual void triggerOnFrameRateOverridesChanged() = 0;
Dominik Laskowski8b01cc02020-07-14 19:02:41 -070070
71protected:
72 ~ISchedulerCallback() = default;
Ady Abraham3a77a7b2019-12-02 18:46:59 -080073};
74
Dominik Laskowski756b7892021-08-04 12:53:59 -070075class Scheduler : impl::MessageQueue {
76 using Impl = impl::MessageQueue;
77
Ana Krulec98b5b242018-08-10 15:03:23 -070078public:
Ady Abraham2139f732019-11-13 18:56:40 -080079 using RefreshRate = scheduler::RefreshRateConfigs::RefreshRate;
Marin Shalamanova7fe3042021-01-29 21:02:08 +010080 using ModeEvent = scheduler::RefreshRateConfigEvent;
Dominik Laskowski98041832019-08-01 18:35:59 -070081
Dominik Laskowski9c93d602021-10-07 19:38:26 -070082 struct Options {
83 // Whether to use content detection at all.
Dominik Laskowski756b7892021-08-04 12:53:59 -070084 bool useContentDetection;
Dominik Laskowski9c93d602021-10-07 19:38:26 -070085 };
86
Dominik Laskowski756b7892021-08-04 12:53:59 -070087 Scheduler(ICompositor&, ISchedulerCallback&, Options);
Dominik Laskowski08d05c22020-07-22 00:05:08 -070088 ~Scheduler();
Ana Krulec98b5b242018-08-10 15:03:23 -070089
Dominik Laskowski9c93d602021-10-07 19:38:26 -070090 void createVsyncSchedule(bool supportKernelIdleTimer);
91 void startTimers();
Dominik Laskowski756b7892021-08-04 12:53:59 -070092 void run();
93
94 using Impl::initVsync;
95 using Impl::setInjector;
96
97 using Impl::getScheduledFrameTime;
98 using Impl::setDuration;
99
100 using Impl::scheduleCommit;
101 using Impl::scheduleComposite;
102
103 // Schedule an asynchronous or synchronous task on the main thread.
104 template <typename F, typename T = std::invoke_result_t<F>>
105 [[nodiscard]] std::future<T> schedule(F&& f) {
106 auto [task, future] = makeTask(std::move(f));
107 postMessage(std::move(task));
108 return std::move(future);
109 }
Dominik Laskowski9c93d602021-10-07 19:38:26 -0700110
Dominik Laskowski98041832019-08-01 18:35:59 -0700111 using ConnectionHandle = scheduler::ConnectionHandle;
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -0700112 ConnectionHandle createConnection(const char* connectionName, frametimeline::TokenManager*,
Ady Abraham9c53ee72020-07-22 21:16:18 -0700113 std::chrono::nanoseconds workDuration,
114 std::chrono::nanoseconds readyDuration,
Dominik Laskowski98041832019-08-01 18:35:59 -0700115 impl::EventThread::InterceptVSyncsCallback);
Ana Krulec98b5b242018-08-10 15:03:23 -0700116
Ady Abraham62f216c2020-10-13 19:07:23 -0700117 sp<IDisplayEventConnection> createDisplayEventConnection(
118 ConnectionHandle, ISurfaceComposer::EventRegistrationFlags eventRegistration = {});
Ana Krulece588e312018-09-18 12:32:24 -0700119
Dominik Laskowski98041832019-08-01 18:35:59 -0700120 sp<EventThreadConnection> getEventConnection(ConnectionHandle);
Kevin DuBois413287f2019-02-25 08:46:47 -0800121
Dominik Laskowski98041832019-08-01 18:35:59 -0700122 void onHotplugReceived(ConnectionHandle, PhysicalDisplayId, bool connected);
Ady Abraham690f4612021-07-01 23:24:03 -0700123 void onPrimaryDisplayModeChanged(ConnectionHandle, DisplayModePtr) EXCLUDES(mFeatureStateLock);
124 void onNonPrimaryDisplayModeChanged(ConnectionHandle, DisplayModePtr);
Dominik Laskowski98041832019-08-01 18:35:59 -0700125 void onScreenAcquired(ConnectionHandle);
126 void onScreenReleased(ConnectionHandle);
Ana Krulece588e312018-09-18 12:32:24 -0700127
Ady Abraham62a0be22020-12-08 16:54:10 -0800128 void onFrameRateOverridesChanged(ConnectionHandle, PhysicalDisplayId)
Ady Abraham3efa3942021-06-24 19:01:25 -0700129 EXCLUDES(mFrameRateOverridesLock) EXCLUDES(mConnectionsLock);
Ady Abraham62f216c2020-10-13 19:07:23 -0700130
Ady Abraham9c53ee72020-07-22 21:16:18 -0700131 // Modifies work duration in the event thread.
132 void setDuration(ConnectionHandle, std::chrono::nanoseconds workDuration,
133 std::chrono::nanoseconds readyDuration);
Ana Krulec98b5b242018-08-10 15:03:23 -0700134
Ady Abrahame90dd522020-12-29 12:08:45 -0800135 DisplayStatInfo getDisplayStatInfo(nsecs_t now);
Ana Krulece588e312018-09-18 12:32:24 -0700136
Dominik Laskowski6505f792019-09-18 11:10:05 -0700137 // Returns injector handle if injection has toggled, or an invalid handle otherwise.
138 ConnectionHandle enableVSyncInjection(bool enable);
Dominik Laskowski6505f792019-09-18 11:10:05 -0700139 // Returns false if injection is disabled.
Ady Abraham9c53ee72020-07-22 21:16:18 -0700140 bool injectVSync(nsecs_t when, nsecs_t expectedVSyncTime, nsecs_t deadlineTimestamp);
Ana Krulece588e312018-09-18 12:32:24 -0700141 void enableHardwareVsync();
142 void disableHardwareVsync(bool makeUnavailable);
Dominik Laskowski98041832019-08-01 18:35:59 -0700143
Alec Mourif8e689c2019-05-20 18:32:22 -0700144 // Resyncs the scheduler to hardware vsync.
145 // If makeAvailable is true, then hardware vsync will be turned on.
146 // Otherwise, if hardware vsync is not already enabled then this method will
147 // no-op.
148 // The period is the vsync period from the current display configuration.
Ana Krulecc2870422019-01-29 19:00:58 -0800149 void resyncToHardwareVsync(bool makeAvailable, nsecs_t period);
Ady Abraham3efa3942021-06-24 19:01:25 -0700150 void resync() EXCLUDES(mRefreshRateConfigsLock);
Dominik Laskowski98041832019-08-01 18:35:59 -0700151
Ady Abraham8cb21882020-08-26 18:22:05 -0700152 // Passes a vsync sample to VsyncController. periodFlushed will be true if
153 // VsyncController detected that the vsync period changed, and false otherwise.
Ady Abraham5dee2f12020-02-05 17:49:47 -0800154 void addResyncSample(nsecs_t timestamp, std::optional<nsecs_t> hwcVsyncPeriod,
155 bool* periodFlushed);
Dominik Laskowski98041832019-08-01 18:35:59 -0700156 void addPresentFence(const std::shared_ptr<FenceTime>&);
Ana Krulece588e312018-09-18 12:32:24 -0700157 void setIgnorePresentFences(bool ignore);
Ady Abraham8f1ee7f2019-04-05 10:32:50 -0700158
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700159 // Layers are registered on creation, and unregistered when the weak reference expires.
160 void registerLayer(Layer*);
Ady Abraham3efa3942021-06-24 19:01:25 -0700161 void recordLayerHistory(Layer*, nsecs_t presentTime, LayerHistory::LayerUpdateType updateType)
162 EXCLUDES(mRefreshRateConfigsLock);
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100163 void setModeChangePending(bool pending);
Ady Abrahambdda8f02021-04-01 16:06:11 -0700164 void deregisterLayer(Layer*);
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700165
Dominik Laskowski49cea512019-11-12 14:13:23 -0800166 // Detects content using layer history, and selects a matching refresh rate.
Ady Abraham3efa3942021-06-24 19:01:25 -0700167 void chooseRefreshRateForContent() EXCLUDES(mRefreshRateConfigsLock);
Ady Abraham97d04232019-03-05 19:48:12 -0800168
Ady Abraham8532d012019-05-08 14:50:56 -0700169 void resetIdleTimer();
170
Dominik Laskowski8da6b0e2021-05-12 15:34:13 -0700171 // Indicates that touch interaction is taking place.
172 void onTouchHint();
Ady Abraham8532d012019-05-08 14:50:56 -0700173
Ady Abraham6fe2c172019-07-12 12:37:57 -0700174 void setDisplayPowerState(bool normal);
175
Ady Abraham55fa7272020-09-30 19:19:27 -0700176 scheduler::VSyncDispatch& getVsyncDispatch() { return *mVsyncSchedule.dispatch; }
177
Ady Abraham0bb6a472020-10-12 10:22:13 -0700178 // Returns true if a given vsync timestamp is considered valid vsync
179 // for a given uid
Ady Abraham62a0be22020-12-08 16:54:10 -0800180 bool isVsyncValid(nsecs_t expectedVsyncTimestamp, uid_t uid) const
Ady Abraham3efa3942021-06-24 19:01:25 -0700181 EXCLUDES(mFrameRateOverridesLock);
Ady Abraham0bb6a472020-10-12 10:22:13 -0700182
Ady Abraham3645e642021-04-20 18:39:00 -0700183 std::chrono::steady_clock::time_point getPreviousVsyncFrom(nsecs_t expectedPresentTime) const;
184
Dominik Laskowski98041832019-08-01 18:35:59 -0700185 void dump(std::string&) const;
186 void dump(ConnectionHandle, std::string&) const;
Ady Abraham8cb21882020-08-26 18:22:05 -0700187 void dumpVsync(std::string&) const;
Ana Krulec0c8cd522018-08-31 12:27:28 -0700188
Ady Abraham2139f732019-11-13 18:56:40 -0800189 // Get the appropriate refresh for current conditions.
Ady Abraham690f4612021-07-01 23:24:03 -0700190 DisplayModePtr getPreferredDisplayMode();
Daniel Solomon0f0ddc12019-08-19 19:31:09 -0700191
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800192 // Notifies the scheduler about a refresh rate timeline change.
Peiyong Line9d809e2020-04-14 13:10:48 -0700193 void onNewVsyncPeriodChangeTimeline(const hal::VsyncPeriodChangeTimeline& timeline);
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800194
Dominik Laskowskie0e0cde2021-07-30 10:42:05 -0700195 // Notifies the scheduler post composition.
196 void onPostComposition(nsecs_t presentTime);
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800197
Ady Abraham8a82ba62020-01-17 12:43:17 -0800198 // Notifies the scheduler when the display size has changed. Called from SF's main thread
Ady Abraham7825c682021-05-17 15:12:14 -0700199 void onActiveDisplayAreaChanged(uint32_t displayArea);
Ady Abraham8a82ba62020-01-17 12:43:17 -0800200
Alec Mouri717bcb62020-02-10 17:07:19 -0800201 size_t getEventThreadConnectionCount(ConnectionHandle handle);
202
Ady Abraham9c53ee72020-07-22 21:16:18 -0700203 std::unique_ptr<VSyncSource> makePrimaryDispSyncSource(const char* name,
204 std::chrono::nanoseconds workDuration,
205 std::chrono::nanoseconds readyDuration,
206 bool traceVsync = true);
207
Ady Abraham62a0be22020-12-08 16:54:10 -0800208 // Stores the preferred refresh rate that an app should run at.
209 // FrameRateOverride.refreshRateHz == 0 means no preference.
Ady Abraham3efa3942021-06-24 19:01:25 -0700210 void setPreferredRefreshRateForUid(FrameRateOverride) EXCLUDES(mFrameRateOverridesLock);
Alec Mouri7d436ec2021-01-27 20:40:50 -0800211 // Retrieves the overridden refresh rate for a given uid.
Ady Abraham3efa3942021-06-24 19:01:25 -0700212 std::optional<Fps> getFrameRateOverride(uid_t uid) const
213 EXCLUDES(mRefreshRateConfigsLock, mFrameRateOverridesLock);
214
215 void setRefreshRateConfigs(std::shared_ptr<scheduler::RefreshRateConfigs> refreshRateConfigs)
216 EXCLUDES(mRefreshRateConfigsLock) {
217 std::scoped_lock lock(mRefreshRateConfigsLock);
218 mRefreshRateConfigs = std::move(refreshRateConfigs);
Ady Abraham9a2ea342021-09-03 17:32:34 -0700219 mRefreshRateConfigs->setIdleTimerCallbacks(
220 [this] { std::invoke(&Scheduler::idleTimerCallback, this, TimerState::Reset); },
221 [this] { std::invoke(&Scheduler::idleTimerCallback, this, TimerState::Expired); },
222 [this] {
223 std::invoke(&Scheduler::kernelIdleTimerCallback, this, TimerState::Reset);
224 },
225 [this] {
226 std::invoke(&Scheduler::kernelIdleTimerCallback, this, TimerState::Expired);
227 });
Ady Abraham3efa3942021-06-24 19:01:25 -0700228 }
229
230 nsecs_t getVsyncPeriodFromRefreshRateConfigs() const EXCLUDES(mRefreshRateConfigsLock) {
231 std::scoped_lock lock(mRefreshRateConfigsLock);
232 return mRefreshRateConfigs->getCurrentRefreshRate().getVsyncPeriod();
233 }
Ady Abraham62a0be22020-12-08 16:54:10 -0800234
Ana Krulec98b5b242018-08-10 15:03:23 -0700235private:
Ana Krulecafb45842019-02-13 13:33:03 -0800236 friend class TestableScheduler;
237
Dominik Laskowski8da6b0e2021-05-12 15:34:13 -0700238 using FrameHint = ISchedulerCallback::FrameHint;
239
Ana Krulecfefd6ae2019-02-13 17:53:08 -0800240 // In order to make sure that the features don't override themselves, we need a state machine
241 // to keep track which feature requested the config change.
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700242 enum class ContentDetectionState { Off, On };
243 enum class TimerState { Reset, Expired };
244 enum class TouchState { Inactive, Active };
Ana Krulecfefd6ae2019-02-13 17:53:08 -0800245
Dominik Laskowski8b01cc02020-07-14 19:02:41 -0700246 struct VsyncSchedule {
Ady Abraham8cb21882020-08-26 18:22:05 -0700247 std::unique_ptr<scheduler::VsyncController> controller;
Dominik Laskowski8b01cc02020-07-14 19:02:41 -0700248 std::unique_ptr<scheduler::VSyncTracker> tracker;
249 std::unique_ptr<scheduler::VSyncDispatch> dispatch;
250 };
251
Dominik Laskowski6505f792019-09-18 11:10:05 -0700252 // Create a connection on the given EventThread.
Steven Thomas2bbaabe2019-08-28 16:08:35 -0700253 ConnectionHandle createConnection(std::unique_ptr<EventThread>);
Ady Abraham62f216c2020-10-13 19:07:23 -0700254 sp<EventThreadConnection> createConnectionInternal(
255 EventThread*, ISurfaceComposer::EventRegistrationFlags eventRegistration = {});
Dominik Laskowskiccf37d72019-02-01 16:47:58 -0800256
Dominik Laskowski3a80a382019-07-25 11:16:07 -0700257 // Update feature state machine to given state when corresponding timer resets or expires.
Ady Abraham3efa3942021-06-24 19:01:25 -0700258 void kernelIdleTimerCallback(TimerState) EXCLUDES(mRefreshRateConfigsLock);
Dominik Laskowski3a80a382019-07-25 11:16:07 -0700259 void idleTimerCallback(TimerState);
260 void touchTimerCallback(TimerState);
261 void displayPowerTimerCallback(TimerState);
262
Ady Abraham6fe2c172019-07-12 12:37:57 -0700263 // handles various timer features to change the refresh rate.
264 template <class T>
Ady Abrahamdfd62162020-06-10 16:11:56 -0700265 bool handleTimerStateChanged(T* currentState, T newState);
Dominik Laskowski98041832019-08-01 18:35:59 -0700266
267 void setVsyncPeriod(nsecs_t period);
268
Ana Krulec3803b8d2020-02-03 16:35:46 -0800269 // This function checks whether individual features that are affecting the refresh rate
Marin Shalamanov23c44202020-12-22 19:09:20 +0100270 // selection were initialized, prioritizes them, and calculates the DisplayModeId
Ana Krulec3803b8d2020-02-03 16:35:46 -0800271 // for the suggested refresh rate.
Ady Abraham690f4612021-07-01 23:24:03 -0700272 DisplayModePtr calculateRefreshRateModeId(
Ady Abrahamdfd62162020-06-10 16:11:56 -0700273 scheduler::RefreshRateConfigs::GlobalSignals* consideredSignals = nullptr)
Ady Abraham1adbb722020-05-15 11:51:48 -0700274 REQUIRES(mFeatureStateLock);
Ana Krulec7ab56032018-11-02 20:51:06 +0100275
Ady Abraham3efa3942021-06-24 19:01:25 -0700276 void dispatchCachedReportedMode() REQUIRES(mFeatureStateLock) EXCLUDES(mRefreshRateConfigsLock);
Ady Abraham62a0be22020-12-08 16:54:10 -0800277 bool updateFrameRateOverrides(scheduler::RefreshRateConfigs::GlobalSignals consideredSignals,
278 Fps displayRefreshRate) REQUIRES(mFeatureStateLock)
Ady Abraham3efa3942021-06-24 19:01:25 -0700279 EXCLUDES(mFrameRateOverridesLock);
Ady Abraham62a0be22020-12-08 16:54:10 -0800280
Ady Abraham3efa3942021-06-24 19:01:25 -0700281 impl::EventThread::ThrottleVsyncCallback makeThrottleVsyncCallback() const
282 EXCLUDES(mRefreshRateConfigsLock);
Jorim Jaggic0086af2021-02-12 18:18:11 +0100283 impl::EventThread::GetVsyncPeriodFunction makeGetVsyncPeriodFunction() const;
Ady Abrahamdfd62162020-06-10 16:11:56 -0700284
Ady Abraham3efa3942021-06-24 19:01:25 -0700285 std::shared_ptr<scheduler::RefreshRateConfigs> holdRefreshRateConfigs() const
286 EXCLUDES(mRefreshRateConfigsLock) {
287 std::scoped_lock lock(mRefreshRateConfigsLock);
288 return mRefreshRateConfigs;
289 }
290
Dominik Laskowski98041832019-08-01 18:35:59 -0700291 // Stores EventThread associated with a given VSyncSource, and an initial EventThreadConnection.
292 struct Connection {
293 sp<EventThreadConnection> connection;
294 std::unique_ptr<EventThread> thread;
295 };
Ady Abraham09bd3922019-04-08 10:44:56 -0700296
Dominik Laskowski98041832019-08-01 18:35:59 -0700297 ConnectionHandle::Id mNextConnectionHandleId = 0;
Ana Krulec6ddd2612020-09-24 13:06:33 -0700298 mutable std::mutex mConnectionsLock;
299 std::unordered_map<ConnectionHandle, Connection> mConnections GUARDED_BY(mConnectionsLock);
Ana Krulece588e312018-09-18 12:32:24 -0700300
Dominik Laskowski6505f792019-09-18 11:10:05 -0700301 bool mInjectVSyncs = false;
302 InjectVSyncSource* mVSyncInjector = nullptr;
303 ConnectionHandle mInjectorConnectionHandle;
304
Ady Abraham4f960d12021-10-13 16:59:49 -0700305 mutable std::mutex mHWVsyncLock;
Dominik Laskowski98041832019-08-01 18:35:59 -0700306 bool mPrimaryHWVsyncEnabled GUARDED_BY(mHWVsyncLock) = false;
307 bool mHWVsyncAvailable GUARDED_BY(mHWVsyncLock) = false;
308
Steven Thomas2bbaabe2019-08-28 16:08:35 -0700309 std::atomic<nsecs_t> mLastResyncTime = 0;
Ana Krulece588e312018-09-18 12:32:24 -0700310
Dominik Laskowski8b01cc02020-07-14 19:02:41 -0700311 const Options mOptions;
312 VsyncSchedule mVsyncSchedule;
Ana Krulec7ab56032018-11-02 20:51:06 +0100313
Dominik Laskowski49cea512019-11-12 14:13:23 -0800314 // Used to choose refresh rate if content detection is enabled.
Dominik Laskowski9c93d602021-10-07 19:38:26 -0700315 LayerHistory mLayerHistory;
Ana Krulecfb772822018-11-30 10:44:07 +0100316
Ady Abraham8532d012019-05-08 14:50:56 -0700317 // Timer used to monitor touch events.
Dominik Laskowski98041832019-08-01 18:35:59 -0700318 std::optional<scheduler::OneShotTimer> mTouchTimer;
Ady Abraham6fe2c172019-07-12 12:37:57 -0700319 // Timer used to monitor display power mode.
Dominik Laskowski98041832019-08-01 18:35:59 -0700320 std::optional<scheduler::OneShotTimer> mDisplayPowerTimer;
Ady Abraham6fe2c172019-07-12 12:37:57 -0700321
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800322 ISchedulerCallback& mSchedulerCallback;
Ana Krulecfefd6ae2019-02-13 17:53:08 -0800323
324 // In order to make sure that the features don't override themselves, we need a state machine
325 // to keep track which feature requested the config change.
Ady Abraham62a0be22020-12-08 16:54:10 -0800326 mutable std::mutex mFeatureStateLock;
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700327
328 struct {
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700329 TimerState idleTimer = TimerState::Reset;
330 TouchState touch = TouchState::Inactive;
331 TimerState displayPowerTimer = TimerState::Expired;
332
Ady Abraham690f4612021-07-01 23:24:03 -0700333 DisplayModePtr mode;
Ady Abraham5def7332020-05-29 16:13:47 -0700334 LayerHistory::Summary contentRequirements;
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700335
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700336 bool isDisplayPowerStateNormal = true;
Ady Abrahamdfd62162020-06-10 16:11:56 -0700337
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100338 // Used to cache the last parameters of onPrimaryDisplayModeChanged
339 struct ModeChangedParams {
Ady Abrahamdfd62162020-06-10 16:11:56 -0700340 ConnectionHandle handle;
Ady Abraham690f4612021-07-01 23:24:03 -0700341 DisplayModePtr mode;
Ady Abrahamdfd62162020-06-10 16:11:56 -0700342 };
343
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100344 std::optional<ModeChangedParams> cachedModeChangedParams;
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700345 } mFeatures GUARDED_BY(mFeatureStateLock);
Ady Abraham09bd3922019-04-08 10:44:56 -0700346
Ady Abraham3efa3942021-06-24 19:01:25 -0700347 mutable std::mutex mRefreshRateConfigsLock;
348 std::shared_ptr<scheduler::RefreshRateConfigs> mRefreshRateConfigs
349 GUARDED_BY(mRefreshRateConfigsLock);
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800350
351 std::mutex mVsyncTimelineLock;
Peiyong Line9d809e2020-04-14 13:10:48 -0700352 std::optional<hal::VsyncPeriodChangeTimeline> mLastVsyncPeriodChangeTimeline
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800353 GUARDED_BY(mVsyncTimelineLock);
354 static constexpr std::chrono::nanoseconds MAX_VSYNC_APPLIED_TIME = 200ms;
Ady Abraham8735eac2020-08-12 16:35:04 -0700355
Dominik Laskowski9c93d602021-10-07 19:38:26 -0700356 std::unique_ptr<PredictedVsyncTracer> mPredictedVsyncTracer;
Ady Abraham62a0be22020-12-08 16:54:10 -0800357
358 // The frame rate override lists need their own mutex as they are being read
359 // by SurfaceFlinger, Scheduler and EventThread (as a callback) to prevent deadlocks
Ady Abraham3efa3942021-06-24 19:01:25 -0700360 mutable std::mutex mFrameRateOverridesLock;
Ady Abraham62a0be22020-12-08 16:54:10 -0800361
362 // mappings between a UID and a preferred refresh rate that this app would
363 // run at.
364 scheduler::RefreshRateConfigs::UidToFrameRateOverride mFrameRateOverridesByContent
Ady Abraham3efa3942021-06-24 19:01:25 -0700365 GUARDED_BY(mFrameRateOverridesLock);
Ady Abraham62a0be22020-12-08 16:54:10 -0800366 scheduler::RefreshRateConfigs::UidToFrameRateOverride mFrameRateOverridesFromBackdoor
Ady Abraham3efa3942021-06-24 19:01:25 -0700367 GUARDED_BY(mFrameRateOverridesLock);
Ady Abraham4f960d12021-10-13 16:59:49 -0700368
369 // Keeps track of whether the screen is acquired for debug
370 std::atomic<bool> mScreenAcquired = false;
Ana Krulec98b5b242018-08-10 15:03:23 -0700371};
372
Ana Krulec7ab56032018-11-02 20:51:06 +0100373} // namespace android