blob: 3ea49518eecd49c5024216d41c60e0a61141e26e [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 */
Greg Kaiser346312c2021-09-09 09:37:48 -070048 FrameMetricsObserver(bool waitForPresentTime)
49 : mWaitForPresentTime(waitForPresentTime)
50 , mSurfaceControlId(INT32_MAX)
51 , mAttachedFrameNumber(UINT64_MAX) {}
Siarhei Vishniakouf0cf18d2021-02-26 00:15:04 +000052
53private:
54 const bool mWaitForPresentTime;
Pablo Gamito88660d72021-08-09 14:37:56 +000055
56 // The id of the surface control (mSurfaceControlGenerationId in CanvasContext)
57 // for which the mAttachedFrameNumber applies to. We rely on this value being
58 // an increasing counter. We will report metrics:
59 // - for all frames if the frame comes from a surface with a surfaceControlId
60 // that is strictly greater than mSurfaceControlId.
61 // - for all frames with a frame number greater than or equal to mAttachedFrameNumber
62 // if the frame comes from a surface with a surfaceControlId that is equal to the
63 // mSurfaceControlId.
64 // We will never report metrics if the frame comes from a surface with a surfaceControlId
65 // that is strictly smaller than mSurfaceControlId.
66 int32_t mSurfaceControlId;
67
68 // The frame number the metrics observer was attached on. Metrics will be sent from this frame
69 // number (inclusive) onwards in the case that the surface id is equal to mSurfaceControlId.
Pablo Gamito35b80cd2021-08-24 11:03:51 +020070 uint64_t mAttachedFrameNumber;
Andres Morales06f5bc72015-12-15 15:21:31 -080071};
72
Chris Blume7b8a8082018-11-30 15:51:58 -080073} // namespace uirenderer
74} // namespace android