xref: /aosp_15_r20/external/mesa3d/src/freedreno/vulkan/tu_tracepoints.py (revision 6104692788411f58d303aa86923a9ff6ecaded22)
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