blob: d267740d15c4498311ad73952f9ced648f429ebd [file] [log] [blame]
Andres Morales06f5bc72015-12-15 15:21:31 -08001/*
2 * Copyright (C) 2016 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 <utils/RefBase.h>
20
Siarhei Vishniakouaed22822025-02-18 11:35:58 -080021#include "FrameInfo.h"
22
Andres Morales06f5bc72015-12-15 15:21:31 -080023namespace android {
24namespace uirenderer {
25
Andres Morales910beb82016-02-02 16:19:40 -080026class FrameMetricsObserver : public VirtualLightRefBase {
Andres Morales06f5bc72015-12-15 15:21:31 -080027public:
Siarhei Vishniakouaed22822025-02-18 11:35:58 -080028 virtual void notify(const FrameInfoBuffer& buffer) = 0;
Siarhei Vishniakouf0cf18d2021-02-26 00:15:04 +000029 bool waitForPresentTime() const { return mWaitForPresentTime; };
30
Pablo Gamito35b80cd2021-08-24 11:03:51 +020031 void reportMetricsFrom(uint64_t frameNumber, int32_t surfaceControlId) {
Pablo Gamito88660d72021-08-09 14:37:56 +000032 mAttachedFrameNumber = frameNumber;
33 mSurfaceControlId = surfaceControlId;
34 };
Pablo Gamito35b80cd2021-08-24 11:03:51 +020035 uint64_t attachedFrameNumber() const { return mAttachedFrameNumber; };
Pablo Gamito88660d72021-08-09 14:37:56 +000036 int32_t attachedSurfaceControlId() const { return mSurfaceControlId; };
37
Siarhei Vishniakouf0cf18d2021-02-26 00:15:04 +000038 /**
39 * Create a new metrics observer. An observer that watches present time gets notified at a
40 * different time than the observer that doesn't.
41 *
42 * The observer that doesn't want present time is notified about metrics just after the frame
43 * is completed. This is the default behaviour that's used by public API's.
44 *
45 * An observer that watches present time is notified about metrics after the actual display
46 * present time is known.
47 * WARNING! This observer may not receive metrics for the last several frames that the app
48 * produces.
49 */
Greg Kaiser346312c2021-09-09 09:37:48 -070050 FrameMetricsObserver(bool waitForPresentTime)
51 : mWaitForPresentTime(waitForPresentTime)
52 , mSurfaceControlId(INT32_MAX)
53 , mAttachedFrameNumber(UINT64_MAX) {}
Siarhei Vishniakouf0cf18d2021-02-26 00:15:04 +000054
55private:
56 const bool mWaitForPresentTime;
Pablo Gamito88660d72021-08-09 14:37:56 +000057
58 // The id of the surface control (mSurfaceControlGenerationId in CanvasContext)
59 // for which the mAttachedFrameNumber applies to. We rely on this value being
60 // an increasing counter. We will report metrics:
61 // - for all frames if the frame comes from a surface with a surfaceControlId
62 // that is strictly greater than mSurfaceControlId.
63 // - for all frames with a frame number greater than or equal to mAttachedFrameNumber
64 // if the frame comes from a surface with a surfaceControlId that is equal to the
65 // mSurfaceControlId.
66 // We will never report metrics if the frame comes from a surface with a surfaceControlId
67 // that is strictly smaller than mSurfaceControlId.
68 int32_t mSurfaceControlId;
69
70 // The frame number the metrics observer was attached on. Metrics will be sent from this frame
71 // number (inclusive) onwards in the case that the surface id is equal to mSurfaceControlId.
Pablo Gamito35b80cd2021-08-24 11:03:51 +020072 uint64_t mAttachedFrameNumber;
Andres Morales06f5bc72015-12-15 15:21:31 -080073};
74
Chris Blume7b8a8082018-11-30 15:51:58 -080075} // namespace uirenderer
76} // namespace android