22f1d278033235c71f6a991935de94f3899ad9ab
[mesa.git] / src / gallium / drivers / trace / tr_dump_state.c
1 /**************************************************************************
2 *
3 * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
4 * All Rights Reserved.
5 *
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:
13 *
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
16 * of the Software.
17 *
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.
25 *
26 **************************************************************************/
27
28
29 #include "pipe/p_compiler.h"
30 #include "util/u_memory.h"
31 #include "util/u_format.h"
32 #include "tgsi/tgsi_dump.h"
33
34 #include "tr_dump.h"
35 #include "tr_dump_state.h"
36
37
38 void trace_dump_format(enum pipe_format format)
39 {
40 if (!trace_dumping_enabled_locked())
41 return;
42
43 trace_dump_enum(util_format_name(format) );
44 }
45
46
47 void trace_dump_resource_template(const struct pipe_resource *templat)
48 {
49 if (!trace_dumping_enabled_locked())
50 return;
51
52 if(!templat) {
53 trace_dump_null();
54 return;
55 }
56
57 trace_dump_struct_begin("pipe_resource");
58
59 trace_dump_member(int, templat, target);
60 trace_dump_member(format, templat, format);
61
62 trace_dump_member_begin("width");
63 trace_dump_uint(templat->width0);
64 trace_dump_member_end();
65
66 trace_dump_member_begin("height");
67 trace_dump_uint(templat->height0);
68 trace_dump_member_end();
69
70 trace_dump_member_begin("depth");
71 trace_dump_uint(templat->depth0);
72 trace_dump_member_end();
73
74 trace_dump_member_begin("array_size");
75 trace_dump_uint(templat->array_size);
76 trace_dump_member_end();
77
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);
83
84 trace_dump_struct_end();
85 }
86
87
88 void trace_dump_box(const struct pipe_box *box)
89 {
90 if (!trace_dumping_enabled_locked())
91 return;
92
93 if(!box) {
94 trace_dump_null();
95 return;
96 }
97
98 trace_dump_struct_begin("pipe_box");
99
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);
106
107 trace_dump_struct_end();
108 }
109
110
111 void trace_dump_rasterizer_state(const struct pipe_rasterizer_state *state)
112 {
113 if (!trace_dumping_enabled_locked())
114 return;
115
116 if(!state) {
117 trace_dump_null();
118 return;
119 }
120
121 trace_dump_struct_begin("pipe_rasterizer_state");
122
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);
155
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);
161
162 trace_dump_struct_end();
163 }
164
165
166 void trace_dump_poly_stipple(const struct pipe_poly_stipple *state)
167 {
168 if (!trace_dumping_enabled_locked())
169 return;
170
171 if(!state) {
172 trace_dump_null();
173 return;
174 }
175
176 trace_dump_struct_begin("pipe_poly_stipple");
177
178 trace_dump_member_begin("stipple");
179 trace_dump_array(uint,
180 state->stipple,
181 Elements(state->stipple));
182 trace_dump_member_end();
183
184 trace_dump_struct_end();
185 }
186
187
188 void trace_dump_viewport_state(const struct pipe_viewport_state *state)
189 {
190 if (!trace_dumping_enabled_locked())
191 return;
192
193 if(!state) {
194 trace_dump_null();
195 return;
196 }
197
198 trace_dump_struct_begin("pipe_viewport_state");
199
200 trace_dump_member_array(float, state, scale);
201 trace_dump_member_array(float, state, translate);
202
203 trace_dump_struct_end();
204 }
205
206
207 void trace_dump_scissor_state(const struct pipe_scissor_state *state)
208 {
209 if (!trace_dumping_enabled_locked())
210 return;
211
212 if(!state) {
213 trace_dump_null();
214 return;
215 }
216
217 trace_dump_struct_begin("pipe_scissor_state");
218
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);
223
224 trace_dump_struct_end();
225 }
226
227
228 void trace_dump_clip_state(const struct pipe_clip_state *state)
229 {
230 unsigned i;
231
232 if (!trace_dumping_enabled_locked())
233 return;
234
235 if(!state) {
236 trace_dump_null();
237 return;
238 }
239
240 trace_dump_struct_begin("pipe_clip_state");
241
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();
248 }
249 trace_dump_array_end();
250 trace_dump_member_end();
251
252 trace_dump_struct_end();
253 }
254
255
256 void trace_dump_shader_state(const struct pipe_shader_state *state)
257 {
258 unsigned i;
259
260 if (!trace_dumping_enabled_locked())
261 return;
262
263 if(!state) {
264 trace_dump_null();
265 return;
266 }
267
268
269 trace_dump_struct_begin("pipe_shader_state");
270
271 trace_dump_member_begin("tokens");
272 if (state->tokens) {
273 static char str[64 * 1024];
274 tgsi_dump_str(state->tokens, 0, str, sizeof(str));
275 trace_dump_string(str);
276 } else {
277 trace_dump_null();
278 }
279 trace_dump_member_end();
280
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();
297 }
298 trace_dump_array_end();
299 trace_dump_member_end(); // output
300 trace_dump_struct_end();
301 trace_dump_member_end(); // stream_output
302
303 trace_dump_struct_end();
304 }
305
306
307 void trace_dump_depth_stencil_alpha_state(const struct pipe_depth_stencil_alpha_state *state)
308 {
309 unsigned i;
310
311 if (!trace_dumping_enabled_locked())
312 return;
313
314 if(!state) {
315 trace_dump_null();
316 return;
317 }
318
319 trace_dump_struct_begin("pipe_depth_stencil_alpha_state");
320
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();
328
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();
343 }
344 trace_dump_array_end();
345 trace_dump_member_end();
346
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();
354
355 trace_dump_struct_end();
356 }
357
358 static void trace_dump_rt_blend_state(const struct pipe_rt_blend_state *state)
359 {
360 trace_dump_struct_begin("pipe_rt_blend_state");
361
362 trace_dump_member(uint, state, blend_enable);
363
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);
367
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);
371
372 trace_dump_member(uint, state, colormask);
373
374 trace_dump_struct_end();
375 }
376
377 void trace_dump_blend_state(const struct pipe_blend_state *state)
378 {
379 unsigned valid_entries = 1;
380
381 if (!trace_dumping_enabled_locked())
382 return;
383
384 if(!state) {
385 trace_dump_null();
386 return;
387 }
388
389 trace_dump_struct_begin("pipe_blend_state");
390
391 trace_dump_member(bool, state, dither);
392
393 trace_dump_member(bool, state, logicop_enable);
394 trace_dump_member(uint, state, logicop_func);
395
396 trace_dump_member(bool, state, independent_blend_enable);
397
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();
403
404 trace_dump_struct_end();
405 }
406
407
408 void trace_dump_blend_color(const struct pipe_blend_color *state)
409 {
410 if (!trace_dumping_enabled_locked())
411 return;
412
413 if(!state) {
414 trace_dump_null();
415 return;
416 }
417
418 trace_dump_struct_begin("pipe_blend_color");
419
420 trace_dump_member_array(float, state, color);
421
422 trace_dump_struct_end();
423 }
424
425 void trace_dump_stencil_ref(const struct pipe_stencil_ref *state)
426 {
427 if (!trace_dumping_enabled_locked())
428 return;
429
430 if(!state) {
431 trace_dump_null();
432 return;
433 }
434
435 trace_dump_struct_begin("pipe_stencil_ref");
436
437 trace_dump_member_array(uint, state, ref_value);
438
439 trace_dump_struct_end();
440 }
441
442 void trace_dump_framebuffer_state(const struct pipe_framebuffer_state *state)
443 {
444 if (!trace_dumping_enabled_locked())
445 return;
446
447 trace_dump_struct_begin("pipe_framebuffer_state");
448
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);
454
455 trace_dump_struct_end();
456 }
457
458
459 void trace_dump_sampler_state(const struct pipe_sampler_state *state)
460 {
461 if (!trace_dumping_enabled_locked())
462 return;
463
464 if(!state) {
465 trace_dump_null();
466 return;
467 }
468
469 trace_dump_struct_begin("pipe_sampler_state");
470
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);
485
486 trace_dump_struct_end();
487 }
488
489
490 void trace_dump_sampler_view_template(const struct pipe_sampler_view *state,
491 enum pipe_texture_target target)
492 {
493 if (!trace_dumping_enabled_locked())
494 return;
495
496 if(!state) {
497 trace_dump_null();
498 return;
499 }
500
501 trace_dump_struct_begin("pipe_sampler_view");
502
503 trace_dump_member(format, state, format);
504
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 */
514 } else {
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 */
523 }
524 trace_dump_struct_end(); /* anonymous */
525 trace_dump_member_end(); /* u */
526
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);
531
532 trace_dump_struct_end();
533 }
534
535
536 void trace_dump_surface_template(const struct pipe_surface *state,
537 enum pipe_texture_target target)
538 {
539 if (!trace_dumping_enabled_locked())
540 return;
541
542 if(!state) {
543 trace_dump_null();
544 return;
545 }
546
547 trace_dump_struct_begin("pipe_surface");
548
549 trace_dump_member(format, state, format);
550 trace_dump_member(uint, state, width);
551 trace_dump_member(uint, state, height);
552
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 */
562 } else {
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 */
570 }
571 trace_dump_struct_end(); /* anonymous */
572 trace_dump_member_end(); /* u */
573
574 trace_dump_struct_end();
575 }
576
577
578 void trace_dump_transfer(const struct pipe_transfer *state)
579 {
580 if (!trace_dumping_enabled_locked())
581 return;
582
583 if(!state) {
584 trace_dump_null();
585 return;
586 }
587
588 trace_dump_struct_begin("pipe_transfer");
589
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);
596
597 trace_dump_member(uint, state, stride);
598 trace_dump_member(uint, state, layer_stride);
599 trace_dump_member(uint, state, usage);
600
601 trace_dump_member(ptr, state, resource);
602
603 trace_dump_struct_end();
604 }
605
606
607 void trace_dump_vertex_buffer(const struct pipe_vertex_buffer *state)
608 {
609 if (!trace_dumping_enabled_locked())
610 return;
611
612 if(!state) {
613 trace_dump_null();
614 return;
615 }
616
617 trace_dump_struct_begin("pipe_vertex_buffer");
618
619 trace_dump_member(uint, state, stride);
620 trace_dump_member(uint, state, buffer_offset);
621 trace_dump_member(resource_ptr, state, buffer);
622
623 trace_dump_struct_end();
624 }
625
626
627 void trace_dump_index_buffer(const struct pipe_index_buffer *state)
628 {
629 if (!trace_dumping_enabled_locked())
630 return;
631
632 if(!state) {
633 trace_dump_null();
634 return;
635 }
636
637 trace_dump_struct_begin("pipe_index_buffer");
638
639 trace_dump_member(uint, state, index_size);
640 trace_dump_member(uint, state, offset);
641 trace_dump_member(resource_ptr, state, buffer);
642
643 trace_dump_struct_end();
644 }
645
646
647 void trace_dump_vertex_element(const struct pipe_vertex_element *state)
648 {
649 if (!trace_dumping_enabled_locked())
650 return;
651
652 if(!state) {
653 trace_dump_null();
654 return;
655 }
656
657 trace_dump_struct_begin("pipe_vertex_element");
658
659 trace_dump_member(uint, state, src_offset);
660
661 trace_dump_member(uint, state, vertex_buffer_index);
662
663 trace_dump_member(format, state, src_format);
664
665 trace_dump_struct_end();
666 }
667
668
669 void trace_dump_constant_buffer(const struct pipe_constant_buffer *state)
670 {
671 if (!trace_dumping_enabled_locked())
672 return;
673
674 if(!state) {
675 trace_dump_null();
676 return;
677 }
678
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();
684 }
685
686
687 void trace_dump_draw_info(const struct pipe_draw_info *state)
688 {
689 if (!trace_dumping_enabled_locked())
690 return;
691
692 if(!state) {
693 trace_dump_null();
694 return;
695 }
696
697 trace_dump_struct_begin("pipe_draw_info");
698
699 trace_dump_member(bool, state, indexed);
700
701 trace_dump_member(uint, state, mode);
702 trace_dump_member(uint, state, start);
703 trace_dump_member(uint, state, count);
704
705 trace_dump_member(uint, state, start_instance);
706 trace_dump_member(uint, state, instance_count);
707
708 trace_dump_member(int, state, index_bias);
709 trace_dump_member(uint, state, min_index);
710 trace_dump_member(uint, state, max_index);
711
712 trace_dump_member(bool, state, primitive_restart);
713 trace_dump_member(uint, state, restart_index);
714
715 trace_dump_member(ptr, state, count_from_stream_output);
716
717 trace_dump_struct_end();
718 }
719
720 void trace_dump_blit_info(const struct pipe_blit_info *info)
721 {
722 char mask[7];
723
724 if (!trace_dumping_enabled_locked())
725 return;
726
727 if (!info) {
728 trace_dump_null();
729 return;
730 }
731
732 trace_dump_struct_begin("pipe_blit_info");
733
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();
744
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();
755
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' : '-';
762 mask[6] = 0;
763
764 trace_dump_member_begin("mask");
765 trace_dump_string(mask);
766 trace_dump_member_end();
767 trace_dump_member(uint, info, filter);
768
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();
773
774 trace_dump_struct_end();
775 }