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"
40 static boolean trace
= FALSE
;
43 trace_screen_get_name(struct pipe_screen
*_screen
)
45 struct trace_screen
*tr_scr
= trace_screen(_screen
);
46 struct pipe_screen
*screen
= tr_scr
->screen
;
49 trace_dump_call_begin("pipe_screen", "get_name");
51 trace_dump_arg(ptr
, screen
);
53 result
= screen
->get_name(screen
);
55 trace_dump_ret(string
, result
);
57 trace_dump_call_end();
64 trace_screen_get_vendor(struct pipe_screen
*_screen
)
66 struct trace_screen
*tr_scr
= trace_screen(_screen
);
67 struct pipe_screen
*screen
= tr_scr
->screen
;
70 trace_dump_call_begin("pipe_screen", "get_vendor");
72 trace_dump_arg(ptr
, screen
);
74 result
= screen
->get_vendor(screen
);
76 trace_dump_ret(string
, result
);
78 trace_dump_call_end();
85 trace_screen_get_param(struct pipe_screen
*_screen
,
88 struct trace_screen
*tr_scr
= trace_screen(_screen
);
89 struct pipe_screen
*screen
= tr_scr
->screen
;
92 trace_dump_call_begin("pipe_screen", "get_param");
94 trace_dump_arg(ptr
, screen
);
95 trace_dump_arg(int, param
);
97 result
= screen
->get_param(screen
, param
);
99 trace_dump_ret(int, result
);
101 trace_dump_call_end();
108 trace_screen_get_paramf(struct pipe_screen
*_screen
,
111 struct trace_screen
*tr_scr
= trace_screen(_screen
);
112 struct pipe_screen
*screen
= tr_scr
->screen
;
115 trace_dump_call_begin("pipe_screen", "get_paramf");
117 trace_dump_arg(ptr
, screen
);
118 trace_dump_arg(int, param
);
120 result
= screen
->get_paramf(screen
, param
);
122 trace_dump_ret(float, result
);
124 trace_dump_call_end();
131 trace_screen_is_format_supported(struct pipe_screen
*_screen
,
132 enum pipe_format format
,
133 enum pipe_texture_target target
,
137 struct trace_screen
*tr_scr
= trace_screen(_screen
);
138 struct pipe_screen
*screen
= tr_scr
->screen
;
141 trace_dump_call_begin("pipe_screen", "is_format_supported");
143 trace_dump_arg(ptr
, screen
);
144 trace_dump_arg(format
, format
);
145 trace_dump_arg(int, target
);
146 trace_dump_arg(uint
, tex_usage
);
147 trace_dump_arg(uint
, geom_flags
);
149 result
= screen
->is_format_supported(screen
, format
, target
, tex_usage
, geom_flags
);
151 trace_dump_ret(bool, result
);
153 trace_dump_call_end();
160 trace_screen_flush_frontbuffer(struct pipe_screen
*_screen
,
161 struct pipe_surface
*_surface
,
162 void *context_private
)
164 struct trace_screen
*tr_scr
= trace_screen(_screen
);
165 struct trace_surface
*tr_surf
= trace_surface(_surface
);
166 struct pipe_screen
*screen
= tr_scr
->screen
;
167 struct pipe_surface
*surface
= tr_surf
->surface
;
169 trace_dump_call_begin("pipe_screen", "flush_frontbuffer");
171 trace_dump_arg(ptr
, screen
);
172 trace_dump_arg(ptr
, surface
);
173 /* XXX: hide, as there is nothing we can do with this
174 trace_dump_arg(ptr, context_private);
177 screen
->flush_frontbuffer(screen
, surface
, context_private
);
179 trace_dump_call_end();
183 /********************************************************************
188 static struct pipe_texture
*
189 trace_screen_texture_create(struct pipe_screen
*_screen
,
190 const struct pipe_texture
*templat
)
192 struct trace_screen
*tr_scr
= trace_screen(_screen
);
193 struct pipe_screen
*screen
= tr_scr
->screen
;
194 struct pipe_texture
*result
;
196 trace_dump_call_begin("pipe_screen", "texture_create");
198 trace_dump_arg(ptr
, screen
);
199 trace_dump_arg(template, templat
);
201 result
= screen
->texture_create(screen
, templat
);
203 trace_dump_ret(ptr
, result
);
205 trace_dump_call_end();
207 result
= trace_texture_create(tr_scr
, result
);
213 static struct pipe_texture
*
214 trace_screen_texture_blanket(struct pipe_screen
*_screen
,
215 const struct pipe_texture
*templat
,
216 const unsigned *ppitch
,
217 struct pipe_buffer
*_buffer
)
219 struct trace_screen
*tr_scr
= trace_screen(_screen
);
220 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
221 struct pipe_screen
*screen
= tr_scr
->screen
;
222 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
223 unsigned pitch
= *ppitch
;
224 struct pipe_texture
*result
;
226 trace_dump_call_begin("pipe_screen", "texture_blanket");
228 trace_dump_arg(ptr
, screen
);
229 trace_dump_arg(template, templat
);
230 trace_dump_arg(uint
, pitch
);
231 trace_dump_arg(ptr
, buffer
);
233 result
= screen
->texture_blanket(screen
, templat
, ppitch
, buffer
);
235 trace_dump_ret(ptr
, result
);
237 trace_dump_call_end();
239 result
= trace_texture_create(tr_scr
, result
);
246 trace_screen_texture_destroy(struct pipe_texture
*_texture
)
248 struct trace_screen
*tr_scr
= trace_screen(_texture
->screen
);
249 struct trace_texture
*tr_tex
= trace_texture(_texture
);
250 struct pipe_screen
*screen
= tr_scr
->screen
;
251 struct pipe_texture
*texture
= tr_tex
->texture
;
253 assert(texture
->screen
== screen
);
255 trace_dump_call_begin("pipe_screen", "texture_destroy");
257 trace_dump_arg(ptr
, screen
);
258 trace_dump_arg(ptr
, texture
);
260 trace_dump_call_end();
262 trace_texture_destroy(tr_tex
);
266 /********************************************************************
271 static struct pipe_surface
*
272 trace_screen_get_tex_surface(struct pipe_screen
*_screen
,
273 struct pipe_texture
*_texture
,
274 unsigned face
, unsigned level
,
278 struct trace_screen
*tr_scr
= trace_screen(_screen
);
279 struct trace_texture
*tr_tex
= trace_texture(_texture
);
280 struct pipe_screen
*screen
= tr_scr
->screen
;
281 struct pipe_texture
*texture
= tr_tex
->texture
;
282 struct pipe_surface
*result
= NULL
;
284 assert(texture
->screen
== screen
);
286 trace_dump_call_begin("pipe_screen", "get_tex_surface");
288 trace_dump_arg(ptr
, screen
);
289 trace_dump_arg(ptr
, texture
);
290 trace_dump_arg(uint
, face
);
291 trace_dump_arg(uint
, level
);
292 trace_dump_arg(uint
, zslice
);
293 trace_dump_arg(uint
, usage
);
295 result
= screen
->get_tex_surface(screen
, texture
, face
, level
, zslice
, usage
);
297 trace_dump_ret(ptr
, result
);
299 trace_dump_call_end();
301 result
= trace_surface_create(tr_tex
, result
);
308 trace_screen_tex_surface_destroy(struct pipe_surface
*_surface
)
310 struct trace_screen
*tr_scr
= trace_screen(_surface
->texture
->screen
);
311 struct trace_surface
*tr_surf
= trace_surface(_surface
);
312 struct pipe_screen
*screen
= tr_scr
->screen
;
313 struct pipe_surface
*surface
= tr_surf
->surface
;
315 trace_dump_call_begin("pipe_screen", "tex_surface_destroy");
317 trace_dump_arg(ptr
, screen
);
318 trace_dump_arg(ptr
, surface
);
320 trace_dump_call_end();
322 trace_surface_destroy(tr_surf
);
326 /********************************************************************
331 static struct pipe_transfer
*
332 trace_screen_get_tex_transfer(struct pipe_screen
*_screen
,
333 struct pipe_texture
*_texture
,
334 unsigned face
, unsigned level
,
336 enum pipe_transfer_usage usage
,
337 unsigned x
, unsigned y
, unsigned w
, unsigned h
)
339 struct trace_screen
*tr_scr
= trace_screen(_screen
);
340 struct trace_texture
*tr_tex
= trace_texture(_texture
);
341 struct pipe_screen
*screen
= tr_scr
->screen
;
342 struct pipe_texture
*texture
= tr_tex
->texture
;
343 struct pipe_transfer
*result
= NULL
;
345 assert(texture
->screen
== screen
);
347 trace_dump_call_begin("pipe_screen", "get_tex_transfer");
349 trace_dump_arg(ptr
, screen
);
350 trace_dump_arg(ptr
, texture
);
351 trace_dump_arg(uint
, face
);
352 trace_dump_arg(uint
, level
);
353 trace_dump_arg(uint
, zslice
);
354 trace_dump_arg(uint
, usage
);
356 trace_dump_arg(uint
, x
);
357 trace_dump_arg(uint
, y
);
358 trace_dump_arg(uint
, w
);
359 trace_dump_arg(uint
, h
);
361 result
= screen
->get_tex_transfer(screen
, texture
, face
, level
, zslice
, usage
,
364 trace_dump_ret(ptr
, result
);
366 trace_dump_call_end();
368 result
= trace_transfer_create(tr_tex
, result
);
375 trace_screen_tex_transfer_destroy(struct pipe_transfer
*_transfer
)
377 struct trace_screen
*tr_scr
= trace_screen(_transfer
->texture
->screen
);
378 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
379 struct pipe_screen
*screen
= tr_scr
->screen
;
380 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
382 trace_dump_call_begin("pipe_screen", "tex_transfer_destroy");
384 trace_dump_arg(ptr
, screen
);
385 trace_dump_arg(ptr
, transfer
);
387 trace_dump_call_end();
389 trace_transfer_destroy(tr_trans
);
394 trace_screen_transfer_map(struct pipe_screen
*_screen
,
395 struct pipe_transfer
*_transfer
)
397 struct trace_screen
*tr_scr
= trace_screen(_screen
);
398 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
399 struct pipe_screen
*screen
= tr_scr
->screen
;
400 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
403 map
= screen
->transfer_map(screen
, transfer
);
405 if(transfer
->usage
!= PIPE_TRANSFER_READ
) {
406 assert(!tr_trans
->map
);
416 trace_screen_transfer_unmap(struct pipe_screen
*_screen
,
417 struct pipe_transfer
*_transfer
)
419 struct trace_screen
*tr_scr
= trace_screen(_screen
);
420 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
421 struct pipe_screen
*screen
= tr_scr
->screen
;
422 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
425 size_t size
= transfer
->nblocksy
* transfer
->stride
;
427 trace_dump_call_begin("pipe_screen", "transfer_write");
429 trace_dump_arg(ptr
, screen
);
431 trace_dump_arg(ptr
, transfer
);
433 trace_dump_arg_begin("stride");
434 trace_dump_uint(transfer
->stride
);
435 trace_dump_arg_end();
437 trace_dump_arg_begin("data");
438 trace_dump_bytes(tr_trans
->map
, size
);
439 trace_dump_arg_end();
441 trace_dump_arg_begin("size");
442 trace_dump_uint(size
);
443 trace_dump_arg_end();
445 trace_dump_call_end();
447 tr_trans
->map
= NULL
;
450 screen
->transfer_unmap(screen
, transfer
);
454 /********************************************************************
459 static struct pipe_buffer
*
460 trace_screen_surface_buffer_create(struct pipe_screen
*_screen
,
461 unsigned width
, unsigned height
,
462 enum pipe_format format
,
466 struct trace_screen
*tr_scr
= trace_screen(_screen
);
467 struct pipe_screen
*screen
= tr_scr
->screen
;
469 struct pipe_buffer
*result
;
471 trace_dump_call_begin("pipe_screen", "surface_buffer_create");
473 trace_dump_arg(ptr
, screen
);
474 trace_dump_arg(uint
, width
);
475 trace_dump_arg(uint
, height
);
476 trace_dump_arg(format
, format
);
477 trace_dump_arg(uint
, usage
);
479 result
= screen
->surface_buffer_create(screen
,
487 trace_dump_arg(uint
, stride
);
489 trace_dump_ret(ptr
, result
);
491 trace_dump_call_end();
493 return trace_buffer_create(tr_scr
, result
);
497 static struct pipe_buffer
*
498 trace_screen_buffer_create(struct pipe_screen
*_screen
,
503 struct trace_screen
*tr_scr
= trace_screen(_screen
);
504 struct pipe_screen
*screen
= tr_scr
->screen
;
505 struct pipe_buffer
*result
;
507 trace_dump_call_begin("pipe_screen", "buffer_create");
509 trace_dump_arg(ptr
, screen
);
510 trace_dump_arg(uint
, alignment
);
511 trace_dump_arg(uint
, usage
);
512 trace_dump_arg(uint
, size
);
514 result
= screen
->buffer_create(screen
, alignment
, usage
, size
);
516 trace_dump_ret(ptr
, result
);
518 trace_dump_call_end();
520 /* Zero the buffer to avoid dumping uninitialized memory */
521 if(result
->usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
523 map
= pipe_buffer_map(screen
, result
, PIPE_BUFFER_USAGE_CPU_WRITE
);
525 memset(map
, 0, result
->size
);
526 screen
->buffer_unmap(screen
, result
);
530 return trace_buffer_create(tr_scr
, result
);
534 static struct pipe_buffer
*
535 trace_screen_user_buffer_create(struct pipe_screen
*_screen
,
539 struct trace_screen
*tr_scr
= trace_screen(_screen
);
540 struct pipe_screen
*screen
= tr_scr
->screen
;
541 struct pipe_buffer
*result
;
543 trace_dump_call_begin("pipe_screen", "user_buffer_create");
545 trace_dump_arg(ptr
, screen
);
546 trace_dump_arg_begin("data");
547 trace_dump_bytes(data
, size
);
548 trace_dump_arg_end();
549 trace_dump_arg(uint
, size
);
551 result
= screen
->user_buffer_create(screen
, data
, size
);
553 trace_dump_ret(ptr
, result
);
555 trace_dump_call_end();
558 assert(!(result
->usage
& TRACE_BUFFER_USAGE_USER
));
559 result
->usage
|= TRACE_BUFFER_USAGE_USER
;
562 return trace_buffer_create(tr_scr
, result
);
567 * This function is used to track if data has been changed on a user buffer
568 * without map/unmap being called.
571 trace_screen_user_buffer_update(struct pipe_screen
*_screen
,
572 struct pipe_buffer
*_buffer
)
575 struct trace_screen
*tr_scr
= trace_screen(_screen
);
576 struct pipe_screen
*screen
= tr_scr
->screen
;
579 if(buffer
&& buffer
->usage
& TRACE_BUFFER_USAGE_USER
) {
580 map
= screen
->buffer_map(screen
, buffer
, PIPE_BUFFER_USAGE_CPU_READ
);
582 trace_dump_call_begin("pipe_winsys", "buffer_write");
584 trace_dump_arg(ptr
, screen
);
586 trace_dump_arg(ptr
, buffer
);
588 trace_dump_arg_begin("data");
589 trace_dump_bytes(map
, buffer
->size
);
590 trace_dump_arg_end();
592 trace_dump_arg_begin("size");
593 trace_dump_uint(buffer
->size
);
594 trace_dump_arg_end();
596 trace_dump_call_end();
598 screen
->buffer_unmap(screen
, buffer
);
606 trace_screen_buffer_map(struct pipe_screen
*_screen
,
607 struct pipe_buffer
*_buffer
,
610 struct trace_screen
*tr_scr
= trace_screen(_screen
);
611 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
612 struct pipe_screen
*screen
= tr_scr
->screen
;
613 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
616 assert(screen
->buffer_map
);
617 map
= screen
->buffer_map(screen
, buffer
, usage
);
619 if(usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
629 trace_screen_buffer_map_range(struct pipe_screen
*_screen
,
630 struct pipe_buffer
*_buffer
,
635 struct trace_screen
*tr_scr
= trace_screen(_screen
);
636 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
637 struct pipe_screen
*screen
= tr_scr
->screen
;
638 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
641 assert(screen
->buffer_map_range
);
642 map
= screen
->buffer_map_range(screen
, buffer
, offset
, length
, usage
);
644 if(usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
654 buffer_write(struct pipe_screen
*screen
,
655 struct pipe_buffer
*buffer
,
662 trace_dump_call_begin("pipe_screen", "buffer_write");
664 trace_dump_arg(ptr
, screen
);
666 trace_dump_arg(ptr
, buffer
);
668 trace_dump_arg(uint
, offset
);
670 trace_dump_arg_begin("data");
671 trace_dump_bytes(map
+ offset
, size
);
672 trace_dump_arg_end();
674 trace_dump_arg(uint
, size
);
676 trace_dump_call_end();
682 trace_screen_buffer_flush_mapped_range(struct pipe_screen
*_screen
,
683 struct pipe_buffer
*_buffer
,
687 struct trace_screen
*tr_scr
= trace_screen(_screen
);
688 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
689 struct pipe_screen
*screen
= tr_scr
->screen
;
690 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
693 buffer_write(screen
, buffer
, offset
, tr_buf
->map
, length
);
694 tr_buf
->range_flushed
= TRUE
;
695 screen
->buffer_flush_mapped_range(screen
, buffer
, offset
, length
);
700 trace_screen_buffer_unmap(struct pipe_screen
*_screen
,
701 struct pipe_buffer
*_buffer
)
703 struct trace_screen
*tr_scr
= trace_screen(_screen
);
704 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
705 struct pipe_screen
*screen
= tr_scr
->screen
;
706 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
708 if (tr_buf
->map
&& !tr_buf
->range_flushed
)
709 buffer_write(screen
, buffer
, 0, tr_buf
->map
, buffer
->size
);
711 tr_buf
->range_flushed
= FALSE
;
712 screen
->buffer_unmap(screen
, buffer
);
717 trace_screen_buffer_destroy(struct pipe_buffer
*_buffer
)
719 struct trace_screen
*tr_scr
= trace_screen(_buffer
->screen
);
720 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
721 struct pipe_screen
*screen
= tr_scr
->screen
;
722 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
724 trace_dump_call_begin("pipe_screen", "buffer_destroy");
726 trace_dump_arg(ptr
, screen
);
727 trace_dump_arg(ptr
, buffer
);
729 trace_dump_call_end();
731 trace_buffer_destroy(tr_scr
, _buffer
);
735 /********************************************************************
741 trace_screen_fence_reference(struct pipe_screen
*_screen
,
742 struct pipe_fence_handle
**pdst
,
743 struct pipe_fence_handle
*src
)
745 struct trace_screen
*tr_scr
= trace_screen(_screen
);
746 struct pipe_screen
*screen
= tr_scr
->screen
;
747 struct pipe_fence_handle
*dst
;
752 trace_dump_call_begin("pipe_screen", "fence_reference");
754 trace_dump_arg(ptr
, screen
);
755 trace_dump_arg(ptr
, dst
);
756 trace_dump_arg(ptr
, src
);
758 screen
->fence_reference(screen
, pdst
, src
);
760 trace_dump_call_end();
765 trace_screen_fence_signalled(struct pipe_screen
*_screen
,
766 struct pipe_fence_handle
*fence
,
769 struct trace_screen
*tr_scr
= trace_screen(_screen
);
770 struct pipe_screen
*screen
= tr_scr
->screen
;
773 trace_dump_call_begin("pipe_screen", "fence_signalled");
775 trace_dump_arg(ptr
, screen
);
776 trace_dump_arg(ptr
, fence
);
777 trace_dump_arg(uint
, flags
);
779 result
= screen
->fence_signalled(screen
, fence
, flags
);
781 trace_dump_ret(int, result
);
783 trace_dump_call_end();
790 trace_screen_fence_finish(struct pipe_screen
*_screen
,
791 struct pipe_fence_handle
*fence
,
794 struct trace_screen
*tr_scr
= trace_screen(_screen
);
795 struct pipe_screen
*screen
= tr_scr
->screen
;
798 trace_dump_call_begin("pipe_screen", "fence_finish");
800 trace_dump_arg(ptr
, screen
);
801 trace_dump_arg(ptr
, fence
);
802 trace_dump_arg(uint
, flags
);
804 result
= screen
->fence_finish(screen
, fence
, flags
);
806 trace_dump_ret(int, result
);
808 trace_dump_call_end();
814 /********************************************************************
819 trace_screen_destroy(struct pipe_screen
*_screen
)
821 struct trace_screen
*tr_scr
= trace_screen(_screen
);
822 struct pipe_screen
*screen
= tr_scr
->screen
;
824 trace_dump_call_begin("pipe_screen", "destroy");
825 trace_dump_arg(ptr
, screen
);
826 trace_dump_call_end();
827 trace_dump_trace_end();
830 trace_rbug_stop(tr_scr
->rbug
);
832 screen
->destroy(screen
);
844 trace_screen_create(struct pipe_screen
*screen
)
846 struct trace_screen
*tr_scr
;
847 struct pipe_winsys
*winsys
;
848 boolean rbug
= FALSE
;
855 if(trace_dump_trace_begin()) {
856 trace_dumping_start();
860 if (debug_get_bool_option("GALLIUM_RBUG", FALSE
)) {
868 trace_dump_call_begin("", "pipe_screen_create");
870 tr_scr
= CALLOC_STRUCT(trace_screen
);
875 winsys
= trace_winsys_create(screen
->winsys
);
879 winsys
= screen
->winsys
;
881 pipe_mutex_init(tr_scr
->list_mutex
);
882 make_empty_list(&tr_scr
->buffers
);
883 make_empty_list(&tr_scr
->contexts
);
884 make_empty_list(&tr_scr
->textures
);
885 make_empty_list(&tr_scr
->surfaces
);
886 make_empty_list(&tr_scr
->transfers
);
888 tr_scr
->base
.winsys
= winsys
;
889 tr_scr
->base
.destroy
= trace_screen_destroy
;
890 tr_scr
->base
.get_name
= trace_screen_get_name
;
891 tr_scr
->base
.get_vendor
= trace_screen_get_vendor
;
892 tr_scr
->base
.get_param
= trace_screen_get_param
;
893 tr_scr
->base
.get_paramf
= trace_screen_get_paramf
;
894 tr_scr
->base
.is_format_supported
= trace_screen_is_format_supported
;
895 tr_scr
->base
.texture_create
= trace_screen_texture_create
;
896 tr_scr
->base
.texture_blanket
= trace_screen_texture_blanket
;
897 tr_scr
->base
.texture_destroy
= trace_screen_texture_destroy
;
898 tr_scr
->base
.get_tex_surface
= trace_screen_get_tex_surface
;
899 tr_scr
->base
.tex_surface_destroy
= trace_screen_tex_surface_destroy
;
900 tr_scr
->base
.get_tex_transfer
= trace_screen_get_tex_transfer
;
901 tr_scr
->base
.tex_transfer_destroy
= trace_screen_tex_transfer_destroy
;
902 tr_scr
->base
.transfer_map
= trace_screen_transfer_map
;
903 tr_scr
->base
.transfer_unmap
= trace_screen_transfer_unmap
;
904 tr_scr
->base
.buffer_create
= trace_screen_buffer_create
;
905 tr_scr
->base
.user_buffer_create
= trace_screen_user_buffer_create
;
906 tr_scr
->base
.surface_buffer_create
= trace_screen_surface_buffer_create
;
907 if (screen
->buffer_map
)
908 tr_scr
->base
.buffer_map
= trace_screen_buffer_map
;
909 if (screen
->buffer_map_range
)
910 tr_scr
->base
.buffer_map_range
= trace_screen_buffer_map_range
;
911 if (screen
->buffer_flush_mapped_range
)
912 tr_scr
->base
.buffer_flush_mapped_range
= trace_screen_buffer_flush_mapped_range
;
913 if (screen
->buffer_unmap
)
914 tr_scr
->base
.buffer_unmap
= trace_screen_buffer_unmap
;
915 tr_scr
->base
.buffer_destroy
= trace_screen_buffer_destroy
;
916 tr_scr
->base
.fence_reference
= trace_screen_fence_reference
;
917 tr_scr
->base
.fence_signalled
= trace_screen_fence_signalled
;
918 tr_scr
->base
.fence_finish
= trace_screen_fence_finish
;
919 tr_scr
->base
.flush_frontbuffer
= trace_screen_flush_frontbuffer
;
920 tr_scr
->screen
= screen
;
922 trace_dump_ret(ptr
, screen
);
923 trace_dump_call_end();
926 tr_scr
->rbug
= trace_rbug_start(tr_scr
);
928 return &tr_scr
->base
;
935 trace_dump_ret(ptr
, screen
);
936 trace_dump_call_end();
937 trace_dump_trace_end();
943 struct trace_screen
*
944 trace_screen(struct pipe_screen
*screen
)
947 assert(screen
->destroy
== trace_screen_destroy
);
948 return (struct trace_screen
*)screen
;