1# Copyright © 2021 Igalia S.L. 2# SPDX-License-Identifier: MIT 3 4import argparse 5import sys 6 7# 8# TODO can we do this with less boilerplate? 9# 10parser = argparse.ArgumentParser() 11parser.add_argument('-p', '--import-path', required=True) 12parser.add_argument('--utrace-src', required=True) 13parser.add_argument('--utrace-hdr', required=True) 14parser.add_argument('--perfetto-hdr', required=True) 15args = parser.parse_args() 16sys.path.insert(0, args.import_path) 17 18 19from u_trace import Header, HeaderScope 20from u_trace import ForwardDecl 21from u_trace import Tracepoint 22from u_trace import TracepointArg as Arg 23from u_trace import TracepointArgStruct as ArgStruct 24from u_trace import utrace_generate 25from u_trace import utrace_generate_perfetto_utils 26 27# List of the default tracepoints enabled. By default tracepoints are enabled, 28# set tp_default_enabled=False to disable them by default. 29tu_default_tps = [] 30 31# 32# Tracepoint definitions: 33# 34 35Header('util/u_dump.h') 36Header('vk_format.h') 37Header('freedreno/vulkan/tu_device.h', scope=HeaderScope.SOURCE) 38 39ForwardDecl('struct tu_device') 40 41 42def begin_end_tp(name, args=[], tp_struct=None, tp_print=None, 43 tp_default_enabled=True): 44 global tu_default_tps 45 if tp_default_enabled: 46 tu_default_tps.append(name) 47 Tracepoint('start_{0}'.format(name), 48 toggle_name=name, 49 tp_perfetto='tu_start_{0}'.format(name)) 50 Tracepoint('end_{0}'.format(name), 51 toggle_name=name, 52 args=args, 53 tp_struct=tp_struct, 54 tp_perfetto='tu_end_{0}'.format(name), 55 tp_print=tp_print) 56 57 58begin_end_tp('render_pass', 59 args=[ArgStruct(type='const struct tu_framebuffer *', var='fb'), 60 ArgStruct(type='const struct tu_tiling_config *', var='tiling')], 61 tp_struct=[Arg(type='uint16_t', name='width', var='fb->width', c_format='%u'), 62 Arg(type='uint16_t', name='height', var='fb->height', c_format='%u'), 63 Arg(type='uint8_t', name='MRTs', var='fb->attachment_count', c_format='%u'), 64 # Arg(type='uint8_t', name='samples', var='fb->samples', c_format='%u'), 65 Arg(type='uint16_t', name='numberOfBins', var='tiling->tile_count.width * tiling->tile_count.height', c_format='%u'), 66 Arg(type='uint16_t', name='binWidth', var='tiling->tile0.width', c_format='%u'), 67 Arg(type='uint16_t', name='binHeight', var='tiling->tile0.height', c_format='%u')]) 68 69begin_end_tp('binning_ib') 70begin_end_tp('draw_ib_sysmem') 71begin_end_tp('draw_ib_gmem') 72 73begin_end_tp('gmem_clear', 74 args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 75 Arg(type='uint8_t', var='samples', c_format='%u')]) 76 77begin_end_tp('sysmem_clear', 78 args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 79 Arg(type='uint8_t', var='uses_3d_ops', c_format='%u'), 80 Arg(type='uint8_t', var='samples', c_format='%u')]) 81 82begin_end_tp('sysmem_clear_all', 83 args=[Arg(type='uint8_t', var='mrt_count', c_format='%u'), 84 Arg(type='uint8_t', var='rect_count', c_format='%u')]) 85 86begin_end_tp('gmem_load', 87 args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 88 Arg(type='uint8_t', var='force_load', c_format='%u')]) 89 90begin_end_tp('gmem_store', 91 args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 92 Arg(type='uint8_t', var='fast_path', c_format='%u'), 93 Arg(type='uint8_t', var='unaligned', c_format='%u')]) 94 95begin_end_tp('sysmem_resolve', 96 args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name')]) 97 98begin_end_tp('blit', 99 # TODO: add source megapixels count and target megapixels count arguments 100 args=[Arg(type='uint8_t', var='uses_3d_blit', c_format='%u'), 101 Arg(type='enum VkFormat', var='src_format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 102 Arg(type='enum VkFormat', var='dst_format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 103 Arg(type='uint8_t', var='layers', c_format='%u')]) 104 105begin_end_tp('compute', 106 args=[Arg(type='uint8_t', var='indirect', c_format='%u'), 107 Arg(type='uint16_t', var='local_size_x', c_format='%u'), 108 Arg(type='uint16_t', var='local_size_y', c_format='%u'), 109 Arg(type='uint16_t', var='local_size_z', c_format='%u'), 110 Arg(type='uint16_t', var='num_groups_x', c_format='%u'), 111 Arg(type='uint16_t', var='num_groups_y', c_format='%u'), 112 Arg(type='uint16_t', var='num_groups_z', c_format='%u')]) 113 114utrace_generate(cpath=args.utrace_src, 115 hpath=args.utrace_hdr, 116 ctx_param='struct tu_device *dev', 117 trace_toggle_name='tu_gpu_tracepoint', 118 trace_toggle_defaults=tu_default_tps) 119utrace_generate_perfetto_utils(hpath=args.perfetto_hdr) 120