xref: /aosp_15_r20/frameworks/base/libs/hwui/FrameMetricsReporter.h (revision d57664e9bc4670b3ecf6748a746a57c557b6bc9e)
1*d57664e9SAndroid Build Coastguard Worker /*
2*d57664e9SAndroid Build Coastguard Worker  * Copyright (C) 2016 The Android Open Source Project
3*d57664e9SAndroid Build Coastguard Worker  *
4*d57664e9SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*d57664e9SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*d57664e9SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*d57664e9SAndroid Build Coastguard Worker  *
8*d57664e9SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*d57664e9SAndroid Build Coastguard Worker  *
10*d57664e9SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*d57664e9SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*d57664e9SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*d57664e9SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*d57664e9SAndroid Build Coastguard Worker  * limitations under the License.
15*d57664e9SAndroid Build Coastguard Worker  */
16*d57664e9SAndroid Build Coastguard Worker 
17*d57664e9SAndroid Build Coastguard Worker #pragma once
18*d57664e9SAndroid Build Coastguard Worker 
19*d57664e9SAndroid Build Coastguard Worker #include <utils/Mutex.h>
20*d57664e9SAndroid Build Coastguard Worker #include <utils/Log.h>
21*d57664e9SAndroid Build Coastguard Worker #include <utils/RefBase.h>
22*d57664e9SAndroid Build Coastguard Worker 
23*d57664e9SAndroid Build Coastguard Worker #include <ui/FatVector.h>
24*d57664e9SAndroid Build Coastguard Worker 
25*d57664e9SAndroid Build Coastguard Worker #include "FrameInfo.h"
26*d57664e9SAndroid Build Coastguard Worker #include "FrameMetricsObserver.h"
27*d57664e9SAndroid Build Coastguard Worker 
28*d57664e9SAndroid Build Coastguard Worker #include <string.h>
29*d57664e9SAndroid Build Coastguard Worker #include <mutex>
30*d57664e9SAndroid Build Coastguard Worker 
31*d57664e9SAndroid Build Coastguard Worker namespace android {
32*d57664e9SAndroid Build Coastguard Worker namespace uirenderer {
33*d57664e9SAndroid Build Coastguard Worker 
34*d57664e9SAndroid Build Coastguard Worker class FrameMetricsReporter {
35*d57664e9SAndroid Build Coastguard Worker public:
FrameMetricsReporter()36*d57664e9SAndroid Build Coastguard Worker     FrameMetricsReporter() {}
37*d57664e9SAndroid Build Coastguard Worker 
addObserver(FrameMetricsObserver * observer)38*d57664e9SAndroid Build Coastguard Worker     void addObserver(FrameMetricsObserver* observer) {
39*d57664e9SAndroid Build Coastguard Worker         std::lock_guard lock(mObserversLock);
40*d57664e9SAndroid Build Coastguard Worker         mObservers.push_back(observer);
41*d57664e9SAndroid Build Coastguard Worker     }
42*d57664e9SAndroid Build Coastguard Worker 
removeObserver(FrameMetricsObserver * observer)43*d57664e9SAndroid Build Coastguard Worker     bool removeObserver(FrameMetricsObserver* observer) {
44*d57664e9SAndroid Build Coastguard Worker         std::lock_guard lock(mObserversLock);
45*d57664e9SAndroid Build Coastguard Worker         for (size_t i = 0; i < mObservers.size(); i++) {
46*d57664e9SAndroid Build Coastguard Worker             if (mObservers[i].get() == observer) {
47*d57664e9SAndroid Build Coastguard Worker                 mObservers.erase(mObservers.begin() + i);
48*d57664e9SAndroid Build Coastguard Worker                 return true;
49*d57664e9SAndroid Build Coastguard Worker             }
50*d57664e9SAndroid Build Coastguard Worker         }
51*d57664e9SAndroid Build Coastguard Worker         return false;
52*d57664e9SAndroid Build Coastguard Worker     }
53*d57664e9SAndroid Build Coastguard Worker 
hasObservers()54*d57664e9SAndroid Build Coastguard Worker     bool hasObservers() {
55*d57664e9SAndroid Build Coastguard Worker         std::lock_guard lock(mObserversLock);
56*d57664e9SAndroid Build Coastguard Worker         return mObservers.size() > 0;
57*d57664e9SAndroid Build Coastguard Worker     }
58*d57664e9SAndroid Build Coastguard Worker 
59*d57664e9SAndroid Build Coastguard Worker     /**
60*d57664e9SAndroid Build Coastguard Worker      * Notify observers about the metrics contained in 'stats'.
61*d57664e9SAndroid Build Coastguard Worker      * If an observer is waiting for present time, notify when 'stats' has present time.
62*d57664e9SAndroid Build Coastguard Worker      *
63*d57664e9SAndroid Build Coastguard Worker      * If an observer does not want present time, only notify when 'hasPresentTime' is false.
64*d57664e9SAndroid Build Coastguard Worker      * Never notify both types of observers from the same callback, because the callback with
65*d57664e9SAndroid Build Coastguard Worker      * 'hasPresentTime' is sent at a different time than the one without.
66*d57664e9SAndroid Build Coastguard Worker      *
67*d57664e9SAndroid Build Coastguard Worker      * The 'frameNumber' and 'surfaceControlId' associated to the frame whose's stats are being
68*d57664e9SAndroid Build Coastguard Worker      * reported are used to determine whether or not the stats should be reported. We won't report
69*d57664e9SAndroid Build Coastguard Worker      * stats of frames that are from "old" surfaces (i.e. with surfaceControlIds older than the one
70*d57664e9SAndroid Build Coastguard Worker      * the observer was attached on) nor those that are from "old" frame numbers.
71*d57664e9SAndroid Build Coastguard Worker      */
72*d57664e9SAndroid Build Coastguard Worker     void reportFrameMetrics(const int64_t* stats, bool hasPresentTime, uint64_t frameNumber,
73*d57664e9SAndroid Build Coastguard Worker                             int32_t surfaceControlId);
74*d57664e9SAndroid Build Coastguard Worker 
75*d57664e9SAndroid Build Coastguard Worker private:
76*d57664e9SAndroid Build Coastguard Worker     FatVector<sp<FrameMetricsObserver>, 10> mObservers GUARDED_BY(mObserversLock);
77*d57664e9SAndroid Build Coastguard Worker     std::mutex mObserversLock;
78*d57664e9SAndroid Build Coastguard Worker };
79*d57664e9SAndroid Build Coastguard Worker 
80*d57664e9SAndroid Build Coastguard Worker }  // namespace uirenderer
81*d57664e9SAndroid Build Coastguard Worker }  // namespace android
82