blob: a1ae35c3128bb7dcebc02217d530d962de3d858c [file] [log] [blame]
Ana Krulec61f86db2018-11-19 14:16:35 +01001/*
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 Laskowskif7a09ed2019-10-07 13:54:18 -070019#include <android-base/thread_annotations.h>
20#include <utils/RefBase.h>
Ana Krulec61f86db2018-11-19 14:16:35 +010021#include <utils/Timers.h>
22
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070023#include <memory>
24#include <mutex>
25#include <utility>
26#include <vector>
Ana Krulec434c22d2018-11-28 13:48:36 +010027
Ady Abraham8a82ba62020-01-17 12:43:17 -080028#include "RefreshRateConfigs.h"
29
Ana Krulec61f86db2018-11-19 14:16:35 +010030namespace android {
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070031
32class Layer;
Dominik Laskowski49cea512019-11-12 14:13:23 -080033class TestableScheduler;
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070034
Ady Abraham09bd3922019-04-08 10:44:56 -070035namespace scheduler {
Ana Krulec61f86db2018-11-19 14:16:35 +010036
Ady Abrahame3ed2f92020-01-06 17:01:28 -080037class LayerHistoryTest;
Ady Abraham8a82ba62020-01-17 12:43:17 -080038class LayerHistoryTestV2;
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070039class LayerInfo;
Ady Abraham8a82ba62020-01-17 12:43:17 -080040class LayerInfoV2;
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070041
Ana Krulec61f86db2018-11-19 14:16:35 +010042class LayerHistory {
43public:
Ady Abraham8a82ba62020-01-17 12:43:17 -080044 using LayerVoteType = RefreshRateConfigs::LayerVoteType;
45
Ady Abrahame3ed2f92020-01-06 17:01:28 -080046 virtual ~LayerHistory() = default;
Ana Krulec61f86db2018-11-19 14:16:35 +010047
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070048 // Layers are unregistered when the weak reference expires.
Ady Abraham8a82ba62020-01-17 12:43:17 -080049 virtual void registerLayer(Layer*, float lowRefreshRate, float highRefreshRate,
50 LayerVoteType type) = 0;
51
52 // Sets the display size. Client is responsible for synchronization.
53 virtual void setDisplayArea(uint32_t displayArea) = 0;
Ady Abraham09bd3922019-04-08 10:44:56 -070054
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070055 // Marks the layer as active, and records the given state to its history.
Ady Abrahame3ed2f92020-01-06 17:01:28 -080056 virtual void record(Layer*, nsecs_t presentTime, nsecs_t now) = 0;
Ady Abrahama315ce72019-04-24 14:35:20 -070057
Ady Abraham8a82ba62020-01-17 12:43:17 -080058 using Summary = std::vector<RefreshRateConfigs::LayerRequirement>;
Ady Abraham09bd3922019-04-08 10:44:56 -070059
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070060 // Rebuilds sets of active/inactive layers, and accumulates stats for active layers.
Ady Abrahame3ed2f92020-01-06 17:01:28 -080061 virtual Summary summarize(nsecs_t now) = 0;
Ady Abrahama9bf4ca2019-06-11 19:08:58 -070062
Ady Abrahame3ed2f92020-01-06 17:01:28 -080063 virtual void clear() = 0;
64};
65
66namespace impl {
67// Records per-layer history of scheduling-related information (primarily present time),
68// heuristically categorizes layers as active or inactive, and summarizes stats about
69// active layers (primarily maximum refresh rate). See go/content-fps-detection-in-scheduler.
70class LayerHistory : public android::scheduler::LayerHistory {
71public:
72 LayerHistory();
73 virtual ~LayerHistory();
74
75 // Layers are unregistered when the weak reference expires.
Ady Abraham8a82ba62020-01-17 12:43:17 -080076 void registerLayer(Layer*, float lowRefreshRate, float highRefreshRate,
77 LayerVoteType type) override;
78
79 void setDisplayArea(uint32_t /*displayArea*/) override {}
Ady Abrahame3ed2f92020-01-06 17:01:28 -080080
81 // Marks the layer as active, and records the given state to its history.
82 void record(Layer*, nsecs_t presentTime, nsecs_t now) override;
83
84 // Rebuilds sets of active/inactive layers, and accumulates stats for active layers.
85 android::scheduler::LayerHistory::Summary summarize(nsecs_t now) override;
86
87 void clear() override;
Ana Krulec61f86db2018-11-19 14:16:35 +010088
89private:
Ady Abrahame3ed2f92020-01-06 17:01:28 -080090 friend class android::scheduler::LayerHistoryTest;
Dominik Laskowski49cea512019-11-12 14:13:23 -080091 friend TestableScheduler;
Ady Abraham09bd3922019-04-08 10:44:56 -070092
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070093 using LayerPair = std::pair<wp<Layer>, std::unique_ptr<LayerInfo>>;
94 using LayerInfos = std::vector<LayerPair>;
Ady Abraham09bd3922019-04-08 10:44:56 -070095
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -070096 struct ActiveLayers {
97 LayerInfos& infos;
Ady Abrahamdec1a412020-01-24 10:23:50 -080098 const size_t index;
Ady Abraham09bd3922019-04-08 10:44:56 -070099
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700100 auto begin() { return infos.begin(); }
Ady Abrahamdec1a412020-01-24 10:23:50 -0800101 auto end() { return begin() + static_cast<long>(index); }
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700102 };
103
104 ActiveLayers activeLayers() REQUIRES(mLock) { return {mLayerInfos, mActiveLayersEnd}; }
105
106 // Iterates over layers in a single pass, swapping pairs such that active layers precede
107 // inactive layers, and inactive layers precede expired layers. Removes expired layers by
108 // truncating after inactive layers.
109 void partitionLayers(nsecs_t now) REQUIRES(mLock);
110
111 mutable std::mutex mLock;
112
113 // Partitioned such that active layers precede inactive layers. For fast lookup, the few active
114 // layers are at the front, and weak pointers are stored in contiguous memory to hit the cache.
115 LayerInfos mLayerInfos GUARDED_BY(mLock);
Ady Abrahamdec1a412020-01-24 10:23:50 -0800116 size_t mActiveLayersEnd GUARDED_BY(mLock) = 0;
Ady Abraham8a82ba62020-01-17 12:43:17 -0800117
118 // Whether to emit systrace output and debug logs.
119 const bool mTraceEnabled;
120
121 // Whether to use priority sent from WindowManager to determine the relevancy of the layer.
122 const bool mUseFrameRatePriority;
123};
124
125class LayerHistoryV2 : public android::scheduler::LayerHistory {
126public:
127 LayerHistoryV2();
128 virtual ~LayerHistoryV2();
129
130 // Layers are unregistered when the weak reference expires.
131 void registerLayer(Layer*, float lowRefreshRate, float highRefreshRate,
132 LayerVoteType type) override;
133
134 // Sets the display size. Client is responsible for synchronization.
135 void setDisplayArea(uint32_t displayArea) override { mDisplayArea = displayArea; }
136
137 // Marks the layer as active, and records the given state to its history.
138 void record(Layer*, nsecs_t presentTime, nsecs_t now) override;
139
140 // Rebuilds sets of active/inactive layers, and accumulates stats for active layers.
141 android::scheduler::LayerHistory::Summary summarize(nsecs_t /*now*/) override;
142
143 void clear() override;
144
145private:
146 friend android::scheduler::LayerHistoryTestV2;
147 friend TestableScheduler;
148
149 using LayerPair = std::pair<wp<Layer>, std::unique_ptr<LayerInfoV2>>;
150 using LayerInfos = std::vector<LayerPair>;
151
152 struct ActiveLayers {
153 LayerInfos& infos;
154 const size_t index;
155
156 auto begin() { return infos.begin(); }
157 auto end() { return begin() + static_cast<long>(index); }
158 };
159
160 ActiveLayers activeLayers() REQUIRES(mLock) { return {mLayerInfos, mActiveLayersEnd}; }
161
162 // Iterates over layers in a single pass, swapping pairs such that active layers precede
163 // inactive layers, and inactive layers precede expired layers. Removes expired layers by
164 // truncating after inactive layers.
165 void partitionLayers(nsecs_t now) REQUIRES(mLock);
166
167 mutable std::mutex mLock;
168
169 // Partitioned such that active layers precede inactive layers. For fast lookup, the few active
170 // layers are at the front, and weak pointers are stored in contiguous memory to hit the cache.
171 LayerInfos mLayerInfos GUARDED_BY(mLock);
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700172 size_t mActiveLayersEnd GUARDED_BY(mLock) = 0;
173
Ady Abraham8a82ba62020-01-17 12:43:17 -0800174 uint32_t mDisplayArea = 0;
175
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700176 // Whether to emit systrace output and debug logs.
177 const bool mTraceEnabled;
Ana Krulecc84d09b2019-11-02 23:10:29 +0100178
179 // Whether to use priority sent from WindowManager to determine the relevancy of the layer.
180 const bool mUseFrameRatePriority;
Ana Krulec61f86db2018-11-19 14:16:35 +0100181};
182
Ady Abrahame3ed2f92020-01-06 17:01:28 -0800183} // namespace impl
Ady Abraham09bd3922019-04-08 10:44:56 -0700184} // namespace scheduler
Dominik Laskowskif7a09ed2019-10-07 13:54:18 -0700185} // namespace android