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(bool, state
, seamless_cube_map
);
474 trace_dump_member(float, state
, lod_bias
);
475 trace_dump_member(float, state
, min_lod
);
476 trace_dump_member(float, state
, max_lod
);
477 trace_dump_member_array(float, state
, border_color
.f
);
479 trace_dump_struct_end();
483 void trace_dump_sampler_view_template(const struct pipe_sampler_view
*state
,
484 enum pipe_texture_target target
)
486 if (!trace_dumping_enabled_locked())
494 trace_dump_struct_begin("pipe_sampler_view");
496 trace_dump_member(format
, state
, format
);
498 trace_dump_member_begin("u");
499 trace_dump_struct_begin(""); /* anonymous */
500 if (target
== PIPE_BUFFER
) {
501 trace_dump_member_begin("buf");
502 trace_dump_struct_begin(""); /* anonymous */
503 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
504 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
505 trace_dump_struct_end(); /* anonymous */
506 trace_dump_member_end(); /* buf */
508 trace_dump_member_begin("tex");
509 trace_dump_struct_begin(""); /* anonymous */
510 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
511 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
512 trace_dump_member(uint
, &state
->u
.tex
, first_level
);
513 trace_dump_member(uint
, &state
->u
.tex
, last_level
);
514 trace_dump_struct_end(); /* anonymous */
515 trace_dump_member_end(); /* tex */
517 trace_dump_struct_end(); /* anonymous */
518 trace_dump_member_end(); /* u */
520 trace_dump_member(uint
, state
, swizzle_r
);
521 trace_dump_member(uint
, state
, swizzle_g
);
522 trace_dump_member(uint
, state
, swizzle_b
);
523 trace_dump_member(uint
, state
, swizzle_a
);
525 trace_dump_struct_end();
529 void trace_dump_surface_template(const struct pipe_surface
*state
,
530 enum pipe_texture_target target
)
532 if (!trace_dumping_enabled_locked())
540 trace_dump_struct_begin("pipe_surface");
542 trace_dump_member(format
, state
, format
);
543 trace_dump_member(uint
, state
, width
);
544 trace_dump_member(uint
, state
, height
);
546 trace_dump_member_begin("u");
547 trace_dump_struct_begin(""); /* anonymous */
548 if (target
== PIPE_BUFFER
) {
549 trace_dump_member_begin("buf");
550 trace_dump_struct_begin(""); /* anonymous */
551 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
552 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
553 trace_dump_struct_end(); /* anonymous */
554 trace_dump_member_end(); /* buf */
556 trace_dump_member_begin("tex");
557 trace_dump_struct_begin(""); /* anonymous */
558 trace_dump_member(uint
, &state
->u
.tex
, level
);
559 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
560 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
561 trace_dump_struct_end(); /* anonymous */
562 trace_dump_member_end(); /* tex */
564 trace_dump_struct_end(); /* anonymous */
565 trace_dump_member_end(); /* u */
567 trace_dump_struct_end();
571 void trace_dump_transfer(const struct pipe_transfer
*state
)
573 if (!trace_dumping_enabled_locked())
581 trace_dump_struct_begin("pipe_transfer");
583 trace_dump_member(uint
, state
, box
.x
);
584 trace_dump_member(uint
, state
, box
.y
);
585 trace_dump_member(uint
, state
, box
.z
);
586 trace_dump_member(uint
, state
, box
.width
);
587 trace_dump_member(uint
, state
, box
.height
);
588 trace_dump_member(uint
, state
, box
.depth
);
590 trace_dump_member(uint
, state
, stride
);
591 trace_dump_member(uint
, state
, layer_stride
);
592 trace_dump_member(uint
, state
, usage
);
594 trace_dump_member(ptr
, state
, resource
);
596 trace_dump_struct_end();
600 void trace_dump_vertex_buffer(const struct pipe_vertex_buffer
*state
)
602 if (!trace_dumping_enabled_locked())
610 trace_dump_struct_begin("pipe_vertex_buffer");
612 trace_dump_member(uint
, state
, stride
);
613 trace_dump_member(uint
, state
, buffer_offset
);
614 trace_dump_member(resource_ptr
, state
, buffer
);
615 trace_dump_member(ptr
, state
, user_buffer
);
617 trace_dump_struct_end();
621 void trace_dump_index_buffer(const struct pipe_index_buffer
*state
)
623 if (!trace_dumping_enabled_locked())
631 trace_dump_struct_begin("pipe_index_buffer");
633 trace_dump_member(uint
, state
, index_size
);
634 trace_dump_member(uint
, state
, offset
);
635 trace_dump_member(resource_ptr
, state
, buffer
);
636 trace_dump_member(ptr
, state
, user_buffer
);
638 trace_dump_struct_end();
642 void trace_dump_vertex_element(const struct pipe_vertex_element
*state
)
644 if (!trace_dumping_enabled_locked())
652 trace_dump_struct_begin("pipe_vertex_element");
654 trace_dump_member(uint
, state
, src_offset
);
656 trace_dump_member(uint
, state
, vertex_buffer_index
);
658 trace_dump_member(format
, state
, src_format
);
660 trace_dump_struct_end();
664 void trace_dump_constant_buffer(const struct pipe_constant_buffer
*state
)
666 if (!trace_dumping_enabled_locked())
674 trace_dump_struct_begin("pipe_constant_buffer");
675 trace_dump_member(ptr
, state
, buffer
);
676 trace_dump_member(uint
, state
, buffer_offset
);
677 trace_dump_member(uint
, state
, buffer_size
);
678 trace_dump_struct_end();
682 void trace_dump_draw_info(const struct pipe_draw_info
*state
)
684 if (!trace_dumping_enabled_locked())
692 trace_dump_struct_begin("pipe_draw_info");
694 trace_dump_member(bool, state
, indexed
);
696 trace_dump_member(uint
, state
, mode
);
697 trace_dump_member(uint
, state
, start
);
698 trace_dump_member(uint
, state
, count
);
700 trace_dump_member(uint
, state
, start_instance
);
701 trace_dump_member(uint
, state
, instance_count
);
703 trace_dump_member(int, state
, index_bias
);
704 trace_dump_member(uint
, state
, min_index
);
705 trace_dump_member(uint
, state
, max_index
);
707 trace_dump_member(bool, state
, primitive_restart
);
708 trace_dump_member(uint
, state
, restart_index
);
710 trace_dump_member(ptr
, state
, count_from_stream_output
);
712 trace_dump_struct_end();
715 void trace_dump_blit_info(const struct pipe_blit_info
*info
)
719 if (!trace_dumping_enabled_locked())
727 trace_dump_struct_begin("pipe_blit_info");
729 trace_dump_member_begin("dst");
730 trace_dump_struct_begin("dst");
731 trace_dump_member(resource_ptr
, &info
->dst
, resource
);
732 trace_dump_member(uint
, &info
->dst
, level
);
733 trace_dump_member(format
, &info
->dst
, format
);
734 trace_dump_member_begin("box");
735 trace_dump_box(&info
->dst
.box
);
736 trace_dump_member_end();
737 trace_dump_struct_end();
738 trace_dump_member_end();
740 trace_dump_member_begin("src");
741 trace_dump_struct_begin("src");
742 trace_dump_member(resource_ptr
, &info
->src
, resource
);
743 trace_dump_member(uint
, &info
->src
, level
);
744 trace_dump_member(format
, &info
->src
, format
);
745 trace_dump_member_begin("box");
746 trace_dump_box(&info
->src
.box
);
747 trace_dump_member_end();
748 trace_dump_struct_end();
749 trace_dump_member_end();
751 mask
[0] = (info
->mask
& PIPE_MASK_R
) ? 'R' : '-';
752 mask
[1] = (info
->mask
& PIPE_MASK_G
) ? 'G' : '-';
753 mask
[2] = (info
->mask
& PIPE_MASK_B
) ? 'B' : '-';
754 mask
[3] = (info
->mask
& PIPE_MASK_A
) ? 'A' : '-';
755 mask
[4] = (info
->mask
& PIPE_MASK_Z
) ? 'Z' : '-';
756 mask
[5] = (info
->mask
& PIPE_MASK_S
) ? 'S' : '-';
759 trace_dump_member_begin("mask");
760 trace_dump_string(mask
);
761 trace_dump_member_end();
762 trace_dump_member(uint
, info
, filter
);
764 trace_dump_member(bool, info
, scissor_enable
);
765 trace_dump_member_begin("scissor");
766 trace_dump_scissor_state(&info
->scissor
);
767 trace_dump_member_end();
769 trace_dump_struct_end();
773 trace_dump_query_result(unsigned query_type
,
774 const union pipe_query_result
*result
)
776 if (!trace_dumping_enabled_locked())
784 switch (query_type
) {
785 case PIPE_QUERY_OCCLUSION_PREDICATE
:
786 case PIPE_QUERY_SO_OVERFLOW_PREDICATE
:
787 case PIPE_QUERY_GPU_FINISHED
:
788 trace_dump_bool(result
->b
);
791 case PIPE_QUERY_OCCLUSION_COUNTER
:
792 case PIPE_QUERY_TIMESTAMP
:
793 case PIPE_QUERY_TIME_ELAPSED
:
794 case PIPE_QUERY_PRIMITIVES_GENERATED
:
795 case PIPE_QUERY_PRIMITIVES_EMITTED
:
796 trace_dump_uint(result
->u64
);
799 case PIPE_QUERY_SO_STATISTICS
:
800 trace_dump_struct_begin("pipe_query_data_so_statistics");
801 trace_dump_member(uint
, &result
->so_statistics
, num_primitives_written
);
802 trace_dump_member(uint
, &result
->so_statistics
, primitives_storage_needed
);
803 trace_dump_struct_end();
806 case PIPE_QUERY_TIMESTAMP_DISJOINT
:
807 trace_dump_struct_begin("pipe_query_data_timestamp_disjoint");
808 trace_dump_member(uint
, &result
->timestamp_disjoint
, frequency
);
809 trace_dump_member(bool, &result
->timestamp_disjoint
, disjoint
);
810 trace_dump_struct_end();
813 case PIPE_QUERY_PIPELINE_STATISTICS
:
814 trace_dump_struct_begin("pipe_query_data_pipeline_statistics");
815 trace_dump_member(uint
, &result
->pipeline_statistics
, ia_vertices
);
816 trace_dump_member(uint
, &result
->pipeline_statistics
, ia_primitives
);
817 trace_dump_member(uint
, &result
->pipeline_statistics
, vs_invocations
);
818 trace_dump_member(uint
, &result
->pipeline_statistics
, gs_invocations
);
819 trace_dump_member(uint
, &result
->pipeline_statistics
, gs_primitives
);
820 trace_dump_member(uint
, &result
->pipeline_statistics
, c_invocations
);
821 trace_dump_member(uint
, &result
->pipeline_statistics
, c_primitives
);
822 trace_dump_member(uint
, &result
->pipeline_statistics
, ps_invocations
);
823 trace_dump_member(uint
, &result
->pipeline_statistics
, hs_invocations
);
824 trace_dump_member(uint
, &result
->pipeline_statistics
, ds_invocations
);
825 trace_dump_member(uint
, &result
->pipeline_statistics
, cs_invocations
);
826 trace_dump_struct_end();
830 assert(query_type
>= PIPE_QUERY_DRIVER_SPECIFIC
);
831 trace_dump_uint(result
->u64
);