1*61046927SAndroid Build Coastguard Worker# Copyright © 2021 Igalia S.L. 2*61046927SAndroid Build Coastguard Worker# SPDX-License-Identifier: MIT 3*61046927SAndroid Build Coastguard Worker 4*61046927SAndroid Build Coastguard Workerimport argparse 5*61046927SAndroid Build Coastguard Workerimport sys 6*61046927SAndroid Build Coastguard Worker 7*61046927SAndroid Build Coastguard Worker# 8*61046927SAndroid Build Coastguard Worker# TODO can we do this with less boilerplate? 9*61046927SAndroid Build Coastguard Worker# 10*61046927SAndroid Build Coastguard Workerparser = argparse.ArgumentParser() 11*61046927SAndroid Build Coastguard Workerparser.add_argument('-p', '--import-path', required=True) 12*61046927SAndroid Build Coastguard Workerparser.add_argument('--utrace-src', required=True) 13*61046927SAndroid Build Coastguard Workerparser.add_argument('--utrace-hdr', required=True) 14*61046927SAndroid Build Coastguard Workerparser.add_argument('--perfetto-hdr', required=True) 15*61046927SAndroid Build Coastguard Workerargs = parser.parse_args() 16*61046927SAndroid Build Coastguard Workersys.path.insert(0, args.import_path) 17*61046927SAndroid Build Coastguard Worker 18*61046927SAndroid Build Coastguard Worker 19*61046927SAndroid Build Coastguard Workerfrom u_trace import Header, HeaderScope 20*61046927SAndroid Build Coastguard Workerfrom u_trace import ForwardDecl 21*61046927SAndroid Build Coastguard Workerfrom u_trace import Tracepoint 22*61046927SAndroid Build Coastguard Workerfrom u_trace import TracepointArg as Arg 23*61046927SAndroid Build Coastguard Workerfrom u_trace import TracepointArgStruct as ArgStruct 24*61046927SAndroid Build Coastguard Workerfrom u_trace import utrace_generate 25*61046927SAndroid Build Coastguard Workerfrom u_trace import utrace_generate_perfetto_utils 26*61046927SAndroid Build Coastguard Worker 27*61046927SAndroid Build Coastguard WorkerHeader('vk_enum_to_str.h', scope=HeaderScope.SOURCE|HeaderScope.PERFETTO) 28*61046927SAndroid Build Coastguard WorkerHeader('vk_format.h') 29*61046927SAndroid Build Coastguard WorkerHeader('tu_cmd_buffer.h', scope=HeaderScope.SOURCE) 30*61046927SAndroid Build Coastguard WorkerHeader('tu_device.h', scope=HeaderScope.SOURCE) 31*61046927SAndroid Build Coastguard WorkerHeader('common/freedreno_lrz.h') 32*61046927SAndroid Build Coastguard WorkerHeader('vulkan/vulkan_core.h', scope=HeaderScope.SOURCE|HeaderScope.PERFETTO) 33*61046927SAndroid Build Coastguard Worker 34*61046927SAndroid Build Coastguard Worker# we can't use tu_common.h because it includes ir3 headers which are not 35*61046927SAndroid Build Coastguard Worker# compatible with C++ 36*61046927SAndroid Build Coastguard WorkerForwardDecl('struct tu_cmd_buffer') 37*61046927SAndroid Build Coastguard WorkerForwardDecl('struct tu_device') 38*61046927SAndroid Build Coastguard WorkerForwardDecl('struct tu_framebuffer') 39*61046927SAndroid Build Coastguard WorkerForwardDecl('struct tu_tiling_config') 40*61046927SAndroid Build Coastguard Worker 41*61046927SAndroid Build Coastguard Worker# List of the default tracepoints enabled. By default tracepoints are enabled, 42*61046927SAndroid Build Coastguard Worker# set tp_default_enabled=False to disable them by default. 43*61046927SAndroid Build Coastguard Workertu_default_tps = [] 44*61046927SAndroid Build Coastguard Worker 45*61046927SAndroid Build Coastguard Worker# 46*61046927SAndroid Build Coastguard Worker# Tracepoint definitions: 47*61046927SAndroid Build Coastguard Worker# 48*61046927SAndroid Build Coastguard Worker 49*61046927SAndroid Build Coastguard Workerdef begin_end_tp(name, args=[], tp_struct=None, tp_print=None, 50*61046927SAndroid Build Coastguard Worker end_args=[], end_tp_struct=None, end_tp_print=None, 51*61046927SAndroid Build Coastguard Worker tp_default_enabled=True, marker_tp=True, 52*61046927SAndroid Build Coastguard Worker queue_tp=True): 53*61046927SAndroid Build Coastguard Worker global tu_default_tps 54*61046927SAndroid Build Coastguard Worker if tp_default_enabled: 55*61046927SAndroid Build Coastguard Worker tu_default_tps.append(name) 56*61046927SAndroid Build Coastguard Worker Tracepoint('start_{0}'.format(name), 57*61046927SAndroid Build Coastguard Worker toggle_name=name, 58*61046927SAndroid Build Coastguard Worker args=args, 59*61046927SAndroid Build Coastguard Worker tp_struct=tp_struct, 60*61046927SAndroid Build Coastguard Worker tp_perfetto='tu_perfetto_start_{0}'.format(name) if queue_tp else None, 61*61046927SAndroid Build Coastguard Worker tp_print=tp_print if queue_tp else None, 62*61046927SAndroid Build Coastguard Worker tp_markers='tu_cs_trace_start' if marker_tp else None) 63*61046927SAndroid Build Coastguard Worker Tracepoint('end_{0}'.format(name), 64*61046927SAndroid Build Coastguard Worker toggle_name=name, 65*61046927SAndroid Build Coastguard Worker args=end_args, 66*61046927SAndroid Build Coastguard Worker tp_struct=end_tp_struct, 67*61046927SAndroid Build Coastguard Worker tp_perfetto='tu_perfetto_end_{0}'.format(name), 68*61046927SAndroid Build Coastguard Worker tp_print=end_tp_print if queue_tp else None, 69*61046927SAndroid Build Coastguard Worker tp_markers='tu_cs_trace_end' if marker_tp else None) 70*61046927SAndroid Build Coastguard Worker 71*61046927SAndroid Build Coastguard Workerbegin_end_tp('cmd_buffer', 72*61046927SAndroid Build Coastguard Worker args=[ArgStruct(type='const struct tu_cmd_buffer *', var='cmd')], 73*61046927SAndroid Build Coastguard Worker tp_struct=[Arg(type='VkCommandBufferLevel', name='level', var='cmd->vk.level', c_format='%s', to_prim_type='vk_CommandBufferLevel_to_str({})'), 74*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', name='render_pass_continue', var='!!(cmd->usage_flags & VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT)', c_format='%u')]) 75*61046927SAndroid Build Coastguard Worker 76*61046927SAndroid Build Coastguard Workerbegin_end_tp('render_pass', 77*61046927SAndroid Build Coastguard Worker args=[ArgStruct(type='const struct tu_framebuffer *', var='fb'), 78*61046927SAndroid Build Coastguard Worker ArgStruct(type='const struct tu_tiling_config *', var='tiling'), 79*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='maxSamples', c_format='%u'), 80*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='clearCPP', c_format='%u'), 81*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='loadCPP', c_format='%u'), 82*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='storeCPP', c_format='%u'), 83*61046927SAndroid Build Coastguard Worker Arg(type='bool', var='hasDepth', c_format='%s', to_prim_type='({} ? "true" : "false")'), 84*61046927SAndroid Build Coastguard Worker Arg(type='str', var='ubwc', c_format='%s', length_arg='11', copy_func='strncpy'),], 85*61046927SAndroid Build Coastguard Worker tp_struct=[Arg(type='uint16_t', name='width', var='fb->width', c_format='%u'), 86*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', name='height', var='fb->height', c_format='%u'), 87*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', name='attachment_count', var='fb->attachment_count', c_format='%u'), 88*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', name='numberOfBins', var='tiling->tile_count.width * tiling->tile_count.height', c_format='%u'), 89*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', name='binWidth', var='tiling->tile0.width', c_format='%u'), 90*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', name='binHeight', var='tiling->tile0.height', c_format='%u'),], 91*61046927SAndroid Build Coastguard Worker # Args known only at the end of the renderpass: 92*61046927SAndroid Build Coastguard Worker end_args=[Arg(type='bool', var='tiledRender', c_format='%s', to_prim_type='({} ? "true" : "false")'), 93*61046927SAndroid Build Coastguard Worker Arg(type='uint32_t', var='drawCount', c_format='%u'), 94*61046927SAndroid Build Coastguard Worker Arg(type='uint32_t', var='avgPerSampleBandwidth', c_format='%u'), 95*61046927SAndroid Build Coastguard Worker Arg(type='bool', var='lrz', c_format='%s', to_prim_type='({} ? "true" : "false")'), 96*61046927SAndroid Build Coastguard Worker Arg(type='const char *', var='lrzDisableReason', c_format='%s'), 97*61046927SAndroid Build Coastguard Worker Arg(type='uint32_t', var='lrzStatus', c_format='%s', to_prim_type='(fd_lrz_gpu_dir_to_str((enum fd_lrz_gpu_dir)({} & 0xff)))', is_indirect=True),]) 98*61046927SAndroid Build Coastguard Worker 99*61046927SAndroid Build Coastguard Worker 100*61046927SAndroid Build Coastguard Workerbegin_end_tp('binning_ib') 101*61046927SAndroid Build Coastguard Workerbegin_end_tp('draw_ib_sysmem') 102*61046927SAndroid Build Coastguard Workerbegin_end_tp('draw_ib_gmem') 103*61046927SAndroid Build Coastguard Worker 104*61046927SAndroid Build Coastguard Workerbegin_end_tp('generic_clear', 105*61046927SAndroid Build Coastguard Worker args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 106*61046927SAndroid Build Coastguard Worker Arg(type='bool', var='ubwc', c_format='%s', to_prim_type='({} ? "true" : "false")'), 107*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='samples', c_format='%u')]) 108*61046927SAndroid Build Coastguard Worker 109*61046927SAndroid Build Coastguard Workerbegin_end_tp('gmem_clear', 110*61046927SAndroid Build Coastguard Worker args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 111*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='samples', c_format='%u')]) 112*61046927SAndroid Build Coastguard Worker 113*61046927SAndroid Build Coastguard Workerbegin_end_tp('sysmem_clear', 114*61046927SAndroid Build Coastguard Worker args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 115*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='uses_3d_ops', c_format='%u'), 116*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='samples', c_format='%u')]) 117*61046927SAndroid Build Coastguard Worker 118*61046927SAndroid Build Coastguard Workerbegin_end_tp('sysmem_clear_all', 119*61046927SAndroid Build Coastguard Worker args=[Arg(type='uint8_t', var='mrt_count', c_format='%u'), 120*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='rect_count', c_format='%u')]) 121*61046927SAndroid Build Coastguard Worker 122*61046927SAndroid Build Coastguard Workerbegin_end_tp('gmem_load', 123*61046927SAndroid Build Coastguard Worker args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 124*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='force_load', c_format='%u')]) 125*61046927SAndroid Build Coastguard Worker 126*61046927SAndroid Build Coastguard Workerbegin_end_tp('gmem_store', 127*61046927SAndroid Build Coastguard Worker args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 128*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='fast_path', c_format='%u'), 129*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='unaligned', c_format='%u')]) 130*61046927SAndroid Build Coastguard Worker 131*61046927SAndroid Build Coastguard Workerbegin_end_tp('sysmem_resolve', 132*61046927SAndroid Build Coastguard Worker args=[Arg(type='enum VkFormat', var='format', c_format='%s', to_prim_type='vk_format_description({})->short_name')]) 133*61046927SAndroid Build Coastguard Worker 134*61046927SAndroid Build Coastguard Workerbegin_end_tp('blit', 135*61046927SAndroid Build Coastguard Worker # TODO: add source megapixels count and target megapixels count arguments 136*61046927SAndroid Build Coastguard Worker args=[Arg(type='uint8_t', var='uses_3d_blit', c_format='%u'), 137*61046927SAndroid Build Coastguard Worker Arg(type='enum VkFormat', var='src_format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 138*61046927SAndroid Build Coastguard Worker Arg(type='enum VkFormat', var='dst_format', c_format='%s', to_prim_type='vk_format_description({})->short_name'), 139*61046927SAndroid Build Coastguard Worker Arg(type='uint8_t', var='layers', c_format='%u')]) 140*61046927SAndroid Build Coastguard Worker 141*61046927SAndroid Build Coastguard Workerbegin_end_tp('compute', 142*61046927SAndroid Build Coastguard Worker args=[Arg(type='uint8_t', var='indirect', c_format='%u'), 143*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', var='local_size_x', c_format='%u'), 144*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', var='local_size_y', c_format='%u'), 145*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', var='local_size_z', c_format='%u'), 146*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', var='num_groups_x', c_format='%u'), 147*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', var='num_groups_y', c_format='%u'), 148*61046927SAndroid Build Coastguard Worker Arg(type='uint16_t', var='num_groups_z', c_format='%u')]) 149*61046927SAndroid Build Coastguard Worker 150*61046927SAndroid Build Coastguard Workerbegin_end_tp('compute_indirect', 151*61046927SAndroid Build Coastguard Worker end_args=[ArgStruct(type='VkDispatchIndirectCommand', var='size', 152*61046927SAndroid Build Coastguard Worker is_indirect=True, c_format="%ux%ux%u", 153*61046927SAndroid Build Coastguard Worker fields=['x', 'y', 'z'])]) 154*61046927SAndroid Build Coastguard Worker 155*61046927SAndroid Build Coastguard Worker# Annotations for Cmd(Begin|End)DebugUtilsLabelEXT 156*61046927SAndroid Build Coastguard Workerfor suffix in ["", "_rp"]: 157*61046927SAndroid Build Coastguard Worker begin_end_tp('cmd_buffer_annotation' + suffix, 158*61046927SAndroid Build Coastguard Worker args=[Arg(type='unsigned', var='len'), 159*61046927SAndroid Build Coastguard Worker Arg(type='str', var='str', c_format='%s', length_arg='len + 1', copy_func='strncpy'),], 160*61046927SAndroid Build Coastguard Worker tp_struct=[Arg(type='uint8_t', name='dummy', var='0'),]) 161*61046927SAndroid Build Coastguard Worker 162*61046927SAndroid Build Coastguard Workerutrace_generate(cpath=args.utrace_src, 163*61046927SAndroid Build Coastguard Worker hpath=args.utrace_hdr, 164*61046927SAndroid Build Coastguard Worker ctx_param='struct tu_device *dev', 165*61046927SAndroid Build Coastguard Worker trace_toggle_name='tu_gpu_tracepoint', 166*61046927SAndroid Build Coastguard Worker trace_toggle_defaults=tu_default_tps) 167*61046927SAndroid Build Coastguard Workerutrace_generate_perfetto_utils(hpath=args.perfetto_hdr) 168