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/RefBase.h> 20*d57664e9SAndroid Build Coastguard Worker 21*d57664e9SAndroid Build Coastguard Worker namespace android { 22*d57664e9SAndroid Build Coastguard Worker namespace uirenderer { 23*d57664e9SAndroid Build Coastguard Worker 24*d57664e9SAndroid Build Coastguard Worker class FrameMetricsObserver : public VirtualLightRefBase { 25*d57664e9SAndroid Build Coastguard Worker public: 26*d57664e9SAndroid Build Coastguard Worker virtual void notify(const int64_t* buffer) = 0; waitForPresentTime()27*d57664e9SAndroid Build Coastguard Worker bool waitForPresentTime() const { return mWaitForPresentTime; }; 28*d57664e9SAndroid Build Coastguard Worker reportMetricsFrom(uint64_t frameNumber,int32_t surfaceControlId)29*d57664e9SAndroid Build Coastguard Worker void reportMetricsFrom(uint64_t frameNumber, int32_t surfaceControlId) { 30*d57664e9SAndroid Build Coastguard Worker mAttachedFrameNumber = frameNumber; 31*d57664e9SAndroid Build Coastguard Worker mSurfaceControlId = surfaceControlId; 32*d57664e9SAndroid Build Coastguard Worker }; attachedFrameNumber()33*d57664e9SAndroid Build Coastguard Worker uint64_t attachedFrameNumber() const { return mAttachedFrameNumber; }; attachedSurfaceControlId()34*d57664e9SAndroid Build Coastguard Worker int32_t attachedSurfaceControlId() const { return mSurfaceControlId; }; 35*d57664e9SAndroid Build Coastguard Worker 36*d57664e9SAndroid Build Coastguard Worker /** 37*d57664e9SAndroid Build Coastguard Worker * Create a new metrics observer. An observer that watches present time gets notified at a 38*d57664e9SAndroid Build Coastguard Worker * different time than the observer that doesn't. 39*d57664e9SAndroid Build Coastguard Worker * 40*d57664e9SAndroid Build Coastguard Worker * The observer that doesn't want present time is notified about metrics just after the frame 41*d57664e9SAndroid Build Coastguard Worker * is completed. This is the default behaviour that's used by public API's. 42*d57664e9SAndroid Build Coastguard Worker * 43*d57664e9SAndroid Build Coastguard Worker * An observer that watches present time is notified about metrics after the actual display 44*d57664e9SAndroid Build Coastguard Worker * present time is known. 45*d57664e9SAndroid Build Coastguard Worker * WARNING! This observer may not receive metrics for the last several frames that the app 46*d57664e9SAndroid Build Coastguard Worker * produces. 47*d57664e9SAndroid Build Coastguard Worker */ FrameMetricsObserver(bool waitForPresentTime)48*d57664e9SAndroid Build Coastguard Worker FrameMetricsObserver(bool waitForPresentTime) 49*d57664e9SAndroid Build Coastguard Worker : mWaitForPresentTime(waitForPresentTime) 50*d57664e9SAndroid Build Coastguard Worker , mSurfaceControlId(INT32_MAX) 51*d57664e9SAndroid Build Coastguard Worker , mAttachedFrameNumber(UINT64_MAX) {} 52*d57664e9SAndroid Build Coastguard Worker 53*d57664e9SAndroid Build Coastguard Worker private: 54*d57664e9SAndroid Build Coastguard Worker const bool mWaitForPresentTime; 55*d57664e9SAndroid Build Coastguard Worker 56*d57664e9SAndroid Build Coastguard Worker // The id of the surface control (mSurfaceControlGenerationId in CanvasContext) 57*d57664e9SAndroid Build Coastguard Worker // for which the mAttachedFrameNumber applies to. We rely on this value being 58*d57664e9SAndroid Build Coastguard Worker // an increasing counter. We will report metrics: 59*d57664e9SAndroid Build Coastguard Worker // - for all frames if the frame comes from a surface with a surfaceControlId 60*d57664e9SAndroid Build Coastguard Worker // that is strictly greater than mSurfaceControlId. 61*d57664e9SAndroid Build Coastguard Worker // - for all frames with a frame number greater than or equal to mAttachedFrameNumber 62*d57664e9SAndroid Build Coastguard Worker // if the frame comes from a surface with a surfaceControlId that is equal to the 63*d57664e9SAndroid Build Coastguard Worker // mSurfaceControlId. 64*d57664e9SAndroid Build Coastguard Worker // We will never report metrics if the frame comes from a surface with a surfaceControlId 65*d57664e9SAndroid Build Coastguard Worker // that is strictly smaller than mSurfaceControlId. 66*d57664e9SAndroid Build Coastguard Worker int32_t mSurfaceControlId; 67*d57664e9SAndroid Build Coastguard Worker 68*d57664e9SAndroid Build Coastguard Worker // The frame number the metrics observer was attached on. Metrics will be sent from this frame 69*d57664e9SAndroid Build Coastguard Worker // number (inclusive) onwards in the case that the surface id is equal to mSurfaceControlId. 70*d57664e9SAndroid Build Coastguard Worker uint64_t mAttachedFrameNumber; 71*d57664e9SAndroid Build Coastguard Worker }; 72*d57664e9SAndroid Build Coastguard Worker 73*d57664e9SAndroid Build Coastguard Worker } // namespace uirenderer 74*d57664e9SAndroid Build Coastguard Worker } // namespace android 75