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 ARRAY_SIZE(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_compute_state(const struct pipe_compute_state
*state
)
310 if (!trace_dumping_enabled_locked())
318 trace_dump_struct_begin("pipe_compute_state");
320 trace_dump_member(uint
, state
, ir_type
);
322 trace_dump_member_begin("prog");
323 if (state
->prog
&& state
->ir_type
== PIPE_SHADER_IR_TGSI
) {
324 static char str
[64 * 1024];
325 tgsi_dump_str(state
->prog
, 0, str
, sizeof(str
));
326 trace_dump_string(str
);
330 trace_dump_member_end();
332 trace_dump_member(uint
, state
, req_local_mem
);
333 trace_dump_member(uint
, state
, req_private_mem
);
334 trace_dump_member(uint
, state
, req_input_mem
);
336 trace_dump_struct_end();
340 void trace_dump_depth_stencil_alpha_state(const struct pipe_depth_stencil_alpha_state
*state
)
344 if (!trace_dumping_enabled_locked())
352 trace_dump_struct_begin("pipe_depth_stencil_alpha_state");
354 trace_dump_member_begin("depth");
355 trace_dump_struct_begin("pipe_depth_state");
356 trace_dump_member(bool, &state
->depth
, enabled
);
357 trace_dump_member(bool, &state
->depth
, writemask
);
358 trace_dump_member(uint
, &state
->depth
, func
);
359 trace_dump_struct_end();
360 trace_dump_member_end();
362 trace_dump_member_begin("stencil");
363 trace_dump_array_begin();
364 for(i
= 0; i
< ARRAY_SIZE(state
->stencil
); ++i
) {
365 trace_dump_elem_begin();
366 trace_dump_struct_begin("pipe_stencil_state");
367 trace_dump_member(bool, &state
->stencil
[i
], enabled
);
368 trace_dump_member(uint
, &state
->stencil
[i
], func
);
369 trace_dump_member(uint
, &state
->stencil
[i
], fail_op
);
370 trace_dump_member(uint
, &state
->stencil
[i
], zpass_op
);
371 trace_dump_member(uint
, &state
->stencil
[i
], zfail_op
);
372 trace_dump_member(uint
, &state
->stencil
[i
], valuemask
);
373 trace_dump_member(uint
, &state
->stencil
[i
], writemask
);
374 trace_dump_struct_end();
375 trace_dump_elem_end();
377 trace_dump_array_end();
378 trace_dump_member_end();
380 trace_dump_member_begin("alpha");
381 trace_dump_struct_begin("pipe_alpha_state");
382 trace_dump_member(bool, &state
->alpha
, enabled
);
383 trace_dump_member(uint
, &state
->alpha
, func
);
384 trace_dump_member(float, &state
->alpha
, ref_value
);
385 trace_dump_struct_end();
386 trace_dump_member_end();
388 trace_dump_struct_end();
391 static void trace_dump_rt_blend_state(const struct pipe_rt_blend_state
*state
)
393 trace_dump_struct_begin("pipe_rt_blend_state");
395 trace_dump_member(uint
, state
, blend_enable
);
397 trace_dump_member(uint
, state
, rgb_func
);
398 trace_dump_member(uint
, state
, rgb_src_factor
);
399 trace_dump_member(uint
, state
, rgb_dst_factor
);
401 trace_dump_member(uint
, state
, alpha_func
);
402 trace_dump_member(uint
, state
, alpha_src_factor
);
403 trace_dump_member(uint
, state
, alpha_dst_factor
);
405 trace_dump_member(uint
, state
, colormask
);
407 trace_dump_struct_end();
410 void trace_dump_blend_state(const struct pipe_blend_state
*state
)
412 unsigned valid_entries
= 1;
414 if (!trace_dumping_enabled_locked())
422 trace_dump_struct_begin("pipe_blend_state");
424 trace_dump_member(bool, state
, dither
);
426 trace_dump_member(bool, state
, logicop_enable
);
427 trace_dump_member(uint
, state
, logicop_func
);
429 trace_dump_member(bool, state
, independent_blend_enable
);
431 trace_dump_member_begin("rt");
432 if (state
->independent_blend_enable
)
433 valid_entries
= PIPE_MAX_COLOR_BUFS
;
434 trace_dump_struct_array(rt_blend_state
, state
->rt
, valid_entries
);
435 trace_dump_member_end();
437 trace_dump_struct_end();
441 void trace_dump_blend_color(const struct pipe_blend_color
*state
)
443 if (!trace_dumping_enabled_locked())
451 trace_dump_struct_begin("pipe_blend_color");
453 trace_dump_member_array(float, state
, color
);
455 trace_dump_struct_end();
458 void trace_dump_stencil_ref(const struct pipe_stencil_ref
*state
)
460 if (!trace_dumping_enabled_locked())
468 trace_dump_struct_begin("pipe_stencil_ref");
470 trace_dump_member_array(uint
, state
, ref_value
);
472 trace_dump_struct_end();
475 void trace_dump_framebuffer_state(const struct pipe_framebuffer_state
*state
)
477 if (!trace_dumping_enabled_locked())
480 trace_dump_struct_begin("pipe_framebuffer_state");
482 trace_dump_member(uint
, state
, width
);
483 trace_dump_member(uint
, state
, height
);
484 trace_dump_member(uint
, state
, samples
);
485 trace_dump_member(uint
, state
, layers
);
486 trace_dump_member(uint
, state
, nr_cbufs
);
487 trace_dump_member_array(ptr
, state
, cbufs
);
488 trace_dump_member(ptr
, state
, zsbuf
);
490 trace_dump_struct_end();
494 void trace_dump_sampler_state(const struct pipe_sampler_state
*state
)
496 if (!trace_dumping_enabled_locked())
504 trace_dump_struct_begin("pipe_sampler_state");
506 trace_dump_member(uint
, state
, wrap_s
);
507 trace_dump_member(uint
, state
, wrap_t
);
508 trace_dump_member(uint
, state
, wrap_r
);
509 trace_dump_member(uint
, state
, min_img_filter
);
510 trace_dump_member(uint
, state
, min_mip_filter
);
511 trace_dump_member(uint
, state
, mag_img_filter
);
512 trace_dump_member(uint
, state
, compare_mode
);
513 trace_dump_member(uint
, state
, compare_func
);
514 trace_dump_member(bool, state
, normalized_coords
);
515 trace_dump_member(uint
, state
, max_anisotropy
);
516 trace_dump_member(bool, state
, seamless_cube_map
);
517 trace_dump_member(float, state
, lod_bias
);
518 trace_dump_member(float, state
, min_lod
);
519 trace_dump_member(float, state
, max_lod
);
520 trace_dump_member_array(float, state
, border_color
.f
);
522 trace_dump_struct_end();
526 void trace_dump_sampler_view_template(const struct pipe_sampler_view
*state
,
527 enum pipe_texture_target target
)
529 if (!trace_dumping_enabled_locked())
537 trace_dump_struct_begin("pipe_sampler_view");
539 trace_dump_member(format
, state
, format
);
541 trace_dump_member_begin("u");
542 trace_dump_struct_begin(""); /* anonymous */
543 if (target
== PIPE_BUFFER
) {
544 trace_dump_member_begin("buf");
545 trace_dump_struct_begin(""); /* anonymous */
546 trace_dump_member(uint
, &state
->u
.buf
, offset
);
547 trace_dump_member(uint
, &state
->u
.buf
, size
);
548 trace_dump_struct_end(); /* anonymous */
549 trace_dump_member_end(); /* buf */
551 trace_dump_member_begin("tex");
552 trace_dump_struct_begin(""); /* anonymous */
553 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
554 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
555 trace_dump_member(uint
, &state
->u
.tex
, first_level
);
556 trace_dump_member(uint
, &state
->u
.tex
, last_level
);
557 trace_dump_struct_end(); /* anonymous */
558 trace_dump_member_end(); /* tex */
560 trace_dump_struct_end(); /* anonymous */
561 trace_dump_member_end(); /* u */
563 trace_dump_member(uint
, state
, swizzle_r
);
564 trace_dump_member(uint
, state
, swizzle_g
);
565 trace_dump_member(uint
, state
, swizzle_b
);
566 trace_dump_member(uint
, state
, swizzle_a
);
568 trace_dump_struct_end();
572 void trace_dump_surface_template(const struct pipe_surface
*state
,
573 enum pipe_texture_target target
)
575 if (!trace_dumping_enabled_locked())
583 trace_dump_struct_begin("pipe_surface");
585 trace_dump_member(format
, state
, format
);
586 trace_dump_member(uint
, state
, width
);
587 trace_dump_member(uint
, state
, height
);
589 trace_dump_member_begin("u");
590 trace_dump_struct_begin(""); /* anonymous */
591 if (target
== PIPE_BUFFER
) {
592 trace_dump_member_begin("buf");
593 trace_dump_struct_begin(""); /* anonymous */
594 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
595 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
596 trace_dump_struct_end(); /* anonymous */
597 trace_dump_member_end(); /* buf */
599 trace_dump_member_begin("tex");
600 trace_dump_struct_begin(""); /* anonymous */
601 trace_dump_member(uint
, &state
->u
.tex
, level
);
602 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
603 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
604 trace_dump_struct_end(); /* anonymous */
605 trace_dump_member_end(); /* tex */
607 trace_dump_struct_end(); /* anonymous */
608 trace_dump_member_end(); /* u */
610 trace_dump_struct_end();
614 void trace_dump_transfer(const struct pipe_transfer
*state
)
616 if (!trace_dumping_enabled_locked())
624 trace_dump_struct_begin("pipe_transfer");
626 trace_dump_member(uint
, state
, box
.x
);
627 trace_dump_member(uint
, state
, box
.y
);
628 trace_dump_member(uint
, state
, box
.z
);
629 trace_dump_member(uint
, state
, box
.width
);
630 trace_dump_member(uint
, state
, box
.height
);
631 trace_dump_member(uint
, state
, box
.depth
);
633 trace_dump_member(uint
, state
, stride
);
634 trace_dump_member(uint
, state
, layer_stride
);
635 trace_dump_member(uint
, state
, usage
);
637 trace_dump_member(ptr
, state
, resource
);
639 trace_dump_struct_end();
643 void trace_dump_vertex_buffer(const struct pipe_vertex_buffer
*state
)
645 if (!trace_dumping_enabled_locked())
653 trace_dump_struct_begin("pipe_vertex_buffer");
655 trace_dump_member(uint
, state
, stride
);
656 trace_dump_member(bool, state
, is_user_buffer
);
657 trace_dump_member(uint
, state
, buffer_offset
);
658 trace_dump_member(ptr
, state
, buffer
.resource
);
660 trace_dump_struct_end();
664 void trace_dump_vertex_element(const struct pipe_vertex_element
*state
)
666 if (!trace_dumping_enabled_locked())
674 trace_dump_struct_begin("pipe_vertex_element");
676 trace_dump_member(uint
, state
, src_offset
);
678 trace_dump_member(uint
, state
, vertex_buffer_index
);
680 trace_dump_member(format
, state
, src_format
);
682 trace_dump_struct_end();
686 void trace_dump_constant_buffer(const struct pipe_constant_buffer
*state
)
688 if (!trace_dumping_enabled_locked())
696 trace_dump_struct_begin("pipe_constant_buffer");
697 trace_dump_member(ptr
, state
, buffer
);
698 trace_dump_member(uint
, state
, buffer_offset
);
699 trace_dump_member(uint
, state
, buffer_size
);
700 trace_dump_struct_end();
704 void trace_dump_shader_buffer(const struct pipe_shader_buffer
*state
)
706 if (!trace_dumping_enabled_locked())
714 trace_dump_struct_begin("pipe_shader_buffer");
715 trace_dump_member(ptr
, state
, buffer
);
716 trace_dump_member(uint
, state
, buffer_offset
);
717 trace_dump_member(uint
, state
, buffer_size
);
718 trace_dump_struct_end();
722 void trace_dump_image_view(const struct pipe_image_view
*state
)
724 if (!trace_dumping_enabled_locked())
732 trace_dump_struct_begin("pipe_image_view");
733 trace_dump_member(ptr
, state
, resource
);
734 trace_dump_member(uint
, state
, format
);
735 trace_dump_member(uint
, state
, access
);
737 trace_dump_member_begin("u");
738 trace_dump_struct_begin(""); /* anonymous */
739 if (state
->resource
->target
== PIPE_BUFFER
) {
740 trace_dump_member_begin("buf");
741 trace_dump_struct_begin(""); /* anonymous */
742 trace_dump_member(uint
, &state
->u
.buf
, offset
);
743 trace_dump_member(uint
, &state
->u
.buf
, size
);
744 trace_dump_struct_end(); /* anonymous */
745 trace_dump_member_end(); /* buf */
747 trace_dump_member_begin("tex");
748 trace_dump_struct_begin(""); /* anonymous */
749 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
750 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
751 trace_dump_member(uint
, &state
->u
.tex
, level
);
752 trace_dump_struct_end(); /* anonymous */
753 trace_dump_member_end(); /* tex */
755 trace_dump_struct_end(); /* anonymous */
756 trace_dump_member_end(); /* u */
758 trace_dump_struct_end();
762 void trace_dump_draw_info(const struct pipe_draw_info
*state
)
764 if (!trace_dumping_enabled_locked())
772 trace_dump_struct_begin("pipe_draw_info");
774 trace_dump_member(uint
, state
, index_size
);
775 trace_dump_member(uint
, state
, has_user_indices
);
777 trace_dump_member(uint
, state
, mode
);
778 trace_dump_member(uint
, state
, start
);
779 trace_dump_member(uint
, state
, count
);
781 trace_dump_member(uint
, state
, start_instance
);
782 trace_dump_member(uint
, state
, instance_count
);
784 trace_dump_member(uint
, state
, vertices_per_patch
);
786 trace_dump_member(int, state
, index_bias
);
787 trace_dump_member(uint
, state
, min_index
);
788 trace_dump_member(uint
, state
, max_index
);
790 trace_dump_member(bool, state
, primitive_restart
);
791 trace_dump_member(uint
, state
, restart_index
);
793 trace_dump_member(ptr
, state
, index
.resource
);
794 trace_dump_member(ptr
, state
, count_from_stream_output
);
796 if (!state
->indirect
) {
797 trace_dump_member(ptr
, state
, indirect
);
799 trace_dump_member(uint
, state
, indirect
->offset
);
800 trace_dump_member(uint
, state
, indirect
->stride
);
801 trace_dump_member(uint
, state
, indirect
->draw_count
);
802 trace_dump_member(uint
, state
, indirect
->indirect_draw_count_offset
);
803 trace_dump_member(ptr
, state
, indirect
->buffer
);
804 trace_dump_member(ptr
, state
, indirect
->indirect_draw_count
);
807 trace_dump_struct_end();
810 void trace_dump_blit_info(const struct pipe_blit_info
*info
)
814 if (!trace_dumping_enabled_locked())
822 trace_dump_struct_begin("pipe_blit_info");
824 trace_dump_member_begin("dst");
825 trace_dump_struct_begin("dst");
826 trace_dump_member(ptr
, &info
->dst
, resource
);
827 trace_dump_member(uint
, &info
->dst
, level
);
828 trace_dump_member(format
, &info
->dst
, format
);
829 trace_dump_member_begin("box");
830 trace_dump_box(&info
->dst
.box
);
831 trace_dump_member_end();
832 trace_dump_struct_end();
833 trace_dump_member_end();
835 trace_dump_member_begin("src");
836 trace_dump_struct_begin("src");
837 trace_dump_member(ptr
, &info
->src
, resource
);
838 trace_dump_member(uint
, &info
->src
, level
);
839 trace_dump_member(format
, &info
->src
, format
);
840 trace_dump_member_begin("box");
841 trace_dump_box(&info
->src
.box
);
842 trace_dump_member_end();
843 trace_dump_struct_end();
844 trace_dump_member_end();
846 mask
[0] = (info
->mask
& PIPE_MASK_R
) ? 'R' : '-';
847 mask
[1] = (info
->mask
& PIPE_MASK_G
) ? 'G' : '-';
848 mask
[2] = (info
->mask
& PIPE_MASK_B
) ? 'B' : '-';
849 mask
[3] = (info
->mask
& PIPE_MASK_A
) ? 'A' : '-';
850 mask
[4] = (info
->mask
& PIPE_MASK_Z
) ? 'Z' : '-';
851 mask
[5] = (info
->mask
& PIPE_MASK_S
) ? 'S' : '-';
854 trace_dump_member_begin("mask");
855 trace_dump_string(mask
);
856 trace_dump_member_end();
857 trace_dump_member(uint
, info
, filter
);
859 trace_dump_member(bool, info
, scissor_enable
);
860 trace_dump_member_begin("scissor");
861 trace_dump_scissor_state(&info
->scissor
);
862 trace_dump_member_end();
864 trace_dump_struct_end();
868 trace_dump_query_result(unsigned query_type
,
869 const union pipe_query_result
*result
)
871 if (!trace_dumping_enabled_locked())
879 switch (query_type
) {
880 case PIPE_QUERY_OCCLUSION_PREDICATE
:
881 case PIPE_QUERY_OCCLUSION_PREDICATE_CONSERVATIVE
:
882 case PIPE_QUERY_SO_OVERFLOW_PREDICATE
:
883 case PIPE_QUERY_SO_OVERFLOW_ANY_PREDICATE
:
884 case PIPE_QUERY_GPU_FINISHED
:
885 trace_dump_bool(result
->b
);
888 case PIPE_QUERY_OCCLUSION_COUNTER
:
889 case PIPE_QUERY_TIMESTAMP
:
890 case PIPE_QUERY_TIME_ELAPSED
:
891 case PIPE_QUERY_PRIMITIVES_GENERATED
:
892 case PIPE_QUERY_PRIMITIVES_EMITTED
:
893 trace_dump_uint(result
->u64
);
896 case PIPE_QUERY_SO_STATISTICS
:
897 trace_dump_struct_begin("pipe_query_data_so_statistics");
898 trace_dump_member(uint
, &result
->so_statistics
, num_primitives_written
);
899 trace_dump_member(uint
, &result
->so_statistics
, primitives_storage_needed
);
900 trace_dump_struct_end();
903 case PIPE_QUERY_TIMESTAMP_DISJOINT
:
904 trace_dump_struct_begin("pipe_query_data_timestamp_disjoint");
905 trace_dump_member(uint
, &result
->timestamp_disjoint
, frequency
);
906 trace_dump_member(bool, &result
->timestamp_disjoint
, disjoint
);
907 trace_dump_struct_end();
910 case PIPE_QUERY_PIPELINE_STATISTICS
:
911 trace_dump_struct_begin("pipe_query_data_pipeline_statistics");
912 trace_dump_member(uint
, &result
->pipeline_statistics
, ia_vertices
);
913 trace_dump_member(uint
, &result
->pipeline_statistics
, ia_primitives
);
914 trace_dump_member(uint
, &result
->pipeline_statistics
, vs_invocations
);
915 trace_dump_member(uint
, &result
->pipeline_statistics
, gs_invocations
);
916 trace_dump_member(uint
, &result
->pipeline_statistics
, gs_primitives
);
917 trace_dump_member(uint
, &result
->pipeline_statistics
, c_invocations
);
918 trace_dump_member(uint
, &result
->pipeline_statistics
, c_primitives
);
919 trace_dump_member(uint
, &result
->pipeline_statistics
, ps_invocations
);
920 trace_dump_member(uint
, &result
->pipeline_statistics
, hs_invocations
);
921 trace_dump_member(uint
, &result
->pipeline_statistics
, ds_invocations
);
922 trace_dump_member(uint
, &result
->pipeline_statistics
, cs_invocations
);
923 trace_dump_struct_end();
927 assert(query_type
>= PIPE_QUERY_DRIVER_SPECIFIC
);
928 trace_dump_uint(result
->u64
);
933 void trace_dump_grid_info(const struct pipe_grid_info
*state
)
935 if (!trace_dumping_enabled_locked())
943 trace_dump_struct_begin("pipe_grid_info");
945 trace_dump_member(uint
, state
, pc
);
946 trace_dump_member(ptr
, state
, input
);
948 trace_dump_member_begin("block");
949 trace_dump_array(uint
, state
->block
, ARRAY_SIZE(state
->block
));
950 trace_dump_member_end();
952 trace_dump_member_begin("grid");
953 trace_dump_array(uint
, state
->grid
, ARRAY_SIZE(state
->grid
));
954 trace_dump_member_end();
956 trace_dump_member(ptr
, state
, indirect
);
957 trace_dump_member(uint
, state
, indirect_offset
);
959 trace_dump_struct_end();