blob: a87b7cb4a6d70d19729c44a98aa2517bb7ff08ce [file] [log] [blame]
Yiwei Zhang0102ad22018-05-02 17:37:17 -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
Peiyong Lin65248e02020-04-18 21:15:07 -070019// TODO(b/129481165): remove the #pragma below and fix conversion issues
Alec Mouri9a29e672020-09-14 12:39:14 -070020#include <cstdint>
Peiyong Lin65248e02020-04-18 21:15:07 -070021#pragma clang diagnostic push
22#pragma clang diagnostic ignored "-Wconversion"
Marin Shalamanovbed7fd32020-12-21 20:02:20 +010023#pragma clang diagnostic ignored "-Wextra"
Peiyong Lin65248e02020-04-18 21:15:07 -070024
25#include <android/hardware/graphics/composer/2.4/IComposerClient.h>
26
27// TODO(b/129481165): remove the #pragma below and fix conversion issues
Marin Shalamanovbed7fd32020-12-21 20:02:20 +010028#pragma clang diagnostic pop // ignored "-Wconversion -Wextra"
Peiyong Lin65248e02020-04-18 21:15:07 -070029
Alec Mouri7d436ec2021-01-27 20:40:50 -080030#include <../Fps.h>
31#include <gui/JankInfo.h>
Alec Mouri8e2f31b2020-01-16 22:04:35 +000032#include <stats_event.h>
33#include <stats_pull_atom_callback.h>
34#include <statslog.h>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070035#include <timestatsproto/TimeStatsHelper.h>
36#include <timestatsproto/TimeStatsProtoHeader.h>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070037#include <ui/FenceTime.h>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070038#include <utils/String16.h>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070039#include <utils/Vector.h>
40
Yiwei Zhangc5f2c452018-05-08 16:31:56 -070041#include <deque>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070042#include <mutex>
Yiwei Zhang8a4015c2018-05-08 16:03:47 -070043#include <optional>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070044#include <unordered_map>
Alec Mourie4034bb2019-11-19 12:45:54 -080045#include <variant>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070046
47using namespace android::surfaceflinger;
48
49namespace android {
Yiwei Zhang0102ad22018-05-02 17:37:17 -070050
51class TimeStats {
Alec Mourifb571ea2019-01-24 18:42:10 -080052public:
Ady Abraham8b9e6122021-01-26 19:11:45 -080053 using SetFrameRateVote = TimeStatsHelper::SetFrameRateVote;
54
Alec Mourifb571ea2019-01-24 18:42:10 -080055 virtual ~TimeStats() = default;
56
Alec Mouri8e2f31b2020-01-16 22:04:35 +000057 // Called once boot has been finished to perform additional capabilities,
58 // e.g. registration to statsd.
59 virtual void onBootFinished() = 0;
60
Alec Mourifb571ea2019-01-24 18:42:10 -080061 virtual void parseArgs(bool asProto, const Vector<String16>& args, std::string& result) = 0;
62 virtual bool isEnabled() = 0;
Oliver Nguyenf3b7c9c2019-05-07 13:28:07 -070063 virtual std::string miniDump() = 0;
Alec Mourifb571ea2019-01-24 18:42:10 -080064
65 virtual void incrementTotalFrames() = 0;
66 virtual void incrementMissedFrames() = 0;
67 virtual void incrementClientCompositionFrames() = 0;
Vishnu Nair9b079a22020-01-21 14:36:08 -080068 virtual void incrementClientCompositionReusedFrames() = 0;
Alec Mouri8de697e2020-03-19 10:52:01 -070069 // Increments the number of times the display refresh rate changed.
70 virtual void incrementRefreshRateSwitches() = 0;
Alec Mouri8f7a0102020-04-15 12:11:10 -070071 // Increments the number of changes in composition strategy
72 // The intention is to reflect the number of changes between hwc and gpu
73 // composition, where "gpu composition" may also include mixed composition.
74 virtual void incrementCompositionStrategyChanges() = 0;
Alec Mouri717bcb62020-02-10 17:07:19 -080075 // Records the most up-to-date count of display event connections.
76 // The stored count will be the maximum ever recoded.
77 virtual void recordDisplayEventConnectionCount(int32_t count) = 0;
Alec Mourifb571ea2019-01-24 18:42:10 -080078
Alec Mouri9519bf12019-11-15 16:54:44 -080079 // Records the start and end times for a frame.
80 // The start time is the same as the beginning of a SurfaceFlinger
81 // invalidate message.
82 // The end time corresponds to when SurfaceFlinger finishes submitting the
83 // request to HWC to present a frame.
84 virtual void recordFrameDuration(nsecs_t startTime, nsecs_t endTime) = 0;
Alec Mourie4034bb2019-11-19 12:45:54 -080085 // Records the start time and end times for when RenderEngine begins work.
86 // The start time corresponds to the beginning of RenderEngine::drawLayers.
87 // The end time corresponds to when RenderEngine finishes rendering.
88 virtual void recordRenderEngineDuration(nsecs_t startTime, nsecs_t endTime) = 0;
89 // Same as above, but passes in a fence representing the end time.
90 virtual void recordRenderEngineDuration(nsecs_t startTime,
91 const std::shared_ptr<FenceTime>& readyFence) = 0;
Alec Mouri9519bf12019-11-15 16:54:44 -080092
Yiwei Zhang1a88c402019-11-18 10:43:58 -080093 virtual void setPostTime(int32_t layerId, uint64_t frameNumber, const std::string& layerName,
Alec Mouri9a29e672020-09-14 12:39:14 -070094 uid_t uid, nsecs_t postTime) = 0;
Yiwei Zhang1a88c402019-11-18 10:43:58 -080095 virtual void setLatchTime(int32_t layerId, uint64_t frameNumber, nsecs_t latchTime) = 0;
Alec Mouri91f6df32020-01-30 08:48:58 -080096 // Reasons why latching a particular buffer may be skipped
97 enum class LatchSkipReason {
98 // If the acquire fence did not fire on some devices we skip latching
99 // the buffer until the fence fires.
100 LateAcquire,
101 };
102 // Increments the counter of skipped latch buffers.
103 virtual void incrementLatchSkipped(int32_t layerId, LatchSkipReason reason) = 0;
104 // Increments the counter of bad desired present times for this layer.
105 // Bad desired present times are "implausible" and cause SurfaceFlinger to
106 // latch a buffer immediately to avoid stalling.
107 virtual void incrementBadDesiredPresent(int32_t layerId) = 0;
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800108 virtual void setDesiredTime(int32_t layerId, uint64_t frameNumber, nsecs_t desiredTime) = 0;
109 virtual void setAcquireTime(int32_t layerId, uint64_t frameNumber, nsecs_t acquireTime) = 0;
110 virtual void setAcquireFence(int32_t layerId, uint64_t frameNumber,
Alec Mourifb571ea2019-01-24 18:42:10 -0800111 const std::shared_ptr<FenceTime>& acquireFence) = 0;
Alec Mourie4034bb2019-11-19 12:45:54 -0800112 // SetPresent{Time, Fence} are not expected to be called in the critical
113 // rendering path, as they flush prior fences if those fences have fired.
Alec Mouri7d436ec2021-01-27 20:40:50 -0800114 virtual void setPresentTime(int32_t layerId, uint64_t frameNumber, nsecs_t presentTime,
Ady Abraham8b9e6122021-01-26 19:11:45 -0800115 Fps displayRefreshRate, std::optional<Fps> renderRate,
116 SetFrameRateVote frameRateVote) = 0;
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800117 virtual void setPresentFence(int32_t layerId, uint64_t frameNumber,
Alec Mouri7d436ec2021-01-27 20:40:50 -0800118 const std::shared_ptr<FenceTime>& presentFence,
Ady Abraham8b9e6122021-01-26 19:11:45 -0800119 Fps displayRefreshRate, std::optional<Fps> renderRate,
120 SetFrameRateVote frameRateVote) = 0;
Alec Mouri9a29e672020-09-14 12:39:14 -0700121
Alec Mouri7d436ec2021-01-27 20:40:50 -0800122 // Increments janky frames, blamed to the provided {refreshRate, renderRate, uid, layerName}
123 // key, with JankMetadata as supplementary reasons for the jank. Because FrameTimeline is the
124 // infrastructure responsible for computing jank in the system, this is expected to be called
125 // from FrameTimeline, rather than directly from SurfaceFlinger or individual layers. If there
126 // are no jank reasons, then total frames are incremented but jank is not, for accurate
Alec Mouri9a29e672020-09-14 12:39:14 -0700127 // accounting of janky frames.
Alec Mouri363faf02021-01-29 16:34:55 -0800128 // displayDeadlineDelta, displayPresentJitter, and appDeadlineDelta are also provided in order
129 // to provide contextual information about a janky frame. These values may only be uploaded if
130 // there was an associated valid jank reason, and they must be positive. When these frame counts
131 // are incremented, these are also aggregated into a global reporting packet to help with data
132 // validation and assessing of overall device health.
133 struct JankyFramesInfo {
134 Fps refreshRate;
135 std::optional<Fps> renderRate;
136 uid_t uid = 0;
137 std::string layerName;
138 int32_t reasons = 0;
139 nsecs_t displayDeadlineDelta = 0;
140 nsecs_t displayPresentJitter = 0;
141 nsecs_t appDeadlineDelta = 0;
142
143 bool operator==(const JankyFramesInfo& o) const {
144 return Fps::EqualsInBuckets{}(refreshRate, o.refreshRate) &&
145 ((renderRate == std::nullopt && o.renderRate == std::nullopt) ||
146 (renderRate != std::nullopt && o.renderRate != std::nullopt &&
147 Fps::EqualsInBuckets{}(*renderRate, *o.renderRate))) &&
148 uid == o.uid && layerName == o.layerName && reasons == o.reasons &&
149 displayDeadlineDelta == o.displayDeadlineDelta &&
150 displayPresentJitter == o.displayPresentJitter &&
151 appDeadlineDelta == o.appDeadlineDelta;
152 }
153
154 friend std::ostream& operator<<(std::ostream& os, const JankyFramesInfo& info) {
155 os << "JankyFramesInfo {";
156 os << "\n .refreshRate = " << info.refreshRate;
157 os << "\n .renderRate = "
158 << (info.renderRate ? to_string(*info.renderRate) : "nullopt");
159 os << "\n .uid = " << info.uid;
160 os << "\n .layerName = " << info.layerName;
161 os << "\n .reasons = " << info.reasons;
162 os << "\n .displayDeadlineDelta = " << info.displayDeadlineDelta;
163 os << "\n .displayPresentJitter = " << info.displayPresentJitter;
164 os << "\n .appDeadlineDelta = " << info.appDeadlineDelta;
165 return os << "\n}";
166 }
167 };
168
169 virtual void incrementJankyFrames(const JankyFramesInfo& info) = 0;
Alec Mourifb571ea2019-01-24 18:42:10 -0800170 // Clean up the layer record
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800171 virtual void onDestroy(int32_t layerId) = 0;
Alec Mourifb571ea2019-01-24 18:42:10 -0800172 // If SF skips or rejects a buffer, remove the corresponding TimeRecord.
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800173 virtual void removeTimeRecord(int32_t layerId, uint64_t frameNumber) = 0;
Alec Mourifb571ea2019-01-24 18:42:10 -0800174
Peiyong Lin65248e02020-04-18 21:15:07 -0700175 virtual void setPowerMode(
176 hardware::graphics::composer::V2_4::IComposerClient::PowerMode powerMode) = 0;
Alec Mourifb571ea2019-01-24 18:42:10 -0800177 // Source of truth is RefrehRateStats.
178 virtual void recordRefreshRate(uint32_t fps, nsecs_t duration) = 0;
179 virtual void setPresentFenceGlobal(const std::shared_ptr<FenceTime>& presentFence) = 0;
180};
181
182namespace impl {
183
184class TimeStats : public android::TimeStats {
Peiyong Lin65248e02020-04-18 21:15:07 -0700185 using PowerMode = android::hardware::graphics::composer::V2_4::IComposerClient::PowerMode;
186
Yiwei Zhangcf50ab92018-06-14 10:50:12 -0700187 struct FrameTime {
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700188 uint64_t frameNumber = 0;
189 nsecs_t postTime = 0;
190 nsecs_t latchTime = 0;
191 nsecs_t acquireTime = 0;
192 nsecs_t desiredTime = 0;
193 nsecs_t presentTime = 0;
Yiwei Zhangcf50ab92018-06-14 10:50:12 -0700194 };
195
196 struct TimeRecord {
197 bool ready = false;
198 FrameTime frameTime;
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700199 std::shared_ptr<FenceTime> acquireFence;
200 std::shared_ptr<FenceTime> presentFence;
201 };
202
203 struct LayerRecord {
Alec Mouri9a29e672020-09-14 12:39:14 -0700204 uid_t uid;
Yiwei Zhang9689e2f2018-05-11 12:33:23 -0700205 std::string layerName;
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700206 // This is the index in timeRecords, at which the timestamps for that
207 // specific frame are still not fully received. This is not waiting for
208 // fences to signal, but rather waiting to receive those fences/timestamps.
209 int32_t waitData = -1;
Yiwei Zhangeaeea062018-06-28 14:46:51 -0700210 uint32_t droppedFrames = 0;
Alec Mouri91f6df32020-01-30 08:48:58 -0800211 uint32_t lateAcquireFrames = 0;
212 uint32_t badDesiredPresentFrames = 0;
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700213 TimeRecord prevTimeRecord;
Yiwei Zhangc5f2c452018-05-08 16:31:56 -0700214 std::deque<TimeRecord> timeRecords;
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700215 };
216
Yiwei Zhang3a226d22018-10-16 09:23:03 -0700217 struct PowerTime {
Peiyong Lin65248e02020-04-18 21:15:07 -0700218 PowerMode powerMode = PowerMode::OFF;
Yiwei Zhang3a226d22018-10-16 09:23:03 -0700219 nsecs_t prevTime = 0;
220 };
221
Alec Mourie4034bb2019-11-19 12:45:54 -0800222 struct RenderEngineDuration {
223 nsecs_t startTime;
224 std::variant<nsecs_t, std::shared_ptr<FenceTime>> endTime;
225 };
226
Yiwei Zhangce6ebc02018-10-20 12:42:38 -0700227 struct GlobalRecord {
228 nsecs_t prevPresentTime = 0;
229 std::deque<std::shared_ptr<FenceTime>> presentFences;
Alec Mourie4034bb2019-11-19 12:45:54 -0800230 std::deque<RenderEngineDuration> renderEngineDurations;
Yiwei Zhangce6ebc02018-10-20 12:42:38 -0700231 };
232
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700233public:
Alec Mourib3885ad2019-09-06 17:08:55 -0700234 TimeStats();
Yiwei Zhang7e666a52018-11-15 13:33:42 -0800235
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000236 // Delegate to the statsd service and associated APIs.
237 // Production code may use this class directly, whereas unit test may define
238 // a subclass for ease of testing.
239 class StatsEventDelegate {
240 public:
241 virtual ~StatsEventDelegate() = default;
Tej Singh2a457b62020-01-31 16:16:10 -0800242 virtual AStatsEvent* addStatsEventToPullData(AStatsEventList* data) {
243 return AStatsEventList_addStatsEvent(data);
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000244 }
Tej Singh38a4b212020-03-13 19:04:51 -0700245 virtual void setStatsPullAtomCallback(int32_t atom_tag,
246 AStatsManager_PullAtomMetadata* metadata,
247 AStatsManager_PullAtomCallback callback,
248 void* cookie) {
249 return AStatsManager_setPullAtomCallback(atom_tag, metadata, callback, cookie);
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000250 }
251
Tej Singh38a4b212020-03-13 19:04:51 -0700252 virtual void clearStatsPullAtomCallback(int32_t atom_tag) {
253 return AStatsManager_clearPullAtomCallback(atom_tag);
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000254 }
255
Tej Singh2a457b62020-01-31 16:16:10 -0800256 virtual void statsEventSetAtomId(AStatsEvent* event, uint32_t atom_id) {
257 return AStatsEvent_setAtomId(event, atom_id);
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000258 }
259
Alec Mouri717bcb62020-02-10 17:07:19 -0800260 virtual void statsEventWriteInt32(AStatsEvent* event, int32_t field) {
261 return AStatsEvent_writeInt32(event, field);
262 }
263
Tej Singh2a457b62020-01-31 16:16:10 -0800264 virtual void statsEventWriteInt64(AStatsEvent* event, int64_t field) {
265 return AStatsEvent_writeInt64(event, field);
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000266 }
267
Tej Singh2a457b62020-01-31 16:16:10 -0800268 virtual void statsEventWriteString8(AStatsEvent* event, const char* field) {
269 return AStatsEvent_writeString(event, field);
Alec Mouri37384342020-01-02 17:23:37 -0800270 }
271
Tej Singh2a457b62020-01-31 16:16:10 -0800272 virtual void statsEventWriteByteArray(AStatsEvent* event, const uint8_t* buf,
Alec Mouri37384342020-01-02 17:23:37 -0800273 size_t numBytes) {
Tej Singh2a457b62020-01-31 16:16:10 -0800274 return AStatsEvent_writeByteArray(event, buf, numBytes);
Alec Mouri37384342020-01-02 17:23:37 -0800275 }
276
Tej Singh2a457b62020-01-31 16:16:10 -0800277 virtual void statsEventBuild(AStatsEvent* event) { return AStatsEvent_build(event); }
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000278 };
279 // For testing only for injecting custom dependencies.
Alec Mouri37384342020-01-02 17:23:37 -0800280 TimeStats(std::unique_ptr<StatsEventDelegate> statsDelegate,
281 std::optional<size_t> maxPulledLayers,
282 std::optional<size_t> maxPulledHistogramBuckets);
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000283
Alec Mouri3ecd5cd2020-01-29 12:53:07 -0800284 ~TimeStats() override;
285
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000286 void onBootFinished() override;
Alec Mourifb571ea2019-01-24 18:42:10 -0800287 void parseArgs(bool asProto, const Vector<String16>& args, std::string& result) override;
288 bool isEnabled() override;
Yiwei Zhang7eb58b72019-04-22 19:00:02 -0700289 std::string miniDump() override;
Yiwei Zhang7e666a52018-11-15 13:33:42 -0800290
Alec Mourifb571ea2019-01-24 18:42:10 -0800291 void incrementTotalFrames() override;
292 void incrementMissedFrames() override;
293 void incrementClientCompositionFrames() override;
Vishnu Nair9b079a22020-01-21 14:36:08 -0800294 void incrementClientCompositionReusedFrames() override;
Alec Mouri8de697e2020-03-19 10:52:01 -0700295 void incrementRefreshRateSwitches() override;
Alec Mouri8f7a0102020-04-15 12:11:10 -0700296 void incrementCompositionStrategyChanges() override;
Alec Mouri717bcb62020-02-10 17:07:19 -0800297 void recordDisplayEventConnectionCount(int32_t count) override;
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700298
Alec Mouri9519bf12019-11-15 16:54:44 -0800299 void recordFrameDuration(nsecs_t startTime, nsecs_t endTime) override;
Alec Mourie4034bb2019-11-19 12:45:54 -0800300 void recordRenderEngineDuration(nsecs_t startTime, nsecs_t endTime) override;
301 void recordRenderEngineDuration(nsecs_t startTime,
302 const std::shared_ptr<FenceTime>& readyFence) override;
Alec Mouri9519bf12019-11-15 16:54:44 -0800303
Alec Mouri9a29e672020-09-14 12:39:14 -0700304 void setPostTime(int32_t layerId, uint64_t frameNumber, const std::string& layerName, uid_t uid,
Alec Mourifb571ea2019-01-24 18:42:10 -0800305 nsecs_t postTime) override;
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800306 void setLatchTime(int32_t layerId, uint64_t frameNumber, nsecs_t latchTime) override;
Alec Mouri91f6df32020-01-30 08:48:58 -0800307 void incrementLatchSkipped(int32_t layerId, LatchSkipReason reason) override;
308 void incrementBadDesiredPresent(int32_t layerId) override;
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800309 void setDesiredTime(int32_t layerId, uint64_t frameNumber, nsecs_t desiredTime) override;
310 void setAcquireTime(int32_t layerId, uint64_t frameNumber, nsecs_t acquireTime) override;
311 void setAcquireFence(int32_t layerId, uint64_t frameNumber,
Alec Mourifb571ea2019-01-24 18:42:10 -0800312 const std::shared_ptr<FenceTime>& acquireFence) override;
Alec Mouri7d436ec2021-01-27 20:40:50 -0800313 void setPresentTime(int32_t layerId, uint64_t frameNumber, nsecs_t presentTime,
Ady Abraham8b9e6122021-01-26 19:11:45 -0800314 Fps displayRefreshRate, std::optional<Fps> renderRate,
315 SetFrameRateVote frameRateVote) override;
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800316 void setPresentFence(int32_t layerId, uint64_t frameNumber,
Alec Mouri7d436ec2021-01-27 20:40:50 -0800317 const std::shared_ptr<FenceTime>& presentFence, Fps displayRefreshRate,
Ady Abraham8b9e6122021-01-26 19:11:45 -0800318 std::optional<Fps> renderRate, SetFrameRateVote frameRateVote) override;
Alec Mouri363faf02021-01-29 16:34:55 -0800319
320 void incrementJankyFrames(const JankyFramesInfo& info) override;
Yiwei Zhangaf8ee942018-11-22 00:15:23 -0800321 // Clean up the layer record
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800322 void onDestroy(int32_t layerId) override;
Yiwei Zhangeaeea062018-06-28 14:46:51 -0700323 // If SF skips or rejects a buffer, remove the corresponding TimeRecord.
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800324 void removeTimeRecord(int32_t layerId, uint64_t frameNumber) override;
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700325
Peiyong Lin65248e02020-04-18 21:15:07 -0700326 void setPowerMode(
327 hardware::graphics::composer::V2_4::IComposerClient::PowerMode powerMode) override;
Alec Mourifb571ea2019-01-24 18:42:10 -0800328 // Source of truth is RefrehRateStats.
329 void recordRefreshRate(uint32_t fps, nsecs_t duration) override;
330 void setPresentFenceGlobal(const std::shared_ptr<FenceTime>& presentFence) override;
Yiwei Zhang3a226d22018-10-16 09:23:03 -0700331
Yiwei Zhangaf8ee942018-11-22 00:15:23 -0800332 static const size_t MAX_NUM_TIME_RECORDS = 64;
333
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700334private:
Tej Singh2a457b62020-01-31 16:16:10 -0800335 static AStatsManager_PullAtomCallbackReturn pullAtomCallback(int32_t atom_tag,
336 AStatsEventList* data,
337 void* cookie);
338 AStatsManager_PullAtomCallbackReturn populateGlobalAtom(AStatsEventList* data);
339 AStatsManager_PullAtomCallbackReturn populateLayerAtom(AStatsEventList* data);
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800340 bool recordReadyLocked(int32_t layerId, TimeRecord* timeRecord);
Alec Mouri7d436ec2021-01-27 20:40:50 -0800341 void flushAvailableRecordsToStatsLocked(int32_t layerId, Fps displayRefreshRate,
Ady Abraham8b9e6122021-01-26 19:11:45 -0800342 std::optional<Fps> renderRate,
343 SetFrameRateVote frameRateVote);
Yiwei Zhang3a226d22018-10-16 09:23:03 -0700344 void flushPowerTimeLocked();
Yiwei Zhangce6ebc02018-10-20 12:42:38 -0700345 void flushAvailableGlobalRecordsToStatsLocked();
Alec Mouri9a29e672020-09-14 12:39:14 -0700346 bool canAddNewAggregatedStats(uid_t uid, const std::string& layerName);
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700347
348 void enable();
349 void disable();
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000350 void clearAll();
351 void clearGlobalLocked();
352 void clearLayersLocked();
Yiwei Zhang5434a782018-12-05 18:06:32 -0800353 void dump(bool asProto, std::optional<uint32_t> maxLayers, std::string& result);
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700354
355 std::atomic<bool> mEnabled = false;
356 std::mutex mMutex;
Yiwei Zhangdc224042018-10-18 15:34:00 -0700357 TimeStatsHelper::TimeStatsGlobal mTimeStats;
Yiwei Zhang1a88c402019-11-18 10:43:58 -0800358 // Hashmap for LayerRecord with layerId as the hash key
Yiwei Zhang9689e2f2018-05-11 12:33:23 -0700359 std::unordered_map<int32_t, LayerRecord> mTimeStatsTracker;
Yiwei Zhang3a226d22018-10-16 09:23:03 -0700360 PowerTime mPowerTime;
Yiwei Zhangce6ebc02018-10-20 12:42:38 -0700361 GlobalRecord mGlobalRecord;
Yiwei Zhang7eb58b72019-04-22 19:00:02 -0700362
363 static const size_t MAX_NUM_LAYER_RECORDS = 200;
Alec Mouri7d436ec2021-01-27 20:40:50 -0800364
365 static const size_t REFRESH_RATE_BUCKET_WIDTH = 30;
366 static const size_t RENDER_RATE_BUCKET_WIDTH = REFRESH_RATE_BUCKET_WIDTH;
Yiwei Zhange926ab52019-08-14 15:16:00 -0700367 static const size_t MAX_NUM_LAYER_STATS = 200;
Alec Mouri52bf7802021-01-20 08:20:50 -0800368 static const size_t MAX_NUM_PULLED_LAYERS = MAX_NUM_LAYER_STATS;
Alec Mouri8e2f31b2020-01-16 22:04:35 +0000369 std::unique_ptr<StatsEventDelegate> mStatsDelegate = std::make_unique<StatsEventDelegate>();
Alec Mouri52bf7802021-01-20 08:20:50 -0800370 size_t mMaxPulledLayers = MAX_NUM_PULLED_LAYERS;
Alec Mouri37384342020-01-02 17:23:37 -0800371 size_t mMaxPulledHistogramBuckets = 6;
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700372};
373
Alec Mourifb571ea2019-01-24 18:42:10 -0800374} // namespace impl
375
Yiwei Zhang0102ad22018-05-02 17:37:17 -0700376} // namespace android