blob: 6ff5d890eaf736d74b991518886324c30b4fa05a [file] [log] [blame]
John Reckba6adf62015-02-19 14:36:50 -08001/*
2 * Copyright (C) 2015 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#ifndef JANKTRACKER_H_
17#define JANKTRACKER_H_
18
19#include "FrameInfo.h"
20#include "renderthread/TimeLord.h"
21#include "utils/RingBuffer.h"
22
John Reckedc524c2015-03-18 15:24:33 -070023#include <cutils/compiler.h>
John Reck2d5b8d72016-07-28 15:36:11 -070024#include <ui/DisplayInfo.h>
John Reckedc524c2015-03-18 15:24:33 -070025
John Reckb36016c2015-03-11 08:50:53 -070026#include <array>
John Reckba6adf62015-02-19 14:36:50 -080027#include <memory>
28
29namespace android {
30namespace uirenderer {
31
32enum JankType {
33 kMissedVsync = 0,
34 kHighInputLatency,
35 kSlowUI,
36 kSlowSync,
37 kSlowRT,
38
39 // must be last
40 NUM_BUCKETS,
41};
42
John Reckedc524c2015-03-18 15:24:33 -070043// Try to keep as small as possible, should match ASHMEM_SIZE in
44// GraphicsStatsService.java
45struct ProfileData {
46 std::array<uint32_t, NUM_BUCKETS> jankTypeCounts;
47 // See comments on kBucket* constants for what this holds
John Reck66010802016-03-30 14:19:44 -070048 std::array<uint32_t, 57> frameCounts;
49 // Holds a histogram of frame times in 50ms increments from 150ms to 5s
50 std::array<uint16_t, 97> slowFrameCounts;
John Reckedc524c2015-03-18 15:24:33 -070051
52 uint32_t totalFrameCount;
53 uint32_t jankFrameCount;
John Reck379f2642015-04-06 13:29:25 -070054 nsecs_t statStartTime;
John Reckba6adf62015-02-19 14:36:50 -080055};
56
John Reckdf1742e2017-01-19 15:56:21 -080057enum class JankTrackerType {
58 // The default, means there's no description set
59 Generic,
60 // The profile data represents a package
61 Package,
62 // The profile data is for a specific window
63 Window,
64};
65
66// Metadata about the ProfileData being collected
67struct ProfileDataDescription {
68 JankTrackerType type;
69 std::string name;
70};
71
John Reckba6adf62015-02-19 14:36:50 -080072// TODO: Replace DrawProfiler with this
73class JankTracker {
74public:
John Reckfb5c6752016-07-29 10:08:16 -070075 explicit JankTracker(const DisplayInfo& displayInfo);
John Reckedc524c2015-03-18 15:24:33 -070076 ~JankTracker();
John Reckba6adf62015-02-19 14:36:50 -080077
John Reckdf1742e2017-01-19 15:56:21 -080078 void setDescription(JankTrackerType type, const std::string&& name) {
79 mDescription.type = type;
80 mDescription.name = name;
81 }
82
John Reckba6adf62015-02-19 14:36:50 -080083 void addFrame(const FrameInfo& frame);
84
John Reckdf1742e2017-01-19 15:56:21 -080085 void dump(int fd) { dumpData(fd, &mDescription, mData); }
John Reckba6adf62015-02-19 14:36:50 -080086 void reset();
87
John Reckdf1742e2017-01-19 15:56:21 -080088 void rotateStorage();
John Reckedc524c2015-03-18 15:24:33 -070089 void switchStorageToAshmem(int ashmemfd);
90
91 uint32_t findPercentile(int p) { return findPercentile(mData, p); }
John Reckdf1742e2017-01-19 15:56:21 -080092 static int32_t frameTimeForFrameCountIndex(uint32_t index);
93 static int32_t frameTimeForSlowFrameCountIndex(uint32_t index);
John Reckedc524c2015-03-18 15:24:33 -070094
John Reckba6adf62015-02-19 14:36:50 -080095private:
John Reckedc524c2015-03-18 15:24:33 -070096 void freeData();
97 void setFrameInterval(nsecs_t frameIntervalNanos);
John Recke70c5752015-03-06 14:40:50 -080098
John Reckedc524c2015-03-18 15:24:33 -070099 static uint32_t findPercentile(const ProfileData* data, int p);
John Reckdf1742e2017-01-19 15:56:21 -0800100 static void dumpData(int fd, const ProfileDataDescription* description, const ProfileData* data);
John Reckedc524c2015-03-18 15:24:33 -0700101
John Reckb36016c2015-03-11 08:50:53 -0700102 std::array<int64_t, NUM_BUCKETS> mThresholds;
John Reckba6adf62015-02-19 14:36:50 -0800103 int64_t mFrameInterval;
John Reck2d5b8d72016-07-28 15:36:11 -0700104 // The amount of time we will erase from the total duration to account
105 // for SF vsync offsets with HWC2 blocking dequeueBuffers.
106 // (Vsync + mDequeueBlockTolerance) is the point at which we expect
107 // SF to have released the buffer normally, so we will forgive up to that
108 // point in time by comparing to (IssueDrawCommandsStart + DequeueDuration)
109 // This is only used if we are in pipelined mode and are using HWC2,
110 // otherwise it's 0.
111 nsecs_t mDequeueTimeForgiveness = 0;
John Reckedc524c2015-03-18 15:24:33 -0700112 ProfileData* mData;
113 bool mIsMapped = false;
John Reckdf1742e2017-01-19 15:56:21 -0800114 ProfileDataDescription mDescription;
John Reckba6adf62015-02-19 14:36:50 -0800115};
116
117} /* namespace uirenderer */
118} /* namespace android */
119
120#endif /* JANKTRACKER_H_ */