| #!/usr/bin/env python3 |
| # Copyright (C) 2020 The Android Open Source Project |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| from os import sys, path |
| |
| import synth_common |
| |
| class JankType: |
| JANK_UNSPECIFIED = 0; |
| JANK_NONE = 1; |
| JANK_SF_SCHEDULING = 2; |
| JANK_PREDICTION_ERROR = 4; |
| JANK_DISPLAY_HAL = 8; |
| JANK_SF_CPU_DEADLINE_MISSED = 16; |
| JANK_SF_GPU_DEADLINE_MISSED = 32; |
| JANK_APP_DEADLINE_MISSED = 64; |
| JANK_BUFFER_STUFFING = 128; |
| JANK_UNKNOWN = 256; |
| JANK_SF_STUFFING = 512; |
| |
| class PresentType: |
| PRESENT_UNSPECIFIED = 0; |
| PRESENT_ON_TIME = 1; |
| PRESENT_LATE = 2; |
| PRESENT_EARLY = 3; |
| PRESENT_DROPPED = 4; |
| PRESENT_UNKNOWN = 5; |
| |
| class PredictionType: |
| PREDICTION_UNSPECIFIED = 0; |
| PREDICTION_VALID = 1; |
| PREDICTION_EXPIRED = 2; |
| PREDICTION_UNKNOWN = 3; |
| |
| trace = synth_common.create_trace() |
| |
| # DisplayFrame without a SurfaceFrame |
| trace.add_expected_display_frame_start_event(ts=20, cookie=1, token=2, pid=666) |
| trace.add_frame_end_event(ts=26, cookie=1) |
| trace.add_actual_display_frame_start_event(ts=20, cookie=2, token=2, pid=666, present_type=PresentType.PRESENT_ON_TIME, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_NONE, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=26, cookie=2) |
| |
| # DisplayFrame with a SurfaceFrame |
| trace.add_expected_display_frame_start_event(ts=40, cookie=3, token=4, pid=666) |
| trace.add_frame_end_event(ts=46, cookie=3) |
| trace.add_actual_display_frame_start_event(ts=42, cookie=4, token=4, pid=666, present_type=PresentType.PRESENT_ON_TIME, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_NONE, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=47, cookie=4) |
| trace.add_expected_surface_frame_start_event(ts=21, cookie=5, token=1, display_frame_token=4, pid=1000, layer_name="Layer1") |
| trace.add_frame_end_event(ts=36, cookie=5) |
| trace.add_actual_surface_frame_start_event(ts=21, cookie=6, token=1, display_frame_token=4, pid=1000, layer_name="Layer1", present_type=PresentType.PRESENT_ON_TIME, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_NONE, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=37, cookie=6) |
| |
| |
| # DisplayFrame with a janky SurfaceFrame |
| trace.add_expected_display_frame_start_event(ts=80, cookie=7, token=6, pid=666) |
| trace.add_frame_end_event(ts=86, cookie=7) |
| trace.add_actual_display_frame_start_event(ts=81, cookie=8, token=6, pid=666, present_type=PresentType.PRESENT_ON_TIME, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_NONE, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=88, cookie=8) |
| trace.add_expected_surface_frame_start_event(ts=41, cookie=9, token=5, display_frame_token=6, pid=1000, layer_name="Layer1") |
| trace.add_frame_end_event(ts=56, cookie=9) |
| trace.add_actual_surface_frame_start_event(ts=41, cookie=10, token=5, display_frame_token=6, pid=1000, layer_name="Layer1", present_type=PresentType.PRESENT_LATE, on_time_finish=0, gpu_composition=0, jank_type=JankType.JANK_APP_DEADLINE_MISSED, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=74, cookie=10) |
| |
| |
| # Janky DisplayFrame with a SurfaceFrame |
| trace.add_expected_display_frame_start_event(ts=120, cookie=11, token=8, pid=666) |
| trace.add_frame_end_event(ts=126, cookie=11) |
| trace.add_actual_display_frame_start_event(ts=108, cookie=12, token=8, pid=666, present_type=PresentType.PRESENT_EARLY, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_SF_SCHEDULING, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=112, cookie=12) |
| trace.add_expected_surface_frame_start_event(ts=90, cookie=13, token=7, display_frame_token=8, pid=1000, layer_name="Layer1") |
| trace.add_frame_end_event(ts=106, cookie=13) |
| trace.add_actual_surface_frame_start_event(ts=90, cookie=14, token=7, display_frame_token=8, pid=1000, layer_name="Layer1", present_type=PresentType.PRESENT_EARLY, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_SF_SCHEDULING, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=106, cookie=14) |
| |
| # DisplayFrame with multiple jank reasons |
| trace.add_expected_display_frame_start_event(ts=140, cookie=15, token=12, pid=666) |
| trace.add_frame_end_event(ts=146, cookie=15) |
| trace.add_actual_display_frame_start_event(ts=148, cookie=16, token=12, pid=666, present_type=PresentType.PRESENT_LATE, on_time_finish=0, gpu_composition=0, jank_type=JankType.JANK_SF_CPU_DEADLINE_MISSED | JankType.JANK_SF_SCHEDULING, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=156, cookie=16) |
| |
| # Two SurfaceFrames with same token |
| trace.add_expected_display_frame_start_event(ts=170, cookie=17, token=15, pid=666) |
| trace.add_frame_end_event(ts=176, cookie=17) |
| trace.add_actual_display_frame_start_event(ts=170, cookie=18, token=15, pid=666, present_type=PresentType.PRESENT_ON_TIME, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_NONE, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=176, cookie=18) |
| trace.add_expected_surface_frame_start_event(ts=150, cookie=19, token=14, display_frame_token=15, pid=1000, layer_name="Layer1") |
| trace.add_frame_end_event(ts=170, cookie=19) |
| trace.add_actual_surface_frame_start_event(ts=150, cookie=20, token=14, display_frame_token=15, pid=1000, layer_name="Layer1", present_type=PresentType.PRESENT_ON_TIME, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_NONE, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=167, cookie=20) |
| trace.add_expected_surface_frame_start_event(ts=150, cookie=21, token=14, display_frame_token=15, pid=1000, layer_name="Layer2") |
| trace.add_frame_end_event(ts=170, cookie=21) |
| trace.add_actual_surface_frame_start_event(ts=150, cookie=22, token=14, display_frame_token=15, pid=1000, layer_name="Layer2", present_type=PresentType.PRESENT_ON_TIME, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_NONE, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=167, cookie=22) |
| |
| # SurfaceFrame with prediction expired (no expected timeline packet) |
| trace.add_expected_display_frame_start_event(ts=200, cookie=23, token=17, pid=666) |
| trace.add_frame_end_event(ts=206, cookie=23) |
| trace.add_actual_display_frame_start_event(ts=200, cookie=24, token=17, pid=666, present_type=PresentType.PRESENT_ON_TIME, on_time_finish=1, gpu_composition=0, jank_type=JankType.JANK_NONE, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=206, cookie=24) |
| trace.add_actual_surface_frame_start_event(ts=80, cookie=25, token=16, display_frame_token=17, pid=1000, layer_name="Layer1", present_type=PresentType.PRESENT_UNKNOWN, on_time_finish=0, gpu_composition=0, jank_type=JankType.JANK_UNKNOWN, prediction_type=PredictionType.PREDICTION_EXPIRED) |
| trace.add_frame_end_event(ts=190, cookie=25) |
| |
| # DisplayFrame with SF Stuffing jank |
| trace.add_expected_display_frame_start_event(ts=220, cookie=26, token=18, pid=666) |
| trace.add_frame_end_event(ts=230, cookie=26) |
| trace.add_actual_display_frame_start_event(ts=245, cookie=27, token=18, pid=666, present_type=PresentType.PRESENT_LATE, on_time_finish=0, gpu_composition=0, jank_type=JankType.JANK_SF_STUFFING, prediction_type=PredictionType.PREDICTION_VALID) |
| trace.add_frame_end_event(ts=260, cookie=27) |
| |
| sys.stdout.buffer.write(trace.trace.SerializeToString()) |