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_state.h"
38 void trace_dump_format(enum pipe_format format
)
40 if (!trace_dumping_enabled_locked())
43 trace_dump_enum(util_format_name(format
) );
47 void trace_dump_resource_template(const struct pipe_resource
*templat
)
49 if (!trace_dumping_enabled_locked())
57 trace_dump_struct_begin("pipe_resource");
59 trace_dump_member(int, templat
, target
);
60 trace_dump_member(format
, templat
, format
);
62 trace_dump_member_begin("width");
63 trace_dump_uint(templat
->width0
);
64 trace_dump_member_end();
66 trace_dump_member_begin("height");
67 trace_dump_uint(templat
->height0
);
68 trace_dump_member_end();
70 trace_dump_member_begin("depth");
71 trace_dump_uint(templat
->depth0
);
72 trace_dump_member_end();
74 trace_dump_member_begin("array_size");
75 trace_dump_uint(templat
->array_size
);
76 trace_dump_member_end();
78 trace_dump_member(uint
, templat
, last_level
);
79 trace_dump_member(uint
, templat
, nr_samples
);
80 trace_dump_member(uint
, templat
, usage
);
81 trace_dump_member(uint
, templat
, bind
);
82 trace_dump_member(uint
, templat
, flags
);
84 trace_dump_struct_end();
88 void trace_dump_box(const struct pipe_box
*box
)
90 if (!trace_dumping_enabled_locked())
98 trace_dump_struct_begin("pipe_box");
100 trace_dump_member(int, box
, x
);
101 trace_dump_member(int, box
, y
);
102 trace_dump_member(int, box
, z
);
103 trace_dump_member(int, box
, width
);
104 trace_dump_member(int, box
, height
);
105 trace_dump_member(int, box
, depth
);
107 trace_dump_struct_end();
111 void trace_dump_rasterizer_state(const struct pipe_rasterizer_state
*state
)
113 if (!trace_dumping_enabled_locked())
121 trace_dump_struct_begin("pipe_rasterizer_state");
123 trace_dump_member(bool, state
, flatshade
);
124 trace_dump_member(bool, state
, light_twoside
);
125 trace_dump_member(bool, state
, clamp_vertex_color
);
126 trace_dump_member(bool, state
, clamp_fragment_color
);
127 trace_dump_member(uint
, state
, front_ccw
);
128 trace_dump_member(uint
, state
, cull_face
);
129 trace_dump_member(uint
, state
, fill_front
);
130 trace_dump_member(uint
, state
, fill_back
);
131 trace_dump_member(bool, state
, offset_point
);
132 trace_dump_member(bool, state
, offset_line
);
133 trace_dump_member(bool, state
, offset_tri
);
134 trace_dump_member(bool, state
, scissor
);
135 trace_dump_member(bool, state
, poly_smooth
);
136 trace_dump_member(bool, state
, poly_stipple_enable
);
137 trace_dump_member(bool, state
, point_smooth
);
138 trace_dump_member(uint
, state
, sprite_coord_enable
);
139 trace_dump_member(bool, state
, sprite_coord_mode
);
140 trace_dump_member(bool, state
, point_quad_rasterization
);
141 trace_dump_member(bool, state
, point_size_per_vertex
);
142 trace_dump_member(bool, state
, multisample
);
143 trace_dump_member(bool, state
, line_smooth
);
144 trace_dump_member(bool, state
, line_stipple_enable
);
145 trace_dump_member(uint
, state
, line_stipple_factor
);
146 trace_dump_member(uint
, state
, line_stipple_pattern
);
147 trace_dump_member(bool, state
, line_last_pixel
);
148 trace_dump_member(bool, state
, flatshade_first
);
149 trace_dump_member(bool, state
, half_pixel_center
);
150 trace_dump_member(bool, state
, bottom_edge_rule
);
151 trace_dump_member(bool, state
, rasterizer_discard
);
152 trace_dump_member(bool, state
, depth_clip
);
153 trace_dump_member(bool, state
, clip_halfz
);
154 trace_dump_member(uint
, state
, clip_plane_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_struct_end();
296 trace_dump_elem_end();
298 trace_dump_array_end();
299 trace_dump_member_end(); // output
300 trace_dump_struct_end();
301 trace_dump_member_end(); // stream_output
303 trace_dump_struct_end();
307 void trace_dump_depth_stencil_alpha_state(const struct pipe_depth_stencil_alpha_state
*state
)
311 if (!trace_dumping_enabled_locked())
319 trace_dump_struct_begin("pipe_depth_stencil_alpha_state");
321 trace_dump_member_begin("depth");
322 trace_dump_struct_begin("pipe_depth_state");
323 trace_dump_member(bool, &state
->depth
, enabled
);
324 trace_dump_member(bool, &state
->depth
, writemask
);
325 trace_dump_member(uint
, &state
->depth
, func
);
326 trace_dump_struct_end();
327 trace_dump_member_end();
329 trace_dump_member_begin("stencil");
330 trace_dump_array_begin();
331 for(i
= 0; i
< Elements(state
->stencil
); ++i
) {
332 trace_dump_elem_begin();
333 trace_dump_struct_begin("pipe_stencil_state");
334 trace_dump_member(bool, &state
->stencil
[i
], enabled
);
335 trace_dump_member(uint
, &state
->stencil
[i
], func
);
336 trace_dump_member(uint
, &state
->stencil
[i
], fail_op
);
337 trace_dump_member(uint
, &state
->stencil
[i
], zpass_op
);
338 trace_dump_member(uint
, &state
->stencil
[i
], zfail_op
);
339 trace_dump_member(uint
, &state
->stencil
[i
], valuemask
);
340 trace_dump_member(uint
, &state
->stencil
[i
], writemask
);
341 trace_dump_struct_end();
342 trace_dump_elem_end();
344 trace_dump_array_end();
345 trace_dump_member_end();
347 trace_dump_member_begin("alpha");
348 trace_dump_struct_begin("pipe_alpha_state");
349 trace_dump_member(bool, &state
->alpha
, enabled
);
350 trace_dump_member(uint
, &state
->alpha
, func
);
351 trace_dump_member(float, &state
->alpha
, ref_value
);
352 trace_dump_struct_end();
353 trace_dump_member_end();
355 trace_dump_struct_end();
358 static void trace_dump_rt_blend_state(const struct pipe_rt_blend_state
*state
)
360 trace_dump_struct_begin("pipe_rt_blend_state");
362 trace_dump_member(uint
, state
, blend_enable
);
364 trace_dump_member(uint
, state
, rgb_func
);
365 trace_dump_member(uint
, state
, rgb_src_factor
);
366 trace_dump_member(uint
, state
, rgb_dst_factor
);
368 trace_dump_member(uint
, state
, alpha_func
);
369 trace_dump_member(uint
, state
, alpha_src_factor
);
370 trace_dump_member(uint
, state
, alpha_dst_factor
);
372 trace_dump_member(uint
, state
, colormask
);
374 trace_dump_struct_end();
377 void trace_dump_blend_state(const struct pipe_blend_state
*state
)
379 unsigned valid_entries
= 1;
381 if (!trace_dumping_enabled_locked())
389 trace_dump_struct_begin("pipe_blend_state");
391 trace_dump_member(bool, state
, dither
);
393 trace_dump_member(bool, state
, logicop_enable
);
394 trace_dump_member(uint
, state
, logicop_func
);
396 trace_dump_member(bool, state
, independent_blend_enable
);
398 trace_dump_member_begin("rt");
399 if (state
->independent_blend_enable
)
400 valid_entries
= PIPE_MAX_COLOR_BUFS
;
401 trace_dump_struct_array(rt_blend_state
, state
->rt
, valid_entries
);
402 trace_dump_member_end();
404 trace_dump_struct_end();
408 void trace_dump_blend_color(const struct pipe_blend_color
*state
)
410 if (!trace_dumping_enabled_locked())
418 trace_dump_struct_begin("pipe_blend_color");
420 trace_dump_member_array(float, state
, color
);
422 trace_dump_struct_end();
425 void trace_dump_stencil_ref(const struct pipe_stencil_ref
*state
)
427 if (!trace_dumping_enabled_locked())
435 trace_dump_struct_begin("pipe_stencil_ref");
437 trace_dump_member_array(uint
, state
, ref_value
);
439 trace_dump_struct_end();
442 void trace_dump_framebuffer_state(const struct pipe_framebuffer_state
*state
)
444 if (!trace_dumping_enabled_locked())
447 trace_dump_struct_begin("pipe_framebuffer_state");
449 trace_dump_member(uint
, state
, width
);
450 trace_dump_member(uint
, state
, height
);
451 trace_dump_member(uint
, state
, nr_cbufs
);
452 trace_dump_member_array(ptr
, state
, cbufs
);
453 trace_dump_member(ptr
, state
, zsbuf
);
455 trace_dump_struct_end();
459 void trace_dump_sampler_state(const struct pipe_sampler_state
*state
)
461 if (!trace_dumping_enabled_locked())
469 trace_dump_struct_begin("pipe_sampler_state");
471 trace_dump_member(uint
, state
, wrap_s
);
472 trace_dump_member(uint
, state
, wrap_t
);
473 trace_dump_member(uint
, state
, wrap_r
);
474 trace_dump_member(uint
, state
, min_img_filter
);
475 trace_dump_member(uint
, state
, min_mip_filter
);
476 trace_dump_member(uint
, state
, mag_img_filter
);
477 trace_dump_member(uint
, state
, compare_mode
);
478 trace_dump_member(uint
, state
, compare_func
);
479 trace_dump_member(bool, state
, normalized_coords
);
480 trace_dump_member(uint
, state
, max_anisotropy
);
481 trace_dump_member(float, state
, lod_bias
);
482 trace_dump_member(float, state
, min_lod
);
483 trace_dump_member(float, state
, max_lod
);
484 trace_dump_member_array(float, state
, border_color
.f
);
486 trace_dump_struct_end();
490 void trace_dump_sampler_view_template(const struct pipe_sampler_view
*state
,
491 enum pipe_texture_target target
)
493 if (!trace_dumping_enabled_locked())
501 trace_dump_struct_begin("pipe_sampler_view");
503 trace_dump_member(format
, state
, format
);
505 trace_dump_member_begin("u");
506 trace_dump_struct_begin(""); /* anonymous */
507 if (target
== PIPE_BUFFER
) {
508 trace_dump_member_begin("buf");
509 trace_dump_struct_begin(""); /* anonymous */
510 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
511 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
512 trace_dump_struct_end(); /* anonymous */
513 trace_dump_member_end(); /* buf */
515 trace_dump_member_begin("tex");
516 trace_dump_struct_begin(""); /* anonymous */
517 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
518 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
519 trace_dump_member(uint
, &state
->u
.tex
, first_level
);
520 trace_dump_member(uint
, &state
->u
.tex
, last_level
);
521 trace_dump_struct_end(); /* anonymous */
522 trace_dump_member_end(); /* tex */
524 trace_dump_struct_end(); /* anonymous */
525 trace_dump_member_end(); /* u */
527 trace_dump_member(uint
, state
, swizzle_r
);
528 trace_dump_member(uint
, state
, swizzle_g
);
529 trace_dump_member(uint
, state
, swizzle_b
);
530 trace_dump_member(uint
, state
, swizzle_a
);
532 trace_dump_struct_end();
536 void trace_dump_surface_template(const struct pipe_surface
*state
,
537 enum pipe_texture_target target
)
539 if (!trace_dumping_enabled_locked())
547 trace_dump_struct_begin("pipe_surface");
549 trace_dump_member(format
, state
, format
);
550 trace_dump_member(uint
, state
, width
);
551 trace_dump_member(uint
, state
, height
);
553 trace_dump_member_begin("u");
554 trace_dump_struct_begin(""); /* anonymous */
555 if (target
== PIPE_BUFFER
) {
556 trace_dump_member_begin("buf");
557 trace_dump_struct_begin(""); /* anonymous */
558 trace_dump_member(uint
, &state
->u
.buf
, first_element
);
559 trace_dump_member(uint
, &state
->u
.buf
, last_element
);
560 trace_dump_struct_end(); /* anonymous */
561 trace_dump_member_end(); /* buf */
563 trace_dump_member_begin("tex");
564 trace_dump_struct_begin(""); /* anonymous */
565 trace_dump_member(uint
, &state
->u
.tex
, level
);
566 trace_dump_member(uint
, &state
->u
.tex
, first_layer
);
567 trace_dump_member(uint
, &state
->u
.tex
, last_layer
);
568 trace_dump_struct_end(); /* anonymous */
569 trace_dump_member_end(); /* tex */
571 trace_dump_struct_end(); /* anonymous */
572 trace_dump_member_end(); /* u */
574 trace_dump_struct_end();
578 void trace_dump_transfer(const struct pipe_transfer
*state
)
580 if (!trace_dumping_enabled_locked())
588 trace_dump_struct_begin("pipe_transfer");
590 trace_dump_member(uint
, state
, box
.x
);
591 trace_dump_member(uint
, state
, box
.y
);
592 trace_dump_member(uint
, state
, box
.z
);
593 trace_dump_member(uint
, state
, box
.width
);
594 trace_dump_member(uint
, state
, box
.height
);
595 trace_dump_member(uint
, state
, box
.depth
);
597 trace_dump_member(uint
, state
, stride
);
598 trace_dump_member(uint
, state
, layer_stride
);
599 trace_dump_member(uint
, state
, usage
);
601 trace_dump_member(ptr
, state
, resource
);
603 trace_dump_struct_end();
607 void trace_dump_vertex_buffer(const struct pipe_vertex_buffer
*state
)
609 if (!trace_dumping_enabled_locked())
617 trace_dump_struct_begin("pipe_vertex_buffer");
619 trace_dump_member(uint
, state
, stride
);
620 trace_dump_member(uint
, state
, buffer_offset
);
621 trace_dump_member(resource_ptr
, state
, buffer
);
623 trace_dump_struct_end();
627 void trace_dump_index_buffer(const struct pipe_index_buffer
*state
)
629 if (!trace_dumping_enabled_locked())
637 trace_dump_struct_begin("pipe_index_buffer");
639 trace_dump_member(uint
, state
, index_size
);
640 trace_dump_member(uint
, state
, offset
);
641 trace_dump_member(resource_ptr
, state
, buffer
);
643 trace_dump_struct_end();
647 void trace_dump_vertex_element(const struct pipe_vertex_element
*state
)
649 if (!trace_dumping_enabled_locked())
657 trace_dump_struct_begin("pipe_vertex_element");
659 trace_dump_member(uint
, state
, src_offset
);
661 trace_dump_member(uint
, state
, vertex_buffer_index
);
663 trace_dump_member(format
, state
, src_format
);
665 trace_dump_struct_end();
669 void trace_dump_constant_buffer(const struct pipe_constant_buffer
*state
)
671 if (!trace_dumping_enabled_locked())
679 trace_dump_struct_begin("pipe_constant_buffer");
680 trace_dump_member(ptr
, state
, buffer
);
681 trace_dump_member(uint
, state
, buffer_offset
);
682 trace_dump_member(uint
, state
, buffer_size
);
683 trace_dump_struct_end();
687 void trace_dump_draw_info(const struct pipe_draw_info
*state
)
689 if (!trace_dumping_enabled_locked())
697 trace_dump_struct_begin("pipe_draw_info");
699 trace_dump_member(bool, state
, indexed
);
701 trace_dump_member(uint
, state
, mode
);
702 trace_dump_member(uint
, state
, start
);
703 trace_dump_member(uint
, state
, count
);
705 trace_dump_member(uint
, state
, start_instance
);
706 trace_dump_member(uint
, state
, instance_count
);
708 trace_dump_member(int, state
, index_bias
);
709 trace_dump_member(uint
, state
, min_index
);
710 trace_dump_member(uint
, state
, max_index
);
712 trace_dump_member(bool, state
, primitive_restart
);
713 trace_dump_member(uint
, state
, restart_index
);
715 trace_dump_member(ptr
, state
, count_from_stream_output
);
717 trace_dump_struct_end();
720 void trace_dump_blit_info(const struct pipe_blit_info
*info
)
724 if (!trace_dumping_enabled_locked())
732 trace_dump_struct_begin("pipe_blit_info");
734 trace_dump_member_begin("dst");
735 trace_dump_struct_begin("dst");
736 trace_dump_member(resource_ptr
, &info
->dst
, resource
);
737 trace_dump_member(uint
, &info
->dst
, level
);
738 trace_dump_member(format
, &info
->dst
, format
);
739 trace_dump_member_begin("box");
740 trace_dump_box(&info
->dst
.box
);
741 trace_dump_member_end();
742 trace_dump_struct_end();
743 trace_dump_member_end();
745 trace_dump_member_begin("src");
746 trace_dump_struct_begin("src");
747 trace_dump_member(resource_ptr
, &info
->src
, resource
);
748 trace_dump_member(uint
, &info
->src
, level
);
749 trace_dump_member(format
, &info
->src
, format
);
750 trace_dump_member_begin("box");
751 trace_dump_box(&info
->src
.box
);
752 trace_dump_member_end();
753 trace_dump_struct_end();
754 trace_dump_member_end();
756 mask
[0] = (info
->mask
& PIPE_MASK_R
) ? 'R' : '-';
757 mask
[1] = (info
->mask
& PIPE_MASK_G
) ? 'G' : '-';
758 mask
[2] = (info
->mask
& PIPE_MASK_B
) ? 'B' : '-';
759 mask
[3] = (info
->mask
& PIPE_MASK_A
) ? 'A' : '-';
760 mask
[4] = (info
->mask
& PIPE_MASK_Z
) ? 'Z' : '-';
761 mask
[5] = (info
->mask
& PIPE_MASK_S
) ? 'S' : '-';
764 trace_dump_member_begin("mask");
765 trace_dump_string(mask
);
766 trace_dump_member_end();
767 trace_dump_member(uint
, info
, filter
);
769 trace_dump_member(bool, info
, scissor_enable
);
770 trace_dump_member_begin("scissor");
771 trace_dump_scissor_state(&info
->scissor
);
772 trace_dump_member_end();
774 trace_dump_struct_end();