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 **************************************************************************/
28 #include "util/u_memory.h"
29 #include "util/u_simple_list.h"
31 #include "tr_buffer.h"
33 #include "tr_dump_state.h"
34 #include "tr_texture.h"
35 #include "tr_screen.h"
37 #include "pipe/p_inlines.h"
38 #include "pipe/p_format.h"
41 static boolean trace
= FALSE
;
42 static boolean rbug
= FALSE
;
45 trace_screen_get_name(struct pipe_screen
*_screen
)
47 struct trace_screen
*tr_scr
= trace_screen(_screen
);
48 struct pipe_screen
*screen
= tr_scr
->screen
;
51 trace_dump_call_begin("pipe_screen", "get_name");
53 trace_dump_arg(ptr
, screen
);
55 result
= screen
->get_name(screen
);
57 trace_dump_ret(string
, result
);
59 trace_dump_call_end();
66 trace_screen_get_vendor(struct pipe_screen
*_screen
)
68 struct trace_screen
*tr_scr
= trace_screen(_screen
);
69 struct pipe_screen
*screen
= tr_scr
->screen
;
72 trace_dump_call_begin("pipe_screen", "get_vendor");
74 trace_dump_arg(ptr
, screen
);
76 result
= screen
->get_vendor(screen
);
78 trace_dump_ret(string
, result
);
80 trace_dump_call_end();
87 trace_screen_get_param(struct pipe_screen
*_screen
,
90 struct trace_screen
*tr_scr
= trace_screen(_screen
);
91 struct pipe_screen
*screen
= tr_scr
->screen
;
94 trace_dump_call_begin("pipe_screen", "get_param");
96 trace_dump_arg(ptr
, screen
);
97 trace_dump_arg(int, param
);
99 result
= screen
->get_param(screen
, param
);
101 trace_dump_ret(int, result
);
103 trace_dump_call_end();
110 trace_screen_get_paramf(struct pipe_screen
*_screen
,
113 struct trace_screen
*tr_scr
= trace_screen(_screen
);
114 struct pipe_screen
*screen
= tr_scr
->screen
;
117 trace_dump_call_begin("pipe_screen", "get_paramf");
119 trace_dump_arg(ptr
, screen
);
120 trace_dump_arg(int, param
);
122 result
= screen
->get_paramf(screen
, param
);
124 trace_dump_ret(float, result
);
126 trace_dump_call_end();
133 trace_screen_is_format_supported(struct pipe_screen
*_screen
,
134 enum pipe_format format
,
135 enum pipe_texture_target target
,
139 struct trace_screen
*tr_scr
= trace_screen(_screen
);
140 struct pipe_screen
*screen
= tr_scr
->screen
;
143 trace_dump_call_begin("pipe_screen", "is_format_supported");
145 trace_dump_arg(ptr
, screen
);
146 trace_dump_arg(format
, format
);
147 trace_dump_arg(int, target
);
148 trace_dump_arg(uint
, tex_usage
);
149 trace_dump_arg(uint
, geom_flags
);
151 result
= screen
->is_format_supported(screen
, format
, target
, tex_usage
, geom_flags
);
153 trace_dump_ret(bool, result
);
155 trace_dump_call_end();
162 trace_screen_flush_frontbuffer(struct pipe_screen
*_screen
,
163 struct pipe_surface
*_surface
,
164 void *context_private
)
166 struct trace_screen
*tr_scr
= trace_screen(_screen
);
167 struct trace_surface
*tr_surf
= trace_surface(_surface
);
168 struct pipe_screen
*screen
= tr_scr
->screen
;
169 struct pipe_surface
*surface
= tr_surf
->surface
;
171 trace_dump_call_begin("pipe_screen", "flush_frontbuffer");
173 trace_dump_arg(ptr
, screen
);
174 trace_dump_arg(ptr
, surface
);
175 /* XXX: hide, as there is nothing we can do with this
176 trace_dump_arg(ptr, context_private);
179 screen
->flush_frontbuffer(screen
, surface
, context_private
);
181 trace_dump_call_end();
185 /********************************************************************
190 static struct pipe_texture
*
191 trace_screen_texture_create(struct pipe_screen
*_screen
,
192 const struct pipe_texture
*templat
)
194 struct trace_screen
*tr_scr
= trace_screen(_screen
);
195 struct pipe_screen
*screen
= tr_scr
->screen
;
196 struct pipe_texture
*result
;
198 trace_dump_call_begin("pipe_screen", "texture_create");
200 trace_dump_arg(ptr
, screen
);
201 trace_dump_arg(template, templat
);
203 result
= screen
->texture_create(screen
, templat
);
205 trace_dump_ret(ptr
, result
);
207 trace_dump_call_end();
209 result
= trace_texture_create(tr_scr
, result
);
215 static struct pipe_texture
*
216 trace_screen_texture_blanket(struct pipe_screen
*_screen
,
217 const struct pipe_texture
*templat
,
218 const unsigned *ppitch
,
219 struct pipe_buffer
*_buffer
)
221 struct trace_screen
*tr_scr
= trace_screen(_screen
);
222 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
223 struct pipe_screen
*screen
= tr_scr
->screen
;
224 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
225 unsigned pitch
= *ppitch
;
226 struct pipe_texture
*result
;
228 trace_dump_call_begin("pipe_screen", "texture_blanket");
230 trace_dump_arg(ptr
, screen
);
231 trace_dump_arg(template, templat
);
232 trace_dump_arg(uint
, pitch
);
233 trace_dump_arg(ptr
, buffer
);
235 result
= screen
->texture_blanket(screen
, templat
, ppitch
, buffer
);
237 trace_dump_ret(ptr
, result
);
239 trace_dump_call_end();
241 result
= trace_texture_create(tr_scr
, result
);
248 trace_screen_texture_destroy(struct pipe_texture
*_texture
)
250 struct trace_screen
*tr_scr
= trace_screen(_texture
->screen
);
251 struct trace_texture
*tr_tex
= trace_texture(_texture
);
252 struct pipe_screen
*screen
= tr_scr
->screen
;
253 struct pipe_texture
*texture
= tr_tex
->texture
;
255 assert(texture
->screen
== screen
);
257 trace_dump_call_begin("pipe_screen", "texture_destroy");
259 trace_dump_arg(ptr
, screen
);
260 trace_dump_arg(ptr
, texture
);
262 trace_dump_call_end();
264 trace_texture_destroy(tr_tex
);
268 /********************************************************************
273 static struct pipe_surface
*
274 trace_screen_get_tex_surface(struct pipe_screen
*_screen
,
275 struct pipe_texture
*_texture
,
276 unsigned face
, unsigned level
,
280 struct trace_screen
*tr_scr
= trace_screen(_screen
);
281 struct trace_texture
*tr_tex
= trace_texture(_texture
);
282 struct pipe_screen
*screen
= tr_scr
->screen
;
283 struct pipe_texture
*texture
= tr_tex
->texture
;
284 struct pipe_surface
*result
= NULL
;
286 assert(texture
->screen
== screen
);
288 trace_dump_call_begin("pipe_screen", "get_tex_surface");
290 trace_dump_arg(ptr
, screen
);
291 trace_dump_arg(ptr
, texture
);
292 trace_dump_arg(uint
, face
);
293 trace_dump_arg(uint
, level
);
294 trace_dump_arg(uint
, zslice
);
295 trace_dump_arg(uint
, usage
);
297 result
= screen
->get_tex_surface(screen
, texture
, face
, level
, zslice
, usage
);
299 trace_dump_ret(ptr
, result
);
301 trace_dump_call_end();
303 result
= trace_surface_create(tr_tex
, result
);
310 trace_screen_tex_surface_destroy(struct pipe_surface
*_surface
)
312 struct trace_screen
*tr_scr
= trace_screen(_surface
->texture
->screen
);
313 struct trace_surface
*tr_surf
= trace_surface(_surface
);
314 struct pipe_screen
*screen
= tr_scr
->screen
;
315 struct pipe_surface
*surface
= tr_surf
->surface
;
317 trace_dump_call_begin("pipe_screen", "tex_surface_destroy");
319 trace_dump_arg(ptr
, screen
);
320 trace_dump_arg(ptr
, surface
);
322 trace_dump_call_end();
324 trace_surface_destroy(tr_surf
);
328 /********************************************************************
333 static struct pipe_transfer
*
334 trace_screen_get_tex_transfer(struct pipe_screen
*_screen
,
335 struct pipe_texture
*_texture
,
336 unsigned face
, unsigned level
,
338 enum pipe_transfer_usage usage
,
339 unsigned x
, unsigned y
, unsigned w
, unsigned h
)
341 struct trace_screen
*tr_scr
= trace_screen(_screen
);
342 struct trace_texture
*tr_tex
= trace_texture(_texture
);
343 struct pipe_screen
*screen
= tr_scr
->screen
;
344 struct pipe_texture
*texture
= tr_tex
->texture
;
345 struct pipe_transfer
*result
= NULL
;
347 assert(texture
->screen
== screen
);
349 trace_dump_call_begin("pipe_screen", "get_tex_transfer");
351 trace_dump_arg(ptr
, screen
);
352 trace_dump_arg(ptr
, texture
);
353 trace_dump_arg(uint
, face
);
354 trace_dump_arg(uint
, level
);
355 trace_dump_arg(uint
, zslice
);
356 trace_dump_arg(uint
, usage
);
358 trace_dump_arg(uint
, x
);
359 trace_dump_arg(uint
, y
);
360 trace_dump_arg(uint
, w
);
361 trace_dump_arg(uint
, h
);
363 result
= screen
->get_tex_transfer(screen
, texture
, face
, level
, zslice
, usage
,
366 trace_dump_ret(ptr
, result
);
368 trace_dump_call_end();
371 result
= trace_transfer_create(tr_tex
, result
);
378 trace_screen_tex_transfer_destroy(struct pipe_transfer
*_transfer
)
380 struct trace_screen
*tr_scr
= trace_screen(_transfer
->texture
->screen
);
381 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
382 struct pipe_screen
*screen
= tr_scr
->screen
;
383 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
385 trace_dump_call_begin("pipe_screen", "tex_transfer_destroy");
387 trace_dump_arg(ptr
, screen
);
388 trace_dump_arg(ptr
, transfer
);
390 trace_dump_call_end();
392 trace_transfer_destroy(tr_trans
);
397 trace_screen_transfer_map(struct pipe_screen
*_screen
,
398 struct pipe_transfer
*_transfer
)
400 struct trace_screen
*tr_scr
= trace_screen(_screen
);
401 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
402 struct pipe_screen
*screen
= tr_scr
->screen
;
403 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
406 map
= screen
->transfer_map(screen
, transfer
);
408 if(transfer
->usage
& PIPE_TRANSFER_WRITE
) {
409 assert(!tr_trans
->map
);
419 trace_screen_transfer_unmap(struct pipe_screen
*_screen
,
420 struct pipe_transfer
*_transfer
)
422 struct trace_screen
*tr_scr
= trace_screen(_screen
);
423 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
424 struct pipe_screen
*screen
= tr_scr
->screen
;
425 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
428 size_t size
= pf_get_nblocksy(transfer
->texture
->format
, transfer
->width
) * transfer
->stride
;
430 trace_dump_call_begin("pipe_screen", "transfer_write");
432 trace_dump_arg(ptr
, screen
);
434 trace_dump_arg(ptr
, transfer
);
436 trace_dump_arg_begin("stride");
437 trace_dump_uint(transfer
->stride
);
438 trace_dump_arg_end();
440 trace_dump_arg_begin("data");
441 trace_dump_bytes(tr_trans
->map
, size
);
442 trace_dump_arg_end();
444 trace_dump_arg_begin("size");
445 trace_dump_uint(size
);
446 trace_dump_arg_end();
448 trace_dump_call_end();
450 tr_trans
->map
= NULL
;
453 screen
->transfer_unmap(screen
, transfer
);
457 /********************************************************************
462 static struct pipe_buffer
*
463 trace_screen_surface_buffer_create(struct pipe_screen
*_screen
,
464 unsigned width
, unsigned height
,
465 enum pipe_format format
,
470 struct trace_screen
*tr_scr
= trace_screen(_screen
);
471 struct pipe_screen
*screen
= tr_scr
->screen
;
473 struct pipe_buffer
*result
;
475 trace_dump_call_begin("pipe_screen", "surface_buffer_create");
477 trace_dump_arg(ptr
, screen
);
478 trace_dump_arg(uint
, width
);
479 trace_dump_arg(uint
, height
);
480 trace_dump_arg(format
, format
);
481 trace_dump_arg(uint
, usage
);
482 trace_dump_arg(uint
, tex_usage
);
484 result
= screen
->surface_buffer_create(screen
,
493 trace_dump_arg(uint
, stride
);
495 trace_dump_ret(ptr
, result
);
497 trace_dump_call_end();
499 return trace_buffer_create(tr_scr
, result
);
503 static struct pipe_buffer
*
504 trace_screen_buffer_create(struct pipe_screen
*_screen
,
509 struct trace_screen
*tr_scr
= trace_screen(_screen
);
510 struct pipe_screen
*screen
= tr_scr
->screen
;
511 struct pipe_buffer
*result
;
513 trace_dump_call_begin("pipe_screen", "buffer_create");
515 trace_dump_arg(ptr
, screen
);
516 trace_dump_arg(uint
, alignment
);
517 trace_dump_arg(uint
, usage
);
518 trace_dump_arg(uint
, size
);
520 result
= screen
->buffer_create(screen
, alignment
, usage
, size
);
522 trace_dump_ret(ptr
, result
);
524 trace_dump_call_end();
526 /* Zero the buffer to avoid dumping uninitialized memory */
527 if(result
->usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
529 map
= pipe_buffer_map(screen
, result
, PIPE_BUFFER_USAGE_CPU_WRITE
);
531 memset(map
, 0, result
->size
);
532 screen
->buffer_unmap(screen
, result
);
536 return trace_buffer_create(tr_scr
, result
);
540 static struct pipe_buffer
*
541 trace_screen_user_buffer_create(struct pipe_screen
*_screen
,
545 struct trace_screen
*tr_scr
= trace_screen(_screen
);
546 struct pipe_screen
*screen
= tr_scr
->screen
;
547 struct pipe_buffer
*result
;
549 trace_dump_call_begin("pipe_screen", "user_buffer_create");
551 trace_dump_arg(ptr
, screen
);
552 trace_dump_arg_begin("data");
553 trace_dump_bytes(data
, size
);
554 trace_dump_arg_end();
555 trace_dump_arg(uint
, size
);
557 result
= screen
->user_buffer_create(screen
, data
, size
);
559 trace_dump_ret(ptr
, result
);
561 trace_dump_call_end();
564 assert(!(result
->usage
& TRACE_BUFFER_USAGE_USER
));
565 result
->usage
|= TRACE_BUFFER_USAGE_USER
;
568 return trace_buffer_create(tr_scr
, result
);
573 * This function is used to track if data has been changed on a user buffer
574 * without map/unmap being called.
577 trace_screen_user_buffer_update(struct pipe_screen
*_screen
,
578 struct pipe_buffer
*_buffer
)
581 struct trace_screen
*tr_scr
= trace_screen(_screen
);
582 struct pipe_screen
*screen
= tr_scr
->screen
;
585 if(buffer
&& buffer
->usage
& TRACE_BUFFER_USAGE_USER
) {
586 map
= screen
->buffer_map(screen
, buffer
, PIPE_BUFFER_USAGE_CPU_READ
);
588 trace_dump_call_begin("pipe_winsys", "buffer_write");
590 trace_dump_arg(ptr
, screen
);
592 trace_dump_arg(ptr
, buffer
);
594 trace_dump_arg_begin("data");
595 trace_dump_bytes(map
, buffer
->size
);
596 trace_dump_arg_end();
598 trace_dump_arg_begin("size");
599 trace_dump_uint(buffer
->size
);
600 trace_dump_arg_end();
602 trace_dump_call_end();
604 screen
->buffer_unmap(screen
, buffer
);
612 trace_screen_buffer_map(struct pipe_screen
*_screen
,
613 struct pipe_buffer
*_buffer
,
616 struct trace_screen
*tr_scr
= trace_screen(_screen
);
617 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
618 struct pipe_screen
*screen
= tr_scr
->screen
;
619 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
622 assert(screen
->buffer_map
);
623 map
= screen
->buffer_map(screen
, buffer
, usage
);
625 if(usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
635 trace_screen_buffer_map_range(struct pipe_screen
*_screen
,
636 struct pipe_buffer
*_buffer
,
641 struct trace_screen
*tr_scr
= trace_screen(_screen
);
642 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
643 struct pipe_screen
*screen
= tr_scr
->screen
;
644 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
647 assert(screen
->buffer_map_range
);
648 map
= screen
->buffer_map_range(screen
, buffer
, offset
, length
, usage
);
650 if(usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
660 buffer_write(struct pipe_screen
*screen
,
661 struct pipe_buffer
*buffer
,
668 trace_dump_call_begin("pipe_screen", "buffer_write");
670 trace_dump_arg(ptr
, screen
);
672 trace_dump_arg(ptr
, buffer
);
674 trace_dump_arg(uint
, offset
);
676 trace_dump_arg_begin("data");
677 trace_dump_bytes(map
+ offset
, size
);
678 trace_dump_arg_end();
680 trace_dump_arg(uint
, size
);
682 trace_dump_call_end();
688 trace_screen_buffer_flush_mapped_range(struct pipe_screen
*_screen
,
689 struct pipe_buffer
*_buffer
,
693 struct trace_screen
*tr_scr
= trace_screen(_screen
);
694 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
695 struct pipe_screen
*screen
= tr_scr
->screen
;
696 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
699 buffer_write(screen
, buffer
, offset
, tr_buf
->map
, length
);
700 tr_buf
->range_flushed
= TRUE
;
701 screen
->buffer_flush_mapped_range(screen
, buffer
, offset
, length
);
706 trace_screen_buffer_unmap(struct pipe_screen
*_screen
,
707 struct pipe_buffer
*_buffer
)
709 struct trace_screen
*tr_scr
= trace_screen(_screen
);
710 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
711 struct pipe_screen
*screen
= tr_scr
->screen
;
712 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
714 if (tr_buf
->map
&& !tr_buf
->range_flushed
)
715 buffer_write(screen
, buffer
, 0, tr_buf
->map
, buffer
->size
);
717 tr_buf
->range_flushed
= FALSE
;
718 screen
->buffer_unmap(screen
, buffer
);
723 trace_screen_buffer_destroy(struct pipe_buffer
*_buffer
)
725 struct trace_screen
*tr_scr
= trace_screen(_buffer
->screen
);
726 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
727 struct pipe_screen
*screen
= tr_scr
->screen
;
728 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
730 trace_dump_call_begin("pipe_screen", "buffer_destroy");
732 trace_dump_arg(ptr
, screen
);
733 trace_dump_arg(ptr
, buffer
);
735 trace_dump_call_end();
737 trace_buffer_destroy(tr_scr
, _buffer
);
741 /********************************************************************
747 trace_screen_fence_reference(struct pipe_screen
*_screen
,
748 struct pipe_fence_handle
**pdst
,
749 struct pipe_fence_handle
*src
)
751 struct trace_screen
*tr_scr
= trace_screen(_screen
);
752 struct pipe_screen
*screen
= tr_scr
->screen
;
753 struct pipe_fence_handle
*dst
;
758 trace_dump_call_begin("pipe_screen", "fence_reference");
760 trace_dump_arg(ptr
, screen
);
761 trace_dump_arg(ptr
, dst
);
762 trace_dump_arg(ptr
, src
);
764 screen
->fence_reference(screen
, pdst
, src
);
766 trace_dump_call_end();
771 trace_screen_fence_signalled(struct pipe_screen
*_screen
,
772 struct pipe_fence_handle
*fence
,
775 struct trace_screen
*tr_scr
= trace_screen(_screen
);
776 struct pipe_screen
*screen
= tr_scr
->screen
;
779 trace_dump_call_begin("pipe_screen", "fence_signalled");
781 trace_dump_arg(ptr
, screen
);
782 trace_dump_arg(ptr
, fence
);
783 trace_dump_arg(uint
, flags
);
785 result
= screen
->fence_signalled(screen
, fence
, flags
);
787 trace_dump_ret(int, result
);
789 trace_dump_call_end();
796 trace_screen_fence_finish(struct pipe_screen
*_screen
,
797 struct pipe_fence_handle
*fence
,
800 struct trace_screen
*tr_scr
= trace_screen(_screen
);
801 struct pipe_screen
*screen
= tr_scr
->screen
;
804 trace_dump_call_begin("pipe_screen", "fence_finish");
806 trace_dump_arg(ptr
, screen
);
807 trace_dump_arg(ptr
, fence
);
808 trace_dump_arg(uint
, flags
);
810 result
= screen
->fence_finish(screen
, fence
, flags
);
812 trace_dump_ret(int, result
);
814 trace_dump_call_end();
820 /********************************************************************
825 trace_screen_destroy(struct pipe_screen
*_screen
)
827 struct trace_screen
*tr_scr
= trace_screen(_screen
);
828 struct pipe_screen
*screen
= tr_scr
->screen
;
830 trace_dump_call_begin("pipe_screen", "destroy");
831 trace_dump_arg(ptr
, screen
);
832 trace_dump_call_end();
833 trace_dump_trace_end();
836 trace_rbug_stop(tr_scr
->rbug
);
838 screen
->destroy(screen
);
846 static boolean firstrun
= TRUE
;
854 if(trace_dump_trace_begin()) {
855 trace_dumping_start();
859 if (debug_get_bool_option("GALLIUM_RBUG", FALSE
)) {
868 trace_screen_create(struct pipe_screen
*screen
)
870 struct trace_screen
*tr_scr
;
871 struct pipe_winsys
*winsys
;
876 if (!trace_enabled())
879 trace_dump_call_begin("", "pipe_screen_create");
881 tr_scr
= CALLOC_STRUCT(trace_screen
);
886 winsys
= trace_winsys_create(screen
->winsys
);
890 winsys
= screen
->winsys
;
892 pipe_mutex_init(tr_scr
->list_mutex
);
893 make_empty_list(&tr_scr
->buffers
);
894 make_empty_list(&tr_scr
->contexts
);
895 make_empty_list(&tr_scr
->textures
);
896 make_empty_list(&tr_scr
->surfaces
);
897 make_empty_list(&tr_scr
->transfers
);
899 tr_scr
->base
.winsys
= winsys
;
900 tr_scr
->base
.destroy
= trace_screen_destroy
;
901 tr_scr
->base
.get_name
= trace_screen_get_name
;
902 tr_scr
->base
.get_vendor
= trace_screen_get_vendor
;
903 tr_scr
->base
.get_param
= trace_screen_get_param
;
904 tr_scr
->base
.get_paramf
= trace_screen_get_paramf
;
905 tr_scr
->base
.is_format_supported
= trace_screen_is_format_supported
;
906 tr_scr
->base
.texture_create
= trace_screen_texture_create
;
907 tr_scr
->base
.texture_blanket
= trace_screen_texture_blanket
;
908 tr_scr
->base
.texture_destroy
= trace_screen_texture_destroy
;
909 tr_scr
->base
.get_tex_surface
= trace_screen_get_tex_surface
;
910 tr_scr
->base
.tex_surface_destroy
= trace_screen_tex_surface_destroy
;
911 tr_scr
->base
.get_tex_transfer
= trace_screen_get_tex_transfer
;
912 tr_scr
->base
.tex_transfer_destroy
= trace_screen_tex_transfer_destroy
;
913 tr_scr
->base
.transfer_map
= trace_screen_transfer_map
;
914 tr_scr
->base
.transfer_unmap
= trace_screen_transfer_unmap
;
915 tr_scr
->base
.buffer_create
= trace_screen_buffer_create
;
916 tr_scr
->base
.user_buffer_create
= trace_screen_user_buffer_create
;
917 tr_scr
->base
.surface_buffer_create
= trace_screen_surface_buffer_create
;
918 if (screen
->buffer_map
)
919 tr_scr
->base
.buffer_map
= trace_screen_buffer_map
;
920 if (screen
->buffer_map_range
)
921 tr_scr
->base
.buffer_map_range
= trace_screen_buffer_map_range
;
922 if (screen
->buffer_flush_mapped_range
)
923 tr_scr
->base
.buffer_flush_mapped_range
= trace_screen_buffer_flush_mapped_range
;
924 if (screen
->buffer_unmap
)
925 tr_scr
->base
.buffer_unmap
= trace_screen_buffer_unmap
;
926 tr_scr
->base
.buffer_destroy
= trace_screen_buffer_destroy
;
927 tr_scr
->base
.fence_reference
= trace_screen_fence_reference
;
928 tr_scr
->base
.fence_signalled
= trace_screen_fence_signalled
;
929 tr_scr
->base
.fence_finish
= trace_screen_fence_finish
;
930 tr_scr
->base
.flush_frontbuffer
= trace_screen_flush_frontbuffer
;
931 tr_scr
->screen
= screen
;
933 trace_dump_ret(ptr
, screen
);
934 trace_dump_call_end();
937 tr_scr
->rbug
= trace_rbug_start(tr_scr
);
939 return &tr_scr
->base
;
946 trace_dump_ret(ptr
, screen
);
947 trace_dump_call_end();
948 trace_dump_trace_end();
954 struct trace_screen
*
955 trace_screen(struct pipe_screen
*screen
)
958 assert(screen
->destroy
== trace_screen_destroy
);
959 return (struct trace_screen
*)screen
;