1 /**************************************************************************
3 * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
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 TUNGSTEN GRAPHICS 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(uint
, state
, sprite_coord_enable
);
131 trace_dump_member(bool, state
, sprite_coord_mode
);
132 trace_dump_member(bool, state
, point_quad_rasterization
);
133 trace_dump_member(bool, state
, point_size_per_vertex
);
134 trace_dump_member(bool, state
, multisample
);
135 trace_dump_member(bool, state
, line_smooth
);
136 trace_dump_member(bool, state
, line_stipple_enable
);
137 trace_dump_member(uint
, state
, line_stipple_factor
);
138 trace_dump_member(uint
, state
, line_stipple_pattern
);
139 trace_dump_member(bool, state
, line_last_pixel
);
140 trace_dump_member(bool, state
, flatshade_first
);
141 trace_dump_member(bool, state
, half_pixel_center
);
142 trace_dump_member(bool, state
, bottom_edge_rule
);
143 trace_dump_member(bool, state
, rasterizer_discard
);
144 trace_dump_member(bool, state
, depth_clip
);
145 trace_dump_member(bool, state
, clip_halfz
);
146 trace_dump_member(uint
, state
, clip_plane_enable
);
148 trace_dump_member(float, state
, line_width
);
149 trace_dump_member(float, state
, point_size
);
150 trace_dump_member(float, state
, offset_units
);
151 trace_dump_member(float, state
, offset_scale
);
152 trace_dump_member(float, state
, offset_clamp
);
154 trace_dump_struct_end();
158 void trace_dump_poly_stipple(const struct pipe_poly_stipple
*state
)
160 if (!trace_dumping_enabled_locked())
168 trace_dump_struct_begin("pipe_poly_stipple");
170 trace_dump_member_begin("stipple");
171 trace_dump_array(uint
,
173 Elements(state
->stipple
));
174 trace_dump_member_end();
176 trace_dump_struct_end();
180 void trace_dump_viewport_state(const struct pipe_viewport_state
*state
)
182 if (!trace_dumping_enabled_locked())
190 trace_dump_struct_begin("pipe_viewport_state");
192 trace_dump_member_array(float, state
, scale
);
193 trace_dump_member_array(float, state
, translate
);
195 trace_dump_struct_end();
199 void trace_dump_scissor_state(const struct pipe_scissor_state
*state
)
201 if (!trace_dumping_enabled_locked())
209 trace_dump_struct_begin("pipe_scissor_state");
211 trace_dump_member(uint
, state
, minx
);
212 trace_dump_member(uint
, state
, miny
);
213 trace_dump_member(uint
, state
, maxx
);
214 trace_dump_member(uint
, state
, maxy
);
216 trace_dump_struct_end();
220 void trace_dump_clip_state(const struct pipe_clip_state
*state
)
224 if (!trace_dumping_enabled_locked())
232 trace_dump_struct_begin("pipe_clip_state");
234 trace_dump_member_begin("ucp");
235 trace_dump_array_begin();
236 for(i
= 0; i
< PIPE_MAX_CLIP_PLANES
; ++i
) {
237 trace_dump_elem_begin();
238 trace_dump_array(float, state
->ucp
[i
], 4);
239 trace_dump_elem_end();
241 trace_dump_array_end();
242 trace_dump_member_end();
244 trace_dump_struct_end();
248 void trace_dump_shader_state(const struct pipe_shader_state
*state
)
252 if (!trace_dumping_enabled_locked())
261 trace_dump_struct_begin("pipe_shader_state");
263 trace_dump_member_begin("tokens");
265 static char str
[64 * 1024];
266 tgsi_dump_str(state
->tokens
, 0, str
, sizeof(str
));
267 trace_dump_string(str
);
271 trace_dump_member_end();
273 trace_dump_member_begin("stream_output");
274 trace_dump_struct_begin("pipe_stream_output_info");
275 trace_dump_member(uint
, &state
->stream_output
, num_outputs
);
276 trace_dump_member_array(uint
, &state
->stream_output
, stride
);
277 trace_dump_member_begin("output");
278 trace_dump_array_begin();
279 for(i
= 0; i
< state
->stream_output
.num_outputs
; ++i
) {
280 trace_dump_elem_begin();
281 trace_dump_struct_begin(""); /* anonymous */
282 trace_dump_member(uint
, &state
->stream_output
.output
[i
], register_index
);
283 trace_dump_member(uint
, &state
->stream_output
.output
[i
], start_component
);
284 trace_dump_member(uint
, &state
->stream_output
.output
[i
], num_components
);
285 trace_dump_member(uint
, &state
->stream_output
.output
[i
], output_buffer
);
286 trace_dump_member(uint
, &state
->stream_output
.output
[i
], dst_offset
);
287 trace_dump_struct_end();
288 trace_dump_elem_end();
290 trace_dump_array_end();
291 trace_dump_member_end(); // output
292 trace_dump_struct_end();
293 trace_dump_member_end(); // stream_output
295 trace_dump_struct_end();
299 void trace_dump_depth_stencil_alpha_state(const struct pipe_depth_stencil_alpha_state
*state
)
303 if (!trace_dumping_enabled_locked())
311 trace_dump_struct_begin("pipe_depth_stencil_alpha_state");
313 trace_dump_member_begin("depth");
314 trace_dump_struct_begin("pipe_depth_state");
315 trace_dump_member(bool, &state
->depth
, enabled
);
316 trace_dump_member(bool, &state
->depth
, writemask
);
317 trace_dump_member(uint
, &state
->depth
, func
);
318 trace_dump_struct_end();
319 trace_dump_member_end();
321 trace_dump_member_begin("stencil");
322 trace_dump_array_begin();
323 for(i
= 0; i
< Elements(state
->stencil
); ++i
) {
324 trace_dump_elem_begin();
325 trace_dump_struct_begin("pipe_stencil_state");
326 trace_dump_member(bool, &state
->stencil
[i
], enabled
);
327 trace_dump_member(uint
, &state
->stencil
[i
], func
);
328 trace_dump_member(uint
, &state
->stencil
[i
], fail_op
);
329 trace_dump_member(uint
, &state
->stencil
[i
], zpass_op
);
330 trace_dump_member(uint
, &state
->stencil
[i
], zfail_op
);
331 trace_dump_member(uint
, &state
->stencil
[i
], valuemask
);
332 trace_dump_member(uint
, &state
->stencil
[i
], writemask
);
333 trace_dump_struct_end();
334 trace_dump_elem_end();
336 trace_dump_array_end();
337 trace_dump_member_end();
339 trace_dump_member_begin("alpha");
340 trace_dump_struct_begin("pipe_alpha_state");
341 trace_dump_member(bool, &state
->alpha
, enabled
);
342 trace_dump_member(uint
, &state
->alpha
, func
);
343 trace_dump_member(float, &state
->alpha
, ref_value
);
344 trace_dump_struct_end();
345 trace_dump_member_end();
347 trace_dump_struct_end();
350 static void trace_dump_rt_blend_state(const struct pipe_rt_blend_state
*state
)
352 trace_dump_struct_begin("pipe_rt_blend_state");
354 trace_dump_member(uint
, state
, blend_enable
);
356 trace_dump_member(uint
, state
, rgb_func
);
357 trace_dump_member(uint
, state
, rgb_src_factor
);
358 trace_dump_member(uint
, state
, rgb_dst_factor
);
360 trace_dump_member(uint
, state
, alpha_func
);
361 trace_dump_member(uint
, state
, alpha_src_factor
);
362 trace_dump_member(uint
, state
, alpha_dst_factor
);
364 trace_dump_member(uint
, state
, colormask
);
366 trace_dump_struct_end();
369 void trace_dump_blend_state(const struct pipe_blend_state
*state
)
371 unsigned valid_entries
= 1;
373 if (!trace_dumping_enabled_locked())
381 trace_dump_struct_begin("pipe_blend_state");
383 trace_dump_member(bool, state
, dither
);
385 trace_dump_member(bool, state
, logicop_enable
);
386 trace_dump_member(uint
, state
, logicop_func
);
388 trace_dump_member(bool, state
, independent_blend_enable
);
390 trace_dump_member_begin("rt");
391 if (state
->independent_blend_enable
)
392 valid_entries
= PIPE_MAX_COLOR_BUFS
;
393 trace_dump_struct_array(rt_blend_state
, state
->rt
, valid_entries
);
394 trace_dump_member_end();
396 trace_dump_struct_end();
400 void trace_dump_blend_color(const struct pipe_blend_color
*state
)
402 if (!trace_dumping_enabled_locked())
410 trace_dump_struct_begin("pipe_blend_color");
412 trace_dump_member_array(float, state
, color
);
414 trace_dump_struct_end();
417 void trace_dump_stencil_ref(const struct pipe_stencil_ref
*state
)
419 if (!trace_dumping_enabled_locked())
427 trace_dump_struct_begin("pipe_stencil_ref");
429 trace_dump_member_array(uint
, state
, ref_value
);
431 trace_dump_struct_end();
434 void trace_dump_framebuffer_state(const struct pipe_framebuffer_state
*state
)
436 if (!trace_dumping_enabled_locked())
439 trace_dump_struct_begin("pipe_framebuffer_state");
441 trace_dump_member(uint
, state
, width
);
442 trace_dump_member(uint
, state
, height
);
443 trace_dump_member(uint
, state
, nr_cbufs
);
444 trace_dump_member_array(ptr
, state
, cbufs
);
445 trace_dump_member(ptr
, state
, zsbuf
);
447 trace_dump_struct_end();
451 void trace_dump_sampler_state(const struct pipe_sampler_state
*state
)
453 if (!trace_dumping_enabled_locked())
461 trace_dump_struct_begin("pipe_sampler_state");
463 trace_dump_member(uint
, state
, wrap_s
);
464 trace_dump_member(uint
, state
, wrap_t
);
465 trace_dump_member(uint
, state
, wrap_r
);
466 trace_dump_member(uint
, state
, min_img_filter
);
467 trace_dump_member(uint
, state
, min_mip_filter
);
468 trace_dump_member(uint
, state
, mag_img_filter
);
469 trace_dump_member(uint
, state
, compare_mode
);
470 trace_dump_member(uint
, state
, compare_func
);
471 trace_dump_member(bool, state
, normalized_coords
);
472 trace_dump_member(uint
, state
, max_anisotropy
);
473 trace_dump_member(float, state
, lod_bias
);
474 trace_dump_member(float, state
, min_lod
);
475 trace_dump_member(float, state
, max_lod
);
476 trace_dump_member_array(float, state
, border_color
.f
);
478 trace_dump_struct_end();
482 void trace_dump_sampler_view_template(const struct pipe_sampler_view
*state
,
483 enum pipe_texture_target target
)
485 if (!trace_dumping_enabled_locked())
493 trace_dump_struct_begin("pipe_sampler_view");
495 trace_dump_member(format
, state
, format
);
497 trace_dump_member_begin("u");
498 trace_dump_struct_begin(""); /* anonymous */
499 if (target
== PIPE_BUFFER
) {
500 trace_dump_member_begin("buf");
501 trace_dump_struct_begin(""); /* anonymous */
502 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
503 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
504 trace_dump_struct_end(); /* anonymous */
505 trace_dump_member_end(); /* buf */
507 trace_dump_member_begin("tex");
508 trace_dump_struct_begin(""); /* anonymous */
509 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
510 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
511 trace_dump_member(uint
, &state
->u
.tex
, first_level
);
512 trace_dump_member(uint
, &state
->u
.tex
, last_level
);
513 trace_dump_struct_end(); /* anonymous */
514 trace_dump_member_end(); /* tex */
516 trace_dump_struct_end(); /* anonymous */
517 trace_dump_member_end(); /* u */
519 trace_dump_member(uint
, state
, swizzle_r
);
520 trace_dump_member(uint
, state
, swizzle_g
);
521 trace_dump_member(uint
, state
, swizzle_b
);
522 trace_dump_member(uint
, state
, swizzle_a
);
524 trace_dump_struct_end();
528 void trace_dump_surface_template(const struct pipe_surface
*state
,
529 enum pipe_texture_target target
)
531 if (!trace_dumping_enabled_locked())
539 trace_dump_struct_begin("pipe_surface");
541 trace_dump_member(format
, state
, format
);
542 trace_dump_member(uint
, state
, width
);
543 trace_dump_member(uint
, state
, height
);
545 trace_dump_member_begin("u");
546 trace_dump_struct_begin(""); /* anonymous */
547 if (target
== PIPE_BUFFER
) {
548 trace_dump_member_begin("buf");
549 trace_dump_struct_begin(""); /* anonymous */
550 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
551 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
552 trace_dump_struct_end(); /* anonymous */
553 trace_dump_member_end(); /* buf */
555 trace_dump_member_begin("tex");
556 trace_dump_struct_begin(""); /* anonymous */
557 trace_dump_member(uint
, &state
->u
.tex
, level
);
558 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
559 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
560 trace_dump_struct_end(); /* anonymous */
561 trace_dump_member_end(); /* tex */
563 trace_dump_struct_end(); /* anonymous */
564 trace_dump_member_end(); /* u */
566 trace_dump_struct_end();
570 void trace_dump_transfer(const struct pipe_transfer
*state
)
572 if (!trace_dumping_enabled_locked())
580 trace_dump_struct_begin("pipe_transfer");
582 trace_dump_member(uint
, state
, box
.x
);
583 trace_dump_member(uint
, state
, box
.y
);
584 trace_dump_member(uint
, state
, box
.z
);
585 trace_dump_member(uint
, state
, box
.width
);
586 trace_dump_member(uint
, state
, box
.height
);
587 trace_dump_member(uint
, state
, box
.depth
);
589 trace_dump_member(uint
, state
, stride
);
590 trace_dump_member(uint
, state
, layer_stride
);
591 trace_dump_member(uint
, state
, usage
);
593 trace_dump_member(ptr
, state
, resource
);
595 trace_dump_struct_end();
599 void trace_dump_vertex_buffer(const struct pipe_vertex_buffer
*state
)
601 if (!trace_dumping_enabled_locked())
609 trace_dump_struct_begin("pipe_vertex_buffer");
611 trace_dump_member(uint
, state
, stride
);
612 trace_dump_member(uint
, state
, buffer_offset
);
613 trace_dump_member(resource_ptr
, state
, buffer
);
614 trace_dump_member(ptr
, state
, user_buffer
);
616 trace_dump_struct_end();
620 void trace_dump_index_buffer(const struct pipe_index_buffer
*state
)
622 if (!trace_dumping_enabled_locked())
630 trace_dump_struct_begin("pipe_index_buffer");
632 trace_dump_member(uint
, state
, index_size
);
633 trace_dump_member(uint
, state
, offset
);
634 trace_dump_member(resource_ptr
, state
, buffer
);
635 trace_dump_member(ptr
, state
, user_buffer
);
637 trace_dump_struct_end();
641 void trace_dump_vertex_element(const struct pipe_vertex_element
*state
)
643 if (!trace_dumping_enabled_locked())
651 trace_dump_struct_begin("pipe_vertex_element");
653 trace_dump_member(uint
, state
, src_offset
);
655 trace_dump_member(uint
, state
, vertex_buffer_index
);
657 trace_dump_member(format
, state
, src_format
);
659 trace_dump_struct_end();
663 void trace_dump_constant_buffer(const struct pipe_constant_buffer
*state
)
665 if (!trace_dumping_enabled_locked())
673 trace_dump_struct_begin("pipe_constant_buffer");
674 trace_dump_member(ptr
, state
, buffer
);
675 trace_dump_member(uint
, state
, buffer_offset
);
676 trace_dump_member(uint
, state
, buffer_size
);
677 trace_dump_struct_end();
681 void trace_dump_draw_info(const struct pipe_draw_info
*state
)
683 if (!trace_dumping_enabled_locked())
691 trace_dump_struct_begin("pipe_draw_info");
693 trace_dump_member(bool, state
, indexed
);
695 trace_dump_member(uint
, state
, mode
);
696 trace_dump_member(uint
, state
, start
);
697 trace_dump_member(uint
, state
, count
);
699 trace_dump_member(uint
, state
, start_instance
);
700 trace_dump_member(uint
, state
, instance_count
);
702 trace_dump_member(int, state
, index_bias
);
703 trace_dump_member(uint
, state
, min_index
);
704 trace_dump_member(uint
, state
, max_index
);
706 trace_dump_member(bool, state
, primitive_restart
);
707 trace_dump_member(uint
, state
, restart_index
);
709 trace_dump_member(ptr
, state
, count_from_stream_output
);
711 trace_dump_struct_end();
714 void trace_dump_blit_info(const struct pipe_blit_info
*info
)
718 if (!trace_dumping_enabled_locked())
726 trace_dump_struct_begin("pipe_blit_info");
728 trace_dump_member_begin("dst");
729 trace_dump_struct_begin("dst");
730 trace_dump_member(resource_ptr
, &info
->dst
, resource
);
731 trace_dump_member(uint
, &info
->dst
, level
);
732 trace_dump_member(format
, &info
->dst
, format
);
733 trace_dump_member_begin("box");
734 trace_dump_box(&info
->dst
.box
);
735 trace_dump_member_end();
736 trace_dump_struct_end();
737 trace_dump_member_end();
739 trace_dump_member_begin("src");
740 trace_dump_struct_begin("src");
741 trace_dump_member(resource_ptr
, &info
->src
, resource
);
742 trace_dump_member(uint
, &info
->src
, level
);
743 trace_dump_member(format
, &info
->src
, format
);
744 trace_dump_member_begin("box");
745 trace_dump_box(&info
->src
.box
);
746 trace_dump_member_end();
747 trace_dump_struct_end();
748 trace_dump_member_end();
750 mask
[0] = (info
->mask
& PIPE_MASK_R
) ? 'R' : '-';
751 mask
[1] = (info
->mask
& PIPE_MASK_G
) ? 'G' : '-';
752 mask
[2] = (info
->mask
& PIPE_MASK_B
) ? 'B' : '-';
753 mask
[3] = (info
->mask
& PIPE_MASK_A
) ? 'A' : '-';
754 mask
[4] = (info
->mask
& PIPE_MASK_Z
) ? 'Z' : '-';
755 mask
[5] = (info
->mask
& PIPE_MASK_S
) ? 'S' : '-';
758 trace_dump_member_begin("mask");
759 trace_dump_string(mask
);
760 trace_dump_member_end();
761 trace_dump_member(uint
, info
, filter
);
763 trace_dump_member(bool, info
, scissor_enable
);
764 trace_dump_member_begin("scissor");
765 trace_dump_scissor_state(&info
->scissor
);
766 trace_dump_member_end();
768 trace_dump_struct_end();
772 trace_dump_query_result(unsigned query_type
,
773 const union pipe_query_result
*result
)
775 if (!trace_dumping_enabled_locked())
783 switch (query_type
) {
784 case PIPE_QUERY_OCCLUSION_PREDICATE
:
785 case PIPE_QUERY_SO_OVERFLOW_PREDICATE
:
786 case PIPE_QUERY_GPU_FINISHED
:
787 trace_dump_bool(result
->b
);
790 case PIPE_QUERY_OCCLUSION_COUNTER
:
791 case PIPE_QUERY_TIMESTAMP
:
792 case PIPE_QUERY_TIME_ELAPSED
:
793 case PIPE_QUERY_PRIMITIVES_GENERATED
:
794 case PIPE_QUERY_PRIMITIVES_EMITTED
:
795 trace_dump_uint(result
->u64
);
798 case PIPE_QUERY_SO_STATISTICS
:
799 trace_dump_struct_begin("pipe_query_data_so_statistics");
800 trace_dump_member(uint
, &result
->so_statistics
, num_primitives_written
);
801 trace_dump_member(uint
, &result
->so_statistics
, primitives_storage_needed
);
802 trace_dump_struct_end();
805 case PIPE_QUERY_TIMESTAMP_DISJOINT
:
806 trace_dump_struct_begin("pipe_query_data_timestamp_disjoint");
807 trace_dump_member(uint
, &result
->timestamp_disjoint
, frequency
);
808 trace_dump_member(bool, &result
->timestamp_disjoint
, disjoint
);
809 trace_dump_struct_end();
812 case PIPE_QUERY_PIPELINE_STATISTICS
:
813 trace_dump_struct_begin("pipe_query_data_pipeline_statistics");
814 trace_dump_member(uint
, &result
->pipeline_statistics
, ia_vertices
);
815 trace_dump_member(uint
, &result
->pipeline_statistics
, ia_primitives
);
816 trace_dump_member(uint
, &result
->pipeline_statistics
, vs_invocations
);
817 trace_dump_member(uint
, &result
->pipeline_statistics
, gs_invocations
);
818 trace_dump_member(uint
, &result
->pipeline_statistics
, gs_primitives
);
819 trace_dump_member(uint
, &result
->pipeline_statistics
, c_invocations
);
820 trace_dump_member(uint
, &result
->pipeline_statistics
, c_primitives
);
821 trace_dump_member(uint
, &result
->pipeline_statistics
, ps_invocations
);
822 trace_dump_member(uint
, &result
->pipeline_statistics
, hs_invocations
);
823 trace_dump_member(uint
, &result
->pipeline_statistics
, ds_invocations
);
824 trace_dump_member(uint
, &result
->pipeline_statistics
, cs_invocations
);
825 trace_dump_struct_end();
829 assert(query_type
>= PIPE_QUERY_DRIVER_SPECIFIC
);
830 trace_dump_uint(result
->u64
);