1*6dbdd20aSAndroid Build Coastguard Worker /* 2*6dbdd20aSAndroid Build Coastguard Worker * Copyright (C) 2024 The Android Open Source Project 3*6dbdd20aSAndroid Build Coastguard Worker * 4*6dbdd20aSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*6dbdd20aSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*6dbdd20aSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*6dbdd20aSAndroid Build Coastguard Worker * 8*6dbdd20aSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*6dbdd20aSAndroid Build Coastguard Worker * 10*6dbdd20aSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*6dbdd20aSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*6dbdd20aSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*6dbdd20aSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*6dbdd20aSAndroid Build Coastguard Worker * limitations under the License. 15*6dbdd20aSAndroid Build Coastguard Worker */ 16*6dbdd20aSAndroid Build Coastguard Worker 17*6dbdd20aSAndroid Build Coastguard Worker #ifndef SRC_TRACE_REDACTION_FRAME_COOKIE_H_ 18*6dbdd20aSAndroid Build Coastguard Worker #define SRC_TRACE_REDACTION_FRAME_COOKIE_H_ 19*6dbdd20aSAndroid Build Coastguard Worker 20*6dbdd20aSAndroid Build Coastguard Worker #include <cstdint> 21*6dbdd20aSAndroid Build Coastguard Worker 22*6dbdd20aSAndroid Build Coastguard Worker struct FrameCookie { 23*6dbdd20aSAndroid Build Coastguard Worker // The timestamp from the trace packet. 24*6dbdd20aSAndroid Build Coastguard Worker uint64_t ts; 25*6dbdd20aSAndroid Build Coastguard Worker 26*6dbdd20aSAndroid Build Coastguard Worker // The cookie value will be found inside of the start event (there are four 27*6dbdd20aSAndroid Build Coastguard Worker // different start types). This is the app's pid (main thread id). 28*6dbdd20aSAndroid Build Coastguard Worker 29*6dbdd20aSAndroid Build Coastguard Worker // ExpectedSurfaceFrameStart: pid = app id 30*6dbdd20aSAndroid Build Coastguard Worker // ActualSurfaceFrameStart: pid = app id 31*6dbdd20aSAndroid Build Coastguard Worker 32*6dbdd20aSAndroid Build Coastguard Worker // ExpectedDisplayFrameStart: pid = surface flinger 33*6dbdd20aSAndroid Build Coastguard Worker // ActualDisplayFrameStart: pid = surface flinger 34*6dbdd20aSAndroid Build Coastguard Worker int32_t pid; 35*6dbdd20aSAndroid Build Coastguard Worker 36*6dbdd20aSAndroid Build Coastguard Worker // The cookie value will be found inside of the start event (there are four 37*6dbdd20aSAndroid Build Coastguard Worker // different start types). End events use the cookie to connect to the start 38*6dbdd20aSAndroid Build Coastguard Worker // event. Therefore end events don't need a pid. 39*6dbdd20aSAndroid Build Coastguard Worker int64_t cookie; 40*6dbdd20aSAndroid Build Coastguard Worker }; 41*6dbdd20aSAndroid Build Coastguard Worker 42*6dbdd20aSAndroid Build Coastguard Worker #endif // SRC_TRACE_REDACTION_FRAME_COOKIE_H_ 43