blob: 498ec5793caba6ef03cb7a6fc517ecf0cd6ef4f9 [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
Andres Morales06f5bc72015-12-15 15:21:31 -080021namespace android {
22namespace uirenderer {
23
Andres Morales910beb82016-02-02 16:19:40 -080024class FrameMetricsObserver : public VirtualLightRefBase {
Andres Morales06f5bc72015-12-15 15:21:31 -080025public:
Pirama Arumuga Nainar459afe92019-02-07 13:24:24 -080026 virtual void notify(const int64_t* buffer) = 0;
Siarhei Vishniakouf0cf18d2021-02-26 00:15:04 +000027 bool waitForPresentTime() const { return mWaitForPresentTime; };
28
Pablo Gamito35b80cd2021-08-24 11:03:51 +020029 void reportMetricsFrom(uint64_t frameNumber, int32_t surfaceControlId) {
Pablo Gamito88660d72021-08-09 14:37:56 +000030 mAttachedFrameNumber = frameNumber;
31 mSurfaceControlId = surfaceControlId;
32 };
Pablo Gamito35b80cd2021-08-24 11:03:51 +020033 uint64_t attachedFrameNumber() const { return mAttachedFrameNumber; };
Pablo Gamito88660d72021-08-09 14:37:56 +000034 int32_t attachedSurfaceControlId() const { return mSurfaceControlId; };
35
Siarhei Vishniakouf0cf18d2021-02-26 00:15:04 +000036 /**
37 * Create a new metrics observer. An observer that watches present time gets notified at a
38 * different time than the observer that doesn't.
39 *
40 * The observer that doesn't want present time is notified about metrics just after the frame
41 * is completed. This is the default behaviour that's used by public API's.
42 *
43 * An observer that watches present time is notified about metrics after the actual display
44 * present time is known.
45 * WARNING! This observer may not receive metrics for the last several frames that the app
46 * produces.
47 */
48 FrameMetricsObserver(bool waitForPresentTime) : mWaitForPresentTime(waitForPresentTime) {}
49
50private:
51 const bool mWaitForPresentTime;
Pablo Gamito88660d72021-08-09 14:37:56 +000052
53 // The id of the surface control (mSurfaceControlGenerationId in CanvasContext)
54 // for which the mAttachedFrameNumber applies to. We rely on this value being
55 // an increasing counter. We will report metrics:
56 // - for all frames if the frame comes from a surface with a surfaceControlId
57 // that is strictly greater than mSurfaceControlId.
58 // - for all frames with a frame number greater than or equal to mAttachedFrameNumber
59 // if the frame comes from a surface with a surfaceControlId that is equal to the
60 // mSurfaceControlId.
61 // We will never report metrics if the frame comes from a surface with a surfaceControlId
62 // that is strictly smaller than mSurfaceControlId.
63 int32_t mSurfaceControlId;
64
65 // The frame number the metrics observer was attached on. Metrics will be sent from this frame
66 // number (inclusive) onwards in the case that the surface id is equal to mSurfaceControlId.
Pablo Gamito35b80cd2021-08-24 11:03:51 +020067 uint64_t mAttachedFrameNumber;
Andres Morales06f5bc72015-12-15 15:21:31 -080068};
69
Chris Blume7b8a8082018-11-30 15:51:58 -080070} // namespace uirenderer
71} // namespace android