blob: 0b1f82eb44c0af89f91f7d0b412556fd2605eddd [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
19#include <timestatsproto/TimeStatsHelper.h>
20#include <timestatsproto/TimeStatsProtoHeader.h>
21
22#include <ui/FenceTime.h>
23
24#include <utils/String16.h>
25#include <utils/String8.h>
26#include <utils/Vector.h>
27
Yiwei Zhangc5f2c452018-05-08 16:31:56 -070028#include <deque>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070029#include <mutex>
Yiwei Zhang8a4015c2018-05-08 16:03:47 -070030#include <optional>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070031#include <unordered_map>
Yiwei Zhang0102ad22018-05-02 17:37:17 -070032
33using namespace android::surfaceflinger;
34
35namespace android {
36class String8;
37
38class TimeStats {
39 // TODO(zzyiwei): Bound the timeStatsTracker with weighted LRU
40 // static const size_t MAX_NUM_LAYER_RECORDS = 200;
41 static const size_t MAX_NUM_TIME_RECORDS = 64;
42
Yiwei Zhangcf50ab92018-06-14 10:50:12 -070043 struct FrameTime {
Yiwei Zhang0102ad22018-05-02 17:37:17 -070044 uint64_t frameNumber = 0;
45 nsecs_t postTime = 0;
46 nsecs_t latchTime = 0;
47 nsecs_t acquireTime = 0;
48 nsecs_t desiredTime = 0;
49 nsecs_t presentTime = 0;
Yiwei Zhangcf50ab92018-06-14 10:50:12 -070050 };
51
52 struct TimeRecord {
53 bool ready = false;
54 FrameTime frameTime;
Yiwei Zhang0102ad22018-05-02 17:37:17 -070055 std::shared_ptr<FenceTime> acquireFence;
56 std::shared_ptr<FenceTime> presentFence;
57 };
58
59 struct LayerRecord {
60 // This is the index in timeRecords, at which the timestamps for that
61 // specific frame are still not fully received. This is not waiting for
62 // fences to signal, but rather waiting to receive those fences/timestamps.
63 int32_t waitData = -1;
64 TimeRecord prevTimeRecord;
Yiwei Zhangc5f2c452018-05-08 16:31:56 -070065 std::deque<TimeRecord> timeRecords;
Yiwei Zhang0102ad22018-05-02 17:37:17 -070066 };
67
68public:
69 static TimeStats& getInstance();
70 void parseArgs(bool asProto, const Vector<String16>& args, size_t& index, String8& result);
71 void incrementTotalFrames();
Yiwei Zhang621f9d42018-05-07 10:40:55 -070072 void incrementMissedFrames();
Yiwei Zhang0102ad22018-05-02 17:37:17 -070073 void incrementClientCompositionFrames();
74
75 void setPostTime(const std::string& layerName, uint64_t frameNumber, nsecs_t postTime);
76 void setLatchTime(const std::string& layerName, uint64_t frameNumber, nsecs_t latchTime);
77 void setDesiredTime(const std::string& layerName, uint64_t frameNumber, nsecs_t desiredTime);
78 void setAcquireTime(const std::string& layerName, uint64_t frameNumber, nsecs_t acquireTime);
79 void setAcquireFence(const std::string& layerName, uint64_t frameNumber,
80 const std::shared_ptr<FenceTime>& acquireFence);
81 void setPresentTime(const std::string& layerName, uint64_t frameNumber, nsecs_t presentTime);
82 void setPresentFence(const std::string& layerName, uint64_t frameNumber,
83 const std::shared_ptr<FenceTime>& presentFence);
84 void onDisconnect(const std::string& layerName);
85 void clearLayerRecord(const std::string& layerName);
86 void removeTimeRecord(const std::string& layerName, uint64_t frameNumber);
87
88private:
89 TimeStats() = default;
90
91 bool recordReadyLocked(const std::string& layerName, TimeRecord* timeRecord);
92 void flushAvailableRecordsToStatsLocked(const std::string& layerName);
93
94 void enable();
95 void disable();
96 void clear();
97 bool isEnabled();
Yiwei Zhang8a4015c2018-05-08 16:03:47 -070098 void dump(bool asProto, std::optional<uint32_t> maxLayers, String8& result);
Yiwei Zhang0102ad22018-05-02 17:37:17 -070099
100 std::atomic<bool> mEnabled = false;
101 std::mutex mMutex;
102 TimeStatsHelper::TimeStatsGlobal timeStats;
103 std::unordered_map<std::string, LayerRecord> timeStatsTracker;
104};
105
106} // namespace android