trace: Dump pipe_sampler_state::seamless_cube_map.
[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_defines.h"
36 #include "tr_dump_state.h"
37
38
39 void trace_dump_resource_template(const struct pipe_resource *templat)
40 {
41 if (!trace_dumping_enabled_locked())
42 return;
43
44 if(!templat) {
45 trace_dump_null();
46 return;
47 }
48
49 trace_dump_struct_begin("pipe_resource");
50
51 trace_dump_member(int, templat, target);
52 trace_dump_member(format, templat, format);
53
54 trace_dump_member_begin("width");
55 trace_dump_uint(templat->width0);
56 trace_dump_member_end();
57
58 trace_dump_member_begin("height");
59 trace_dump_uint(templat->height0);
60 trace_dump_member_end();
61
62 trace_dump_member_begin("depth");
63 trace_dump_uint(templat->depth0);
64 trace_dump_member_end();
65
66 trace_dump_member_begin("array_size");
67 trace_dump_uint(templat->array_size);
68 trace_dump_member_end();
69
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);
75
76 trace_dump_struct_end();
77 }
78
79
80 void trace_dump_box(const struct pipe_box *box)
81 {
82 if (!trace_dumping_enabled_locked())
83 return;
84
85 if(!box) {
86 trace_dump_null();
87 return;
88 }
89
90 trace_dump_struct_begin("pipe_box");
91
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);
98
99 trace_dump_struct_end();
100 }
101
102
103 void trace_dump_rasterizer_state(const struct pipe_rasterizer_state *state)
104 {
105 if (!trace_dumping_enabled_locked())
106 return;
107
108 if(!state) {
109 trace_dump_null();
110 return;
111 }
112
113 trace_dump_struct_begin("pipe_rasterizer_state");
114
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);
147
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);
153
154 trace_dump_struct_end();
155 }
156
157
158 void trace_dump_poly_stipple(const struct pipe_poly_stipple *state)
159 {
160 if (!trace_dumping_enabled_locked())
161 return;
162
163 if(!state) {
164 trace_dump_null();
165 return;
166 }
167
168 trace_dump_struct_begin("pipe_poly_stipple");
169
170 trace_dump_member_begin("stipple");
171 trace_dump_array(uint,
172 state->stipple,
173 Elements(state->stipple));
174 trace_dump_member_end();
175
176 trace_dump_struct_end();
177 }
178
179
180 void trace_dump_viewport_state(const struct pipe_viewport_state *state)
181 {
182 if (!trace_dumping_enabled_locked())
183 return;
184
185 if(!state) {
186 trace_dump_null();
187 return;
188 }
189
190 trace_dump_struct_begin("pipe_viewport_state");
191
192 trace_dump_member_array(float, state, scale);
193 trace_dump_member_array(float, state, translate);
194
195 trace_dump_struct_end();
196 }
197
198
199 void trace_dump_scissor_state(const struct pipe_scissor_state *state)
200 {
201 if (!trace_dumping_enabled_locked())
202 return;
203
204 if(!state) {
205 trace_dump_null();
206 return;
207 }
208
209 trace_dump_struct_begin("pipe_scissor_state");
210
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);
215
216 trace_dump_struct_end();
217 }
218
219
220 void trace_dump_clip_state(const struct pipe_clip_state *state)
221 {
222 unsigned i;
223
224 if (!trace_dumping_enabled_locked())
225 return;
226
227 if(!state) {
228 trace_dump_null();
229 return;
230 }
231
232 trace_dump_struct_begin("pipe_clip_state");
233
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();
240 }
241 trace_dump_array_end();
242 trace_dump_member_end();
243
244 trace_dump_struct_end();
245 }
246
247
248 void trace_dump_shader_state(const struct pipe_shader_state *state)
249 {
250 unsigned i;
251
252 if (!trace_dumping_enabled_locked())
253 return;
254
255 if(!state) {
256 trace_dump_null();
257 return;
258 }
259
260
261 trace_dump_struct_begin("pipe_shader_state");
262
263 trace_dump_member_begin("tokens");
264 if (state->tokens) {
265 static char str[64 * 1024];
266 tgsi_dump_str(state->tokens, 0, str, sizeof(str));
267 trace_dump_string(str);
268 } else {
269 trace_dump_null();
270 }
271 trace_dump_member_end();
272
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();
289 }
290 trace_dump_array_end();
291 trace_dump_member_end(); // output
292 trace_dump_struct_end();
293 trace_dump_member_end(); // stream_output
294
295 trace_dump_struct_end();
296 }
297
298
299 void trace_dump_depth_stencil_alpha_state(const struct pipe_depth_stencil_alpha_state *state)
300 {
301 unsigned i;
302
303 if (!trace_dumping_enabled_locked())
304 return;
305
306 if(!state) {
307 trace_dump_null();
308 return;
309 }
310
311 trace_dump_struct_begin("pipe_depth_stencil_alpha_state");
312
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();
320
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();
335 }
336 trace_dump_array_end();
337 trace_dump_member_end();
338
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();
346
347 trace_dump_struct_end();
348 }
349
350 static void trace_dump_rt_blend_state(const struct pipe_rt_blend_state *state)
351 {
352 trace_dump_struct_begin("pipe_rt_blend_state");
353
354 trace_dump_member(uint, state, blend_enable);
355
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);
359
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);
363
364 trace_dump_member(uint, state, colormask);
365
366 trace_dump_struct_end();
367 }
368
369 void trace_dump_blend_state(const struct pipe_blend_state *state)
370 {
371 unsigned valid_entries = 1;
372
373 if (!trace_dumping_enabled_locked())
374 return;
375
376 if(!state) {
377 trace_dump_null();
378 return;
379 }
380
381 trace_dump_struct_begin("pipe_blend_state");
382
383 trace_dump_member(bool, state, dither);
384
385 trace_dump_member(bool, state, logicop_enable);
386 trace_dump_member(uint, state, logicop_func);
387
388 trace_dump_member(bool, state, independent_blend_enable);
389
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();
395
396 trace_dump_struct_end();
397 }
398
399
400 void trace_dump_blend_color(const struct pipe_blend_color *state)
401 {
402 if (!trace_dumping_enabled_locked())
403 return;
404
405 if(!state) {
406 trace_dump_null();
407 return;
408 }
409
410 trace_dump_struct_begin("pipe_blend_color");
411
412 trace_dump_member_array(float, state, color);
413
414 trace_dump_struct_end();
415 }
416
417 void trace_dump_stencil_ref(const struct pipe_stencil_ref *state)
418 {
419 if (!trace_dumping_enabled_locked())
420 return;
421
422 if(!state) {
423 trace_dump_null();
424 return;
425 }
426
427 trace_dump_struct_begin("pipe_stencil_ref");
428
429 trace_dump_member_array(uint, state, ref_value);
430
431 trace_dump_struct_end();
432 }
433
434 void trace_dump_framebuffer_state(const struct pipe_framebuffer_state *state)
435 {
436 if (!trace_dumping_enabled_locked())
437 return;
438
439 trace_dump_struct_begin("pipe_framebuffer_state");
440
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);
446
447 trace_dump_struct_end();
448 }
449
450
451 void trace_dump_sampler_state(const struct pipe_sampler_state *state)
452 {
453 if (!trace_dumping_enabled_locked())
454 return;
455
456 if(!state) {
457 trace_dump_null();
458 return;
459 }
460
461 trace_dump_struct_begin("pipe_sampler_state");
462
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);
478
479 trace_dump_struct_end();
480 }
481
482
483 void trace_dump_sampler_view_template(const struct pipe_sampler_view *state,
484 enum pipe_texture_target target)
485 {
486 if (!trace_dumping_enabled_locked())
487 return;
488
489 if(!state) {
490 trace_dump_null();
491 return;
492 }
493
494 trace_dump_struct_begin("pipe_sampler_view");
495
496 trace_dump_member(format, state, format);
497
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 */
507 } else {
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 */
516 }
517 trace_dump_struct_end(); /* anonymous */
518 trace_dump_member_end(); /* u */
519
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);
524
525 trace_dump_struct_end();
526 }
527
528
529 void trace_dump_surface_template(const struct pipe_surface *state,
530 enum pipe_texture_target target)
531 {
532 if (!trace_dumping_enabled_locked())
533 return;
534
535 if(!state) {
536 trace_dump_null();
537 return;
538 }
539
540 trace_dump_struct_begin("pipe_surface");
541
542 trace_dump_member(format, state, format);
543 trace_dump_member(uint, state, width);
544 trace_dump_member(uint, state, height);
545
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 */
555 } else {
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 */
563 }
564 trace_dump_struct_end(); /* anonymous */
565 trace_dump_member_end(); /* u */
566
567 trace_dump_struct_end();
568 }
569
570
571 void trace_dump_transfer(const struct pipe_transfer *state)
572 {
573 if (!trace_dumping_enabled_locked())
574 return;
575
576 if(!state) {
577 trace_dump_null();
578 return;
579 }
580
581 trace_dump_struct_begin("pipe_transfer");
582
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);
589
590 trace_dump_member(uint, state, stride);
591 trace_dump_member(uint, state, layer_stride);
592 trace_dump_member(uint, state, usage);
593
594 trace_dump_member(ptr, state, resource);
595
596 trace_dump_struct_end();
597 }
598
599
600 void trace_dump_vertex_buffer(const struct pipe_vertex_buffer *state)
601 {
602 if (!trace_dumping_enabled_locked())
603 return;
604
605 if(!state) {
606 trace_dump_null();
607 return;
608 }
609
610 trace_dump_struct_begin("pipe_vertex_buffer");
611
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);
616
617 trace_dump_struct_end();
618 }
619
620
621 void trace_dump_index_buffer(const struct pipe_index_buffer *state)
622 {
623 if (!trace_dumping_enabled_locked())
624 return;
625
626 if(!state) {
627 trace_dump_null();
628 return;
629 }
630
631 trace_dump_struct_begin("pipe_index_buffer");
632
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);
637
638 trace_dump_struct_end();
639 }
640
641
642 void trace_dump_vertex_element(const struct pipe_vertex_element *state)
643 {
644 if (!trace_dumping_enabled_locked())
645 return;
646
647 if(!state) {
648 trace_dump_null();
649 return;
650 }
651
652 trace_dump_struct_begin("pipe_vertex_element");
653
654 trace_dump_member(uint, state, src_offset);
655
656 trace_dump_member(uint, state, vertex_buffer_index);
657
658 trace_dump_member(format, state, src_format);
659
660 trace_dump_struct_end();
661 }
662
663
664 void trace_dump_constant_buffer(const struct pipe_constant_buffer *state)
665 {
666 if (!trace_dumping_enabled_locked())
667 return;
668
669 if(!state) {
670 trace_dump_null();
671 return;
672 }
673
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();
679 }
680
681
682 void trace_dump_draw_info(const struct pipe_draw_info *state)
683 {
684 if (!trace_dumping_enabled_locked())
685 return;
686
687 if(!state) {
688 trace_dump_null();
689 return;
690 }
691
692 trace_dump_struct_begin("pipe_draw_info");
693
694 trace_dump_member(bool, state, indexed);
695
696 trace_dump_member(uint, state, mode);
697 trace_dump_member(uint, state, start);
698 trace_dump_member(uint, state, count);
699
700 trace_dump_member(uint, state, start_instance);
701 trace_dump_member(uint, state, instance_count);
702
703 trace_dump_member(int, state, index_bias);
704 trace_dump_member(uint, state, min_index);
705 trace_dump_member(uint, state, max_index);
706
707 trace_dump_member(bool, state, primitive_restart);
708 trace_dump_member(uint, state, restart_index);
709
710 trace_dump_member(ptr, state, count_from_stream_output);
711
712 trace_dump_struct_end();
713 }
714
715 void trace_dump_blit_info(const struct pipe_blit_info *info)
716 {
717 char mask[7];
718
719 if (!trace_dumping_enabled_locked())
720 return;
721
722 if (!info) {
723 trace_dump_null();
724 return;
725 }
726
727 trace_dump_struct_begin("pipe_blit_info");
728
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();
739
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();
750
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' : '-';
757 mask[6] = 0;
758
759 trace_dump_member_begin("mask");
760 trace_dump_string(mask);
761 trace_dump_member_end();
762 trace_dump_member(uint, info, filter);
763
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();
768
769 trace_dump_struct_end();
770 }
771
772 void
773 trace_dump_query_result(unsigned query_type,
774 const union pipe_query_result *result)
775 {
776 if (!trace_dumping_enabled_locked())
777 return;
778
779 if (!result) {
780 trace_dump_null();
781 return;
782 }
783
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);
789 break;
790
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);
797 break;
798
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();
804 break;
805
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();
811 break;
812
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();
827 break;
828
829 default:
830 assert(query_type >= PIPE_QUERY_DRIVER_SPECIFIC);
831 trace_dump_uint(result->u64);
832 break;
833 }
834 }