blob: e7dfb3b4d2fd75d372def563114512ed11e1a506 [file] [log] [blame]
#!/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
trace = synth_common.create_trace()
trace.add_packet()
trace.add_process(1, 0, "app_1")
trace.add_process(2, 0, "app_2")
trace.add_process(3, 0, "app_2")
trace.add_ftrace_packet(cpu=0)
# max=4, min=1, avg=(2*1+5*2+(10-9)*4)/(10-2)=2
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=0, pid=0, ts=2, size=1)
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=0, pid=0, ts=4, size=2)
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=0, pid=0, ts=9, size=4)
# max=8, min=2, avg=(5*2+(10-9)*8)/(10-4)=3
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=1, pid=1, ts=4, size=2)
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=1, pid=1, ts=9, size=8)
# max=8, min=6, avgxdur=2*6+(10-4)*8=60, dur=2+(10-4)=8
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=2, pid=2, ts=2, size=6)
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=2, pid=2, ts=4, size=8)
# max=10, min=7, avgxdur=1*7+(10-7)*10=37, dur=1+(10-7)=4
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=3, pid=3, ts=6, size=7)
trace.add_gpu_mem_total_ftrace_event(ftrace_pid=3, pid=3, ts=7, size=10)
# app_2 will be aggregated
# max=10, min=6, avg=(60+37)/(8+4)=8
sys.stdout.buffer.write(trace.trace.SerializeToString())