1 /**************************************************************************
3 * Copyright 2008 VMware, Inc.
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21 * IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR
22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 **************************************************************************/
29 #include "pipe/p_compiler.h"
30 #include "util/u_memory.h"
31 #include "util/u_format.h"
32 #include "tgsi/tgsi_dump.h"
35 #include "tr_dump_defines.h"
36 #include "tr_dump_state.h"
39 void trace_dump_resource_template(const struct pipe_resource
*templat
)
41 if (!trace_dumping_enabled_locked())
49 trace_dump_struct_begin("pipe_resource");
51 trace_dump_member(int, templat
, target
);
52 trace_dump_member(format
, templat
, format
);
54 trace_dump_member_begin("width");
55 trace_dump_uint(templat
->width0
);
56 trace_dump_member_end();
58 trace_dump_member_begin("height");
59 trace_dump_uint(templat
->height0
);
60 trace_dump_member_end();
62 trace_dump_member_begin("depth");
63 trace_dump_uint(templat
->depth0
);
64 trace_dump_member_end();
66 trace_dump_member_begin("array_size");
67 trace_dump_uint(templat
->array_size
);
68 trace_dump_member_end();
70 trace_dump_member(uint
, templat
, last_level
);
71 trace_dump_member(uint
, templat
, nr_samples
);
72 trace_dump_member(uint
, templat
, usage
);
73 trace_dump_member(uint
, templat
, bind
);
74 trace_dump_member(uint
, templat
, flags
);
76 trace_dump_struct_end();
80 void trace_dump_box(const struct pipe_box
*box
)
82 if (!trace_dumping_enabled_locked())
90 trace_dump_struct_begin("pipe_box");
92 trace_dump_member(int, box
, x
);
93 trace_dump_member(int, box
, y
);
94 trace_dump_member(int, box
, z
);
95 trace_dump_member(int, box
, width
);
96 trace_dump_member(int, box
, height
);
97 trace_dump_member(int, box
, depth
);
99 trace_dump_struct_end();
103 void trace_dump_rasterizer_state(const struct pipe_rasterizer_state
*state
)
105 if (!trace_dumping_enabled_locked())
113 trace_dump_struct_begin("pipe_rasterizer_state");
115 trace_dump_member(bool, state
, flatshade
);
116 trace_dump_member(bool, state
, light_twoside
);
117 trace_dump_member(bool, state
, clamp_vertex_color
);
118 trace_dump_member(bool, state
, clamp_fragment_color
);
119 trace_dump_member(uint
, state
, front_ccw
);
120 trace_dump_member(uint
, state
, cull_face
);
121 trace_dump_member(uint
, state
, fill_front
);
122 trace_dump_member(uint
, state
, fill_back
);
123 trace_dump_member(bool, state
, offset_point
);
124 trace_dump_member(bool, state
, offset_line
);
125 trace_dump_member(bool, state
, offset_tri
);
126 trace_dump_member(bool, state
, scissor
);
127 trace_dump_member(bool, state
, poly_smooth
);
128 trace_dump_member(bool, state
, poly_stipple_enable
);
129 trace_dump_member(bool, state
, point_smooth
);
130 trace_dump_member(bool, state
, sprite_coord_mode
);
131 trace_dump_member(bool, state
, point_quad_rasterization
);
132 trace_dump_member(bool, state
, point_size_per_vertex
);
133 trace_dump_member(bool, state
, multisample
);
134 trace_dump_member(bool, state
, line_smooth
);
135 trace_dump_member(bool, state
, line_stipple_enable
);
136 trace_dump_member(bool, state
, line_last_pixel
);
138 trace_dump_member(bool, state
, flatshade_first
);
140 trace_dump_member(bool, state
, half_pixel_center
);
141 trace_dump_member(bool, state
, bottom_edge_rule
);
143 trace_dump_member(bool, state
, rasterizer_discard
);
145 trace_dump_member(bool, state
, depth_clip
);
147 trace_dump_member(bool, state
, clip_halfz
);
149 trace_dump_member(uint
, state
, clip_plane_enable
);
151 trace_dump_member(uint
, state
, line_stipple_factor
);
152 trace_dump_member(uint
, state
, line_stipple_pattern
);
154 trace_dump_member(uint
, state
, sprite_coord_enable
);
156 trace_dump_member(float, state
, line_width
);
157 trace_dump_member(float, state
, point_size
);
158 trace_dump_member(float, state
, offset_units
);
159 trace_dump_member(float, state
, offset_scale
);
160 trace_dump_member(float, state
, offset_clamp
);
162 trace_dump_struct_end();
166 void trace_dump_poly_stipple(const struct pipe_poly_stipple
*state
)
168 if (!trace_dumping_enabled_locked())
176 trace_dump_struct_begin("pipe_poly_stipple");
178 trace_dump_member_begin("stipple");
179 trace_dump_array(uint
,
181 Elements(state
->stipple
));
182 trace_dump_member_end();
184 trace_dump_struct_end();
188 void trace_dump_viewport_state(const struct pipe_viewport_state
*state
)
190 if (!trace_dumping_enabled_locked())
198 trace_dump_struct_begin("pipe_viewport_state");
200 trace_dump_member_array(float, state
, scale
);
201 trace_dump_member_array(float, state
, translate
);
203 trace_dump_struct_end();
207 void trace_dump_scissor_state(const struct pipe_scissor_state
*state
)
209 if (!trace_dumping_enabled_locked())
217 trace_dump_struct_begin("pipe_scissor_state");
219 trace_dump_member(uint
, state
, minx
);
220 trace_dump_member(uint
, state
, miny
);
221 trace_dump_member(uint
, state
, maxx
);
222 trace_dump_member(uint
, state
, maxy
);
224 trace_dump_struct_end();
228 void trace_dump_clip_state(const struct pipe_clip_state
*state
)
232 if (!trace_dumping_enabled_locked())
240 trace_dump_struct_begin("pipe_clip_state");
242 trace_dump_member_begin("ucp");
243 trace_dump_array_begin();
244 for(i
= 0; i
< PIPE_MAX_CLIP_PLANES
; ++i
) {
245 trace_dump_elem_begin();
246 trace_dump_array(float, state
->ucp
[i
], 4);
247 trace_dump_elem_end();
249 trace_dump_array_end();
250 trace_dump_member_end();
252 trace_dump_struct_end();
256 void trace_dump_shader_state(const struct pipe_shader_state
*state
)
260 if (!trace_dumping_enabled_locked())
269 trace_dump_struct_begin("pipe_shader_state");
271 trace_dump_member_begin("tokens");
273 static char str
[64 * 1024];
274 tgsi_dump_str(state
->tokens
, 0, str
, sizeof(str
));
275 trace_dump_string(str
);
279 trace_dump_member_end();
281 trace_dump_member_begin("stream_output");
282 trace_dump_struct_begin("pipe_stream_output_info");
283 trace_dump_member(uint
, &state
->stream_output
, num_outputs
);
284 trace_dump_member_array(uint
, &state
->stream_output
, stride
);
285 trace_dump_member_begin("output");
286 trace_dump_array_begin();
287 for(i
= 0; i
< state
->stream_output
.num_outputs
; ++i
) {
288 trace_dump_elem_begin();
289 trace_dump_struct_begin(""); /* anonymous */
290 trace_dump_member(uint
, &state
->stream_output
.output
[i
], register_index
);
291 trace_dump_member(uint
, &state
->stream_output
.output
[i
], start_component
);
292 trace_dump_member(uint
, &state
->stream_output
.output
[i
], num_components
);
293 trace_dump_member(uint
, &state
->stream_output
.output
[i
], output_buffer
);
294 trace_dump_member(uint
, &state
->stream_output
.output
[i
], dst_offset
);
295 trace_dump_member(uint
, &state
->stream_output
.output
[i
], stream
);
296 trace_dump_struct_end();
297 trace_dump_elem_end();
299 trace_dump_array_end();
300 trace_dump_member_end(); // output
301 trace_dump_struct_end();
302 trace_dump_member_end(); // stream_output
304 trace_dump_struct_end();
308 void trace_dump_depth_stencil_alpha_state(const struct pipe_depth_stencil_alpha_state
*state
)
312 if (!trace_dumping_enabled_locked())
320 trace_dump_struct_begin("pipe_depth_stencil_alpha_state");
322 trace_dump_member_begin("depth");
323 trace_dump_struct_begin("pipe_depth_state");
324 trace_dump_member(bool, &state
->depth
, enabled
);
325 trace_dump_member(bool, &state
->depth
, writemask
);
326 trace_dump_member(uint
, &state
->depth
, func
);
327 trace_dump_struct_end();
328 trace_dump_member_end();
330 trace_dump_member_begin("stencil");
331 trace_dump_array_begin();
332 for(i
= 0; i
< Elements(state
->stencil
); ++i
) {
333 trace_dump_elem_begin();
334 trace_dump_struct_begin("pipe_stencil_state");
335 trace_dump_member(bool, &state
->stencil
[i
], enabled
);
336 trace_dump_member(uint
, &state
->stencil
[i
], func
);
337 trace_dump_member(uint
, &state
->stencil
[i
], fail_op
);
338 trace_dump_member(uint
, &state
->stencil
[i
], zpass_op
);
339 trace_dump_member(uint
, &state
->stencil
[i
], zfail_op
);
340 trace_dump_member(uint
, &state
->stencil
[i
], valuemask
);
341 trace_dump_member(uint
, &state
->stencil
[i
], writemask
);
342 trace_dump_struct_end();
343 trace_dump_elem_end();
345 trace_dump_array_end();
346 trace_dump_member_end();
348 trace_dump_member_begin("alpha");
349 trace_dump_struct_begin("pipe_alpha_state");
350 trace_dump_member(bool, &state
->alpha
, enabled
);
351 trace_dump_member(uint
, &state
->alpha
, func
);
352 trace_dump_member(float, &state
->alpha
, ref_value
);
353 trace_dump_struct_end();
354 trace_dump_member_end();
356 trace_dump_struct_end();
359 static void trace_dump_rt_blend_state(const struct pipe_rt_blend_state
*state
)
361 trace_dump_struct_begin("pipe_rt_blend_state");
363 trace_dump_member(uint
, state
, blend_enable
);
365 trace_dump_member(uint
, state
, rgb_func
);
366 trace_dump_member(uint
, state
, rgb_src_factor
);
367 trace_dump_member(uint
, state
, rgb_dst_factor
);
369 trace_dump_member(uint
, state
, alpha_func
);
370 trace_dump_member(uint
, state
, alpha_src_factor
);
371 trace_dump_member(uint
, state
, alpha_dst_factor
);
373 trace_dump_member(uint
, state
, colormask
);
375 trace_dump_struct_end();
378 void trace_dump_blend_state(const struct pipe_blend_state
*state
)
380 unsigned valid_entries
= 1;
382 if (!trace_dumping_enabled_locked())
390 trace_dump_struct_begin("pipe_blend_state");
392 trace_dump_member(bool, state
, dither
);
394 trace_dump_member(bool, state
, logicop_enable
);
395 trace_dump_member(uint
, state
, logicop_func
);
397 trace_dump_member(bool, state
, independent_blend_enable
);
399 trace_dump_member_begin("rt");
400 if (state
->independent_blend_enable
)
401 valid_entries
= PIPE_MAX_COLOR_BUFS
;
402 trace_dump_struct_array(rt_blend_state
, state
->rt
, valid_entries
);
403 trace_dump_member_end();
405 trace_dump_struct_end();
409 void trace_dump_blend_color(const struct pipe_blend_color
*state
)
411 if (!trace_dumping_enabled_locked())
419 trace_dump_struct_begin("pipe_blend_color");
421 trace_dump_member_array(float, state
, color
);
423 trace_dump_struct_end();
426 void trace_dump_stencil_ref(const struct pipe_stencil_ref
*state
)
428 if (!trace_dumping_enabled_locked())
436 trace_dump_struct_begin("pipe_stencil_ref");
438 trace_dump_member_array(uint
, state
, ref_value
);
440 trace_dump_struct_end();
443 void trace_dump_framebuffer_state(const struct pipe_framebuffer_state
*state
)
445 if (!trace_dumping_enabled_locked())
448 trace_dump_struct_begin("pipe_framebuffer_state");
450 trace_dump_member(uint
, state
, width
);
451 trace_dump_member(uint
, state
, height
);
452 trace_dump_member(uint
, state
, nr_cbufs
);
453 trace_dump_member_array(ptr
, state
, cbufs
);
454 trace_dump_member(ptr
, state
, zsbuf
);
456 trace_dump_struct_end();
460 void trace_dump_sampler_state(const struct pipe_sampler_state
*state
)
462 if (!trace_dumping_enabled_locked())
470 trace_dump_struct_begin("pipe_sampler_state");
472 trace_dump_member(uint
, state
, wrap_s
);
473 trace_dump_member(uint
, state
, wrap_t
);
474 trace_dump_member(uint
, state
, wrap_r
);
475 trace_dump_member(uint
, state
, min_img_filter
);
476 trace_dump_member(uint
, state
, min_mip_filter
);
477 trace_dump_member(uint
, state
, mag_img_filter
);
478 trace_dump_member(uint
, state
, compare_mode
);
479 trace_dump_member(uint
, state
, compare_func
);
480 trace_dump_member(bool, state
, normalized_coords
);
481 trace_dump_member(uint
, state
, max_anisotropy
);
482 trace_dump_member(bool, state
, seamless_cube_map
);
483 trace_dump_member(float, state
, lod_bias
);
484 trace_dump_member(float, state
, min_lod
);
485 trace_dump_member(float, state
, max_lod
);
486 trace_dump_member_array(float, state
, border_color
.f
);
488 trace_dump_struct_end();
492 void trace_dump_sampler_view_template(const struct pipe_sampler_view
*state
,
493 enum pipe_texture_target target
)
495 if (!trace_dumping_enabled_locked())
503 trace_dump_struct_begin("pipe_sampler_view");
505 trace_dump_member(format
, state
, format
);
507 trace_dump_member_begin("u");
508 trace_dump_struct_begin(""); /* anonymous */
509 if (target
== PIPE_BUFFER
) {
510 trace_dump_member_begin("buf");
511 trace_dump_struct_begin(""); /* anonymous */
512 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
513 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
514 trace_dump_struct_end(); /* anonymous */
515 trace_dump_member_end(); /* buf */
517 trace_dump_member_begin("tex");
518 trace_dump_struct_begin(""); /* anonymous */
519 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
520 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
521 trace_dump_member(uint
, &state
->u
.tex
, first_level
);
522 trace_dump_member(uint
, &state
->u
.tex
, last_level
);
523 trace_dump_struct_end(); /* anonymous */
524 trace_dump_member_end(); /* tex */
526 trace_dump_struct_end(); /* anonymous */
527 trace_dump_member_end(); /* u */
529 trace_dump_member(uint
, state
, swizzle_r
);
530 trace_dump_member(uint
, state
, swizzle_g
);
531 trace_dump_member(uint
, state
, swizzle_b
);
532 trace_dump_member(uint
, state
, swizzle_a
);
534 trace_dump_struct_end();
538 void trace_dump_surface_template(const struct pipe_surface
*state
,
539 enum pipe_texture_target target
)
541 if (!trace_dumping_enabled_locked())
549 trace_dump_struct_begin("pipe_surface");
551 trace_dump_member(format
, state
, format
);
552 trace_dump_member(uint
, state
, width
);
553 trace_dump_member(uint
, state
, height
);
555 trace_dump_member_begin("u");
556 trace_dump_struct_begin(""); /* anonymous */
557 if (target
== PIPE_BUFFER
) {
558 trace_dump_member_begin("buf");
559 trace_dump_struct_begin(""); /* anonymous */
560 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
561 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
562 trace_dump_struct_end(); /* anonymous */
563 trace_dump_member_end(); /* buf */
565 trace_dump_member_begin("tex");
566 trace_dump_struct_begin(""); /* anonymous */
567 trace_dump_member(uint
, &state
->u
.tex
, level
);
568 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
569 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
570 trace_dump_struct_end(); /* anonymous */
571 trace_dump_member_end(); /* tex */
573 trace_dump_struct_end(); /* anonymous */
574 trace_dump_member_end(); /* u */
576 trace_dump_struct_end();
580 void trace_dump_transfer(const struct pipe_transfer
*state
)
582 if (!trace_dumping_enabled_locked())
590 trace_dump_struct_begin("pipe_transfer");
592 trace_dump_member(uint
, state
, box
.x
);
593 trace_dump_member(uint
, state
, box
.y
);
594 trace_dump_member(uint
, state
, box
.z
);
595 trace_dump_member(uint
, state
, box
.width
);
596 trace_dump_member(uint
, state
, box
.height
);
597 trace_dump_member(uint
, state
, box
.depth
);
599 trace_dump_member(uint
, state
, stride
);
600 trace_dump_member(uint
, state
, layer_stride
);
601 trace_dump_member(uint
, state
, usage
);
603 trace_dump_member(ptr
, state
, resource
);
605 trace_dump_struct_end();
609 void trace_dump_vertex_buffer(const struct pipe_vertex_buffer
*state
)
611 if (!trace_dumping_enabled_locked())
619 trace_dump_struct_begin("pipe_vertex_buffer");
621 trace_dump_member(uint
, state
, stride
);
622 trace_dump_member(uint
, state
, buffer_offset
);
623 trace_dump_member(resource_ptr
, state
, buffer
);
624 trace_dump_member(ptr
, state
, user_buffer
);
626 trace_dump_struct_end();
630 void trace_dump_index_buffer(const struct pipe_index_buffer
*state
)
632 if (!trace_dumping_enabled_locked())
640 trace_dump_struct_begin("pipe_index_buffer");
642 trace_dump_member(uint
, state
, index_size
);
643 trace_dump_member(uint
, state
, offset
);
644 trace_dump_member(resource_ptr
, state
, buffer
);
645 trace_dump_member(ptr
, state
, user_buffer
);
647 trace_dump_struct_end();
651 void trace_dump_vertex_element(const struct pipe_vertex_element
*state
)
653 if (!trace_dumping_enabled_locked())
661 trace_dump_struct_begin("pipe_vertex_element");
663 trace_dump_member(uint
, state
, src_offset
);
665 trace_dump_member(uint
, state
, vertex_buffer_index
);
667 trace_dump_member(format
, state
, src_format
);
669 trace_dump_struct_end();
673 void trace_dump_constant_buffer(const struct pipe_constant_buffer
*state
)
675 if (!trace_dumping_enabled_locked())
683 trace_dump_struct_begin("pipe_constant_buffer");
684 trace_dump_member(ptr
, state
, buffer
);
685 trace_dump_member(uint
, state
, buffer_offset
);
686 trace_dump_member(uint
, state
, buffer_size
);
687 trace_dump_struct_end();
691 void trace_dump_draw_info(const struct pipe_draw_info
*state
)
693 if (!trace_dumping_enabled_locked())
701 trace_dump_struct_begin("pipe_draw_info");
703 trace_dump_member(bool, state
, indexed
);
705 trace_dump_member(uint
, state
, mode
);
706 trace_dump_member(uint
, state
, start
);
707 trace_dump_member(uint
, state
, count
);
709 trace_dump_member(uint
, state
, start_instance
);
710 trace_dump_member(uint
, state
, instance_count
);
712 trace_dump_member(uint
, state
, vertices_per_patch
);
714 trace_dump_member(int, state
, index_bias
);
715 trace_dump_member(uint
, state
, min_index
);
716 trace_dump_member(uint
, state
, max_index
);
718 trace_dump_member(bool, state
, primitive_restart
);
719 trace_dump_member(uint
, state
, restart_index
);
721 trace_dump_member(ptr
, state
, count_from_stream_output
);
723 trace_dump_member(ptr
, state
, indirect
);
724 trace_dump_member(uint
, state
, indirect_offset
);
726 trace_dump_struct_end();
729 void trace_dump_blit_info(const struct pipe_blit_info
*info
)
733 if (!trace_dumping_enabled_locked())
741 trace_dump_struct_begin("pipe_blit_info");
743 trace_dump_member_begin("dst");
744 trace_dump_struct_begin("dst");
745 trace_dump_member(resource_ptr
, &info
->dst
, resource
);
746 trace_dump_member(uint
, &info
->dst
, level
);
747 trace_dump_member(format
, &info
->dst
, format
);
748 trace_dump_member_begin("box");
749 trace_dump_box(&info
->dst
.box
);
750 trace_dump_member_end();
751 trace_dump_struct_end();
752 trace_dump_member_end();
754 trace_dump_member_begin("src");
755 trace_dump_struct_begin("src");
756 trace_dump_member(resource_ptr
, &info
->src
, resource
);
757 trace_dump_member(uint
, &info
->src
, level
);
758 trace_dump_member(format
, &info
->src
, format
);
759 trace_dump_member_begin("box");
760 trace_dump_box(&info
->src
.box
);
761 trace_dump_member_end();
762 trace_dump_struct_end();
763 trace_dump_member_end();
765 mask
[0] = (info
->mask
& PIPE_MASK_R
) ? 'R' : '-';
766 mask
[1] = (info
->mask
& PIPE_MASK_G
) ? 'G' : '-';
767 mask
[2] = (info
->mask
& PIPE_MASK_B
) ? 'B' : '-';
768 mask
[3] = (info
->mask
& PIPE_MASK_A
) ? 'A' : '-';
769 mask
[4] = (info
->mask
& PIPE_MASK_Z
) ? 'Z' : '-';
770 mask
[5] = (info
->mask
& PIPE_MASK_S
) ? 'S' : '-';
773 trace_dump_member_begin("mask");
774 trace_dump_string(mask
);
775 trace_dump_member_end();
776 trace_dump_member(uint
, info
, filter
);
778 trace_dump_member(bool, info
, scissor_enable
);
779 trace_dump_member_begin("scissor");
780 trace_dump_scissor_state(&info
->scissor
);
781 trace_dump_member_end();
783 trace_dump_struct_end();
787 trace_dump_query_result(unsigned query_type
,
788 const union pipe_query_result
*result
)
790 if (!trace_dumping_enabled_locked())
798 switch (query_type
) {
799 case PIPE_QUERY_OCCLUSION_PREDICATE
:
800 case PIPE_QUERY_SO_OVERFLOW_PREDICATE
:
801 case PIPE_QUERY_GPU_FINISHED
:
802 trace_dump_bool(result
->b
);
805 case PIPE_QUERY_OCCLUSION_COUNTER
:
806 case PIPE_QUERY_TIMESTAMP
:
807 case PIPE_QUERY_TIME_ELAPSED
:
808 case PIPE_QUERY_PRIMITIVES_GENERATED
:
809 case PIPE_QUERY_PRIMITIVES_EMITTED
:
810 trace_dump_uint(result
->u64
);
813 case PIPE_QUERY_SO_STATISTICS
:
814 trace_dump_struct_begin("pipe_query_data_so_statistics");
815 trace_dump_member(uint
, &result
->so_statistics
, num_primitives_written
);
816 trace_dump_member(uint
, &result
->so_statistics
, primitives_storage_needed
);
817 trace_dump_struct_end();
820 case PIPE_QUERY_TIMESTAMP_DISJOINT
:
821 trace_dump_struct_begin("pipe_query_data_timestamp_disjoint");
822 trace_dump_member(uint
, &result
->timestamp_disjoint
, frequency
);
823 trace_dump_member(bool, &result
->timestamp_disjoint
, disjoint
);
824 trace_dump_struct_end();
827 case PIPE_QUERY_PIPELINE_STATISTICS
:
828 trace_dump_struct_begin("pipe_query_data_pipeline_statistics");
829 trace_dump_member(uint
, &result
->pipeline_statistics
, ia_vertices
);
830 trace_dump_member(uint
, &result
->pipeline_statistics
, ia_primitives
);
831 trace_dump_member(uint
, &result
->pipeline_statistics
, vs_invocations
);
832 trace_dump_member(uint
, &result
->pipeline_statistics
, gs_invocations
);
833 trace_dump_member(uint
, &result
->pipeline_statistics
, gs_primitives
);
834 trace_dump_member(uint
, &result
->pipeline_statistics
, c_invocations
);
835 trace_dump_member(uint
, &result
->pipeline_statistics
, c_primitives
);
836 trace_dump_member(uint
, &result
->pipeline_statistics
, ps_invocations
);
837 trace_dump_member(uint
, &result
->pipeline_statistics
, hs_invocations
);
838 trace_dump_member(uint
, &result
->pipeline_statistics
, ds_invocations
);
839 trace_dump_member(uint
, &result
->pipeline_statistics
, cs_invocations
);
840 trace_dump_struct_end();
844 assert(query_type
>= PIPE_QUERY_DRIVER_SPECIFIC
);
845 trace_dump_uint(result
->u64
);