blob: f3c5b353e0a47163de9243af4e73c2e75ca7cd5a [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
Dominik Laskowski46f3e3b2021-08-10 11:44:24 -0700100 using Impl::scheduleFrame;
Dominik Laskowski756b7892021-08-04 12:53:59 -0700101
102 // Schedule an asynchronous or synchronous task on the main thread.
103 template <typename F, typename T = std::invoke_result_t<F>>
104 [[nodiscard]] std::future<T> schedule(F&& f) {
105 auto [task, future] = makeTask(std::move(f));
106 postMessage(std::move(task));
107 return std::move(future);
108 }
Dominik Laskowski9c93d602021-10-07 19:38:26 -0700109
Dominik Laskowski98041832019-08-01 18:35:59 -0700110 using ConnectionHandle = scheduler::ConnectionHandle;
Adithya Srinivasan5f683cf2020-09-15 14:21:04 -0700111 ConnectionHandle createConnection(const char* connectionName, frametimeline::TokenManager*,
Ady Abraham9c53ee72020-07-22 21:16:18 -0700112 std::chrono::nanoseconds workDuration,
113 std::chrono::nanoseconds readyDuration,
Dominik Laskowski98041832019-08-01 18:35:59 -0700114 impl::EventThread::InterceptVSyncsCallback);
Ana Krulec98b5b242018-08-10 15:03:23 -0700115
Ady Abraham62f216c2020-10-13 19:07:23 -0700116 sp<IDisplayEventConnection> createDisplayEventConnection(
117 ConnectionHandle, ISurfaceComposer::EventRegistrationFlags eventRegistration = {});
Ana Krulece588e312018-09-18 12:32:24 -0700118
Dominik Laskowski98041832019-08-01 18:35:59 -0700119 sp<EventThreadConnection> getEventConnection(ConnectionHandle);
Kevin DuBois413287f2019-02-25 08:46:47 -0800120
Dominik Laskowski98041832019-08-01 18:35:59 -0700121 void onHotplugReceived(ConnectionHandle, PhysicalDisplayId, bool connected);
Ady Abraham690f4612021-07-01 23:24:03 -0700122 void onPrimaryDisplayModeChanged(ConnectionHandle, DisplayModePtr) EXCLUDES(mFeatureStateLock);
123 void onNonPrimaryDisplayModeChanged(ConnectionHandle, DisplayModePtr);
Dominik Laskowski98041832019-08-01 18:35:59 -0700124 void onScreenAcquired(ConnectionHandle);
125 void onScreenReleased(ConnectionHandle);
Ana Krulece588e312018-09-18 12:32:24 -0700126
Ady Abraham62a0be22020-12-08 16:54:10 -0800127 void onFrameRateOverridesChanged(ConnectionHandle, PhysicalDisplayId)
Ady Abraham3efa3942021-06-24 19:01:25 -0700128 EXCLUDES(mFrameRateOverridesLock) EXCLUDES(mConnectionsLock);
Ady Abraham62f216c2020-10-13 19:07:23 -0700129
Ady Abraham9c53ee72020-07-22 21:16:18 -0700130 // Modifies work duration in the event thread.
131 void setDuration(ConnectionHandle, std::chrono::nanoseconds workDuration,
132 std::chrono::nanoseconds readyDuration);
Ana Krulec98b5b242018-08-10 15:03:23 -0700133
Ady Abrahame90dd522020-12-29 12:08:45 -0800134 DisplayStatInfo getDisplayStatInfo(nsecs_t now);
Ana Krulece588e312018-09-18 12:32:24 -0700135
Dominik Laskowski6505f792019-09-18 11:10:05 -0700136 // Returns injector handle if injection has toggled, or an invalid handle otherwise.
137 ConnectionHandle enableVSyncInjection(bool enable);
Dominik Laskowski6505f792019-09-18 11:10:05 -0700138 // Returns false if injection is disabled.
Ady Abraham9c53ee72020-07-22 21:16:18 -0700139 bool injectVSync(nsecs_t when, nsecs_t expectedVSyncTime, nsecs_t deadlineTimestamp);
Ana Krulece588e312018-09-18 12:32:24 -0700140 void enableHardwareVsync();
141 void disableHardwareVsync(bool makeUnavailable);
Dominik Laskowski98041832019-08-01 18:35:59 -0700142
Alec Mourif8e689c2019-05-20 18:32:22 -0700143 // Resyncs the scheduler to hardware vsync.
144 // If makeAvailable is true, then hardware vsync will be turned on.
145 // Otherwise, if hardware vsync is not already enabled then this method will
146 // no-op.
147 // The period is the vsync period from the current display configuration.
Ana Krulecc2870422019-01-29 19:00:58 -0800148 void resyncToHardwareVsync(bool makeAvailable, nsecs_t period);
Ady Abraham3efa3942021-06-24 19:01:25 -0700149 void resync() EXCLUDES(mRefreshRateConfigsLock);
Dominik Laskowski98041832019-08-01 18:35:59 -0700150
Ady Abraham8cb21882020-08-26 18:22:05 -0700151 // Passes a vsync sample to VsyncController. periodFlushed will be true if
152 // VsyncController detected that the vsync period changed, and false otherwise.
Ady Abraham5dee2f12020-02-05 17:49:47 -0800153 void addResyncSample(nsecs_t timestamp, std::optional<nsecs_t> hwcVsyncPeriod,
154 bool* periodFlushed);
Dominik Laskowski98041832019-08-01 18:35:59 -0700155 void addPresentFence(const std::shared_ptr<FenceTime>&);
Ana Krulece588e312018-09-18 12:32:24 -0700156 void setIgnorePresentFences(bool ignore);
Ady Abraham8f1ee7f2019-04-05 10:32:50 -0700157
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700158 // Layers are registered on creation, and unregistered when the weak reference expires.
159 void registerLayer(Layer*);
Ady Abraham3efa3942021-06-24 19:01:25 -0700160 void recordLayerHistory(Layer*, nsecs_t presentTime, LayerHistory::LayerUpdateType updateType)
161 EXCLUDES(mRefreshRateConfigsLock);
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100162 void setModeChangePending(bool pending);
Ady Abrahambdda8f02021-04-01 16:06:11 -0700163 void deregisterLayer(Layer*);
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700164
Dominik Laskowski49cea512019-11-12 14:13:23 -0800165 // Detects content using layer history, and selects a matching refresh rate.
Ady Abraham3efa3942021-06-24 19:01:25 -0700166 void chooseRefreshRateForContent() EXCLUDES(mRefreshRateConfigsLock);
Ady Abraham97d04232019-03-05 19:48:12 -0800167
Ady Abraham8532d012019-05-08 14:50:56 -0700168 void resetIdleTimer();
169
Dominik Laskowski8da6b0e2021-05-12 15:34:13 -0700170 // Indicates that touch interaction is taking place.
171 void onTouchHint();
Ady Abraham8532d012019-05-08 14:50:56 -0700172
Ady Abraham6fe2c172019-07-12 12:37:57 -0700173 void setDisplayPowerState(bool normal);
174
Ady Abraham55fa7272020-09-30 19:19:27 -0700175 scheduler::VSyncDispatch& getVsyncDispatch() { return *mVsyncSchedule.dispatch; }
176
Ady Abraham0bb6a472020-10-12 10:22:13 -0700177 // Returns true if a given vsync timestamp is considered valid vsync
178 // for a given uid
Ady Abraham62a0be22020-12-08 16:54:10 -0800179 bool isVsyncValid(nsecs_t expectedVsyncTimestamp, uid_t uid) const
Ady Abraham3efa3942021-06-24 19:01:25 -0700180 EXCLUDES(mFrameRateOverridesLock);
Ady Abraham0bb6a472020-10-12 10:22:13 -0700181
Ady Abraham3645e642021-04-20 18:39:00 -0700182 std::chrono::steady_clock::time_point getPreviousVsyncFrom(nsecs_t expectedPresentTime) const;
183
Dominik Laskowski98041832019-08-01 18:35:59 -0700184 void dump(std::string&) const;
185 void dump(ConnectionHandle, std::string&) const;
Ady Abraham8cb21882020-08-26 18:22:05 -0700186 void dumpVsync(std::string&) const;
Ana Krulec0c8cd522018-08-31 12:27:28 -0700187
Ady Abraham2139f732019-11-13 18:56:40 -0800188 // Get the appropriate refresh for current conditions.
Ady Abraham690f4612021-07-01 23:24:03 -0700189 DisplayModePtr getPreferredDisplayMode();
Daniel Solomon0f0ddc12019-08-19 19:31:09 -0700190
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800191 // Notifies the scheduler about a refresh rate timeline change.
Peiyong Line9d809e2020-04-14 13:10:48 -0700192 void onNewVsyncPeriodChangeTimeline(const hal::VsyncPeriodChangeTimeline& timeline);
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800193
Dominik Laskowskie0e0cde2021-07-30 10:42:05 -0700194 // Notifies the scheduler post composition.
195 void onPostComposition(nsecs_t presentTime);
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800196
Ady Abraham8a82ba62020-01-17 12:43:17 -0800197 // Notifies the scheduler when the display size has changed. Called from SF's main thread
Ady Abraham7825c682021-05-17 15:12:14 -0700198 void onActiveDisplayAreaChanged(uint32_t displayArea);
Ady Abraham8a82ba62020-01-17 12:43:17 -0800199
Alec Mouri717bcb62020-02-10 17:07:19 -0800200 size_t getEventThreadConnectionCount(ConnectionHandle handle);
201
Ady Abraham9c53ee72020-07-22 21:16:18 -0700202 std::unique_ptr<VSyncSource> makePrimaryDispSyncSource(const char* name,
203 std::chrono::nanoseconds workDuration,
204 std::chrono::nanoseconds readyDuration,
205 bool traceVsync = true);
206
Ady Abraham62a0be22020-12-08 16:54:10 -0800207 // Stores the preferred refresh rate that an app should run at.
208 // FrameRateOverride.refreshRateHz == 0 means no preference.
Ady Abraham3efa3942021-06-24 19:01:25 -0700209 void setPreferredRefreshRateForUid(FrameRateOverride) EXCLUDES(mFrameRateOverridesLock);
Alec Mouri7d436ec2021-01-27 20:40:50 -0800210 // Retrieves the overridden refresh rate for a given uid.
Ady Abraham3efa3942021-06-24 19:01:25 -0700211 std::optional<Fps> getFrameRateOverride(uid_t uid) const
212 EXCLUDES(mRefreshRateConfigsLock, mFrameRateOverridesLock);
213
214 void setRefreshRateConfigs(std::shared_ptr<scheduler::RefreshRateConfigs> refreshRateConfigs)
215 EXCLUDES(mRefreshRateConfigsLock) {
216 std::scoped_lock lock(mRefreshRateConfigsLock);
217 mRefreshRateConfigs = std::move(refreshRateConfigs);
Ady Abraham9a2ea342021-09-03 17:32:34 -0700218 mRefreshRateConfigs->setIdleTimerCallbacks(
219 [this] { std::invoke(&Scheduler::idleTimerCallback, this, TimerState::Reset); },
220 [this] { std::invoke(&Scheduler::idleTimerCallback, this, TimerState::Expired); },
221 [this] {
222 std::invoke(&Scheduler::kernelIdleTimerCallback, this, TimerState::Reset);
223 },
224 [this] {
225 std::invoke(&Scheduler::kernelIdleTimerCallback, this, TimerState::Expired);
226 });
Ady Abraham3efa3942021-06-24 19:01:25 -0700227 }
228
229 nsecs_t getVsyncPeriodFromRefreshRateConfigs() const EXCLUDES(mRefreshRateConfigsLock) {
230 std::scoped_lock lock(mRefreshRateConfigsLock);
231 return mRefreshRateConfigs->getCurrentRefreshRate().getVsyncPeriod();
232 }
Ady Abraham62a0be22020-12-08 16:54:10 -0800233
Ana Krulec98b5b242018-08-10 15:03:23 -0700234private:
Ana Krulecafb45842019-02-13 13:33:03 -0800235 friend class TestableScheduler;
236
Dominik Laskowski8da6b0e2021-05-12 15:34:13 -0700237 using FrameHint = ISchedulerCallback::FrameHint;
238
Ana Krulecfefd6ae2019-02-13 17:53:08 -0800239 // In order to make sure that the features don't override themselves, we need a state machine
240 // to keep track which feature requested the config change.
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700241 enum class ContentDetectionState { Off, On };
242 enum class TimerState { Reset, Expired };
243 enum class TouchState { Inactive, Active };
Ana Krulecfefd6ae2019-02-13 17:53:08 -0800244
Dominik Laskowski8b01cc02020-07-14 19:02:41 -0700245 struct VsyncSchedule {
Ady Abraham8cb21882020-08-26 18:22:05 -0700246 std::unique_ptr<scheduler::VsyncController> controller;
Dominik Laskowski8b01cc02020-07-14 19:02:41 -0700247 std::unique_ptr<scheduler::VSyncTracker> tracker;
248 std::unique_ptr<scheduler::VSyncDispatch> dispatch;
249 };
250
Dominik Laskowski6505f792019-09-18 11:10:05 -0700251 // Create a connection on the given EventThread.
Steven Thomas2bbaabe2019-08-28 16:08:35 -0700252 ConnectionHandle createConnection(std::unique_ptr<EventThread>);
Ady Abraham62f216c2020-10-13 19:07:23 -0700253 sp<EventThreadConnection> createConnectionInternal(
254 EventThread*, ISurfaceComposer::EventRegistrationFlags eventRegistration = {});
Dominik Laskowskiccf37d72019-02-01 16:47:58 -0800255
Dominik Laskowski3a80a382019-07-25 11:16:07 -0700256 // Update feature state machine to given state when corresponding timer resets or expires.
Ady Abraham3efa3942021-06-24 19:01:25 -0700257 void kernelIdleTimerCallback(TimerState) EXCLUDES(mRefreshRateConfigsLock);
Dominik Laskowski3a80a382019-07-25 11:16:07 -0700258 void idleTimerCallback(TimerState);
259 void touchTimerCallback(TimerState);
260 void displayPowerTimerCallback(TimerState);
261
Ady Abraham6fe2c172019-07-12 12:37:57 -0700262 // handles various timer features to change the refresh rate.
263 template <class T>
Ady Abrahamdfd62162020-06-10 16:11:56 -0700264 bool handleTimerStateChanged(T* currentState, T newState);
Dominik Laskowski98041832019-08-01 18:35:59 -0700265
266 void setVsyncPeriod(nsecs_t period);
267
Ana Krulec3803b8d2020-02-03 16:35:46 -0800268 // This function checks whether individual features that are affecting the refresh rate
Marin Shalamanov23c44202020-12-22 19:09:20 +0100269 // selection were initialized, prioritizes them, and calculates the DisplayModeId
Ana Krulec3803b8d2020-02-03 16:35:46 -0800270 // for the suggested refresh rate.
Ady Abraham690f4612021-07-01 23:24:03 -0700271 DisplayModePtr calculateRefreshRateModeId(
Ady Abrahamdfd62162020-06-10 16:11:56 -0700272 scheduler::RefreshRateConfigs::GlobalSignals* consideredSignals = nullptr)
Ady Abraham1adbb722020-05-15 11:51:48 -0700273 REQUIRES(mFeatureStateLock);
Ana Krulec7ab56032018-11-02 20:51:06 +0100274
Ady Abraham3efa3942021-06-24 19:01:25 -0700275 void dispatchCachedReportedMode() REQUIRES(mFeatureStateLock) EXCLUDES(mRefreshRateConfigsLock);
Ady Abraham62a0be22020-12-08 16:54:10 -0800276 bool updateFrameRateOverrides(scheduler::RefreshRateConfigs::GlobalSignals consideredSignals,
277 Fps displayRefreshRate) REQUIRES(mFeatureStateLock)
Ady Abraham3efa3942021-06-24 19:01:25 -0700278 EXCLUDES(mFrameRateOverridesLock);
Ady Abraham62a0be22020-12-08 16:54:10 -0800279
Ady Abraham3efa3942021-06-24 19:01:25 -0700280 impl::EventThread::ThrottleVsyncCallback makeThrottleVsyncCallback() const
281 EXCLUDES(mRefreshRateConfigsLock);
Jorim Jaggic0086af2021-02-12 18:18:11 +0100282 impl::EventThread::GetVsyncPeriodFunction makeGetVsyncPeriodFunction() const;
Ady Abrahamdfd62162020-06-10 16:11:56 -0700283
Ady Abraham3efa3942021-06-24 19:01:25 -0700284 std::shared_ptr<scheduler::RefreshRateConfigs> holdRefreshRateConfigs() const
285 EXCLUDES(mRefreshRateConfigsLock) {
286 std::scoped_lock lock(mRefreshRateConfigsLock);
287 return mRefreshRateConfigs;
288 }
289
Dominik Laskowski98041832019-08-01 18:35:59 -0700290 // Stores EventThread associated with a given VSyncSource, and an initial EventThreadConnection.
291 struct Connection {
292 sp<EventThreadConnection> connection;
293 std::unique_ptr<EventThread> thread;
294 };
Ady Abraham09bd3922019-04-08 10:44:56 -0700295
Dominik Laskowski98041832019-08-01 18:35:59 -0700296 ConnectionHandle::Id mNextConnectionHandleId = 0;
Ana Krulec6ddd2612020-09-24 13:06:33 -0700297 mutable std::mutex mConnectionsLock;
298 std::unordered_map<ConnectionHandle, Connection> mConnections GUARDED_BY(mConnectionsLock);
Ana Krulece588e312018-09-18 12:32:24 -0700299
Dominik Laskowski6505f792019-09-18 11:10:05 -0700300 bool mInjectVSyncs = false;
301 InjectVSyncSource* mVSyncInjector = nullptr;
302 ConnectionHandle mInjectorConnectionHandle;
303
Ady Abraham4f960d12021-10-13 16:59:49 -0700304 mutable std::mutex mHWVsyncLock;
Dominik Laskowski98041832019-08-01 18:35:59 -0700305 bool mPrimaryHWVsyncEnabled GUARDED_BY(mHWVsyncLock) = false;
306 bool mHWVsyncAvailable GUARDED_BY(mHWVsyncLock) = false;
307
Steven Thomas2bbaabe2019-08-28 16:08:35 -0700308 std::atomic<nsecs_t> mLastResyncTime = 0;
Ana Krulece588e312018-09-18 12:32:24 -0700309
Dominik Laskowski8b01cc02020-07-14 19:02:41 -0700310 const Options mOptions;
311 VsyncSchedule mVsyncSchedule;
Ana Krulec7ab56032018-11-02 20:51:06 +0100312
Dominik Laskowski49cea512019-11-12 14:13:23 -0800313 // Used to choose refresh rate if content detection is enabled.
Dominik Laskowski9c93d602021-10-07 19:38:26 -0700314 LayerHistory mLayerHistory;
Ana Krulecfb772822018-11-30 10:44:07 +0100315
Ady Abraham8532d012019-05-08 14:50:56 -0700316 // Timer used to monitor touch events.
Dominik Laskowski98041832019-08-01 18:35:59 -0700317 std::optional<scheduler::OneShotTimer> mTouchTimer;
Ady Abraham6fe2c172019-07-12 12:37:57 -0700318 // Timer used to monitor display power mode.
Dominik Laskowski98041832019-08-01 18:35:59 -0700319 std::optional<scheduler::OneShotTimer> mDisplayPowerTimer;
Ady Abraham6fe2c172019-07-12 12:37:57 -0700320
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800321 ISchedulerCallback& mSchedulerCallback;
Ana Krulecfefd6ae2019-02-13 17:53:08 -0800322
323 // In order to make sure that the features don't override themselves, we need a state machine
324 // to keep track which feature requested the config change.
Ady Abraham62a0be22020-12-08 16:54:10 -0800325 mutable std::mutex mFeatureStateLock;
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700326
327 struct {
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700328 TimerState idleTimer = TimerState::Reset;
329 TouchState touch = TouchState::Inactive;
330 TimerState displayPowerTimer = TimerState::Expired;
331
Ady Abraham690f4612021-07-01 23:24:03 -0700332 DisplayModePtr mode;
Ady Abraham5def7332020-05-29 16:13:47 -0700333 LayerHistory::Summary contentRequirements;
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700334
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700335 bool isDisplayPowerStateNormal = true;
Ady Abrahamdfd62162020-06-10 16:11:56 -0700336
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100337 // Used to cache the last parameters of onPrimaryDisplayModeChanged
338 struct ModeChangedParams {
Ady Abrahamdfd62162020-06-10 16:11:56 -0700339 ConnectionHandle handle;
Ady Abraham690f4612021-07-01 23:24:03 -0700340 DisplayModePtr mode;
Ady Abrahamdfd62162020-06-10 16:11:56 -0700341 };
342
Marin Shalamanova7fe3042021-01-29 21:02:08 +0100343 std::optional<ModeChangedParams> cachedModeChangedParams;
Dominik Laskowskidd252cd2019-07-26 09:10:16 -0700344 } mFeatures GUARDED_BY(mFeatureStateLock);
Ady Abraham09bd3922019-04-08 10:44:56 -0700345
Ady Abraham3efa3942021-06-24 19:01:25 -0700346 mutable std::mutex mRefreshRateConfigsLock;
347 std::shared_ptr<scheduler::RefreshRateConfigs> mRefreshRateConfigs
348 GUARDED_BY(mRefreshRateConfigsLock);
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800349
350 std::mutex mVsyncTimelineLock;
Peiyong Line9d809e2020-04-14 13:10:48 -0700351 std::optional<hal::VsyncPeriodChangeTimeline> mLastVsyncPeriodChangeTimeline
Ady Abraham3a77a7b2019-12-02 18:46:59 -0800352 GUARDED_BY(mVsyncTimelineLock);
353 static constexpr std::chrono::nanoseconds MAX_VSYNC_APPLIED_TIME = 200ms;
Ady Abraham8735eac2020-08-12 16:35:04 -0700354
Dominik Laskowski9c93d602021-10-07 19:38:26 -0700355 std::unique_ptr<PredictedVsyncTracer> mPredictedVsyncTracer;
Ady Abraham62a0be22020-12-08 16:54:10 -0800356
357 // The frame rate override lists need their own mutex as they are being read
358 // by SurfaceFlinger, Scheduler and EventThread (as a callback) to prevent deadlocks
Ady Abraham3efa3942021-06-24 19:01:25 -0700359 mutable std::mutex mFrameRateOverridesLock;
Ady Abraham62a0be22020-12-08 16:54:10 -0800360
361 // mappings between a UID and a preferred refresh rate that this app would
362 // run at.
363 scheduler::RefreshRateConfigs::UidToFrameRateOverride mFrameRateOverridesByContent
Ady Abraham3efa3942021-06-24 19:01:25 -0700364 GUARDED_BY(mFrameRateOverridesLock);
Ady Abraham62a0be22020-12-08 16:54:10 -0800365 scheduler::RefreshRateConfigs::UidToFrameRateOverride mFrameRateOverridesFromBackdoor
Ady Abraham3efa3942021-06-24 19:01:25 -0700366 GUARDED_BY(mFrameRateOverridesLock);
Ady Abraham4f960d12021-10-13 16:59:49 -0700367
368 // Keeps track of whether the screen is acquired for debug
369 std::atomic<bool> mScreenAcquired = false;
Ana Krulec98b5b242018-08-10 15:03:23 -0700370};
371
Ana Krulec7ab56032018-11-02 20:51:06 +0100372} // namespace android