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_format.h"
29 #include "util/u_memory.h"
30 #include "util/u_simple_list.h"
32 #include "tr_buffer.h"
34 #include "tr_dump_state.h"
35 #include "tr_texture.h"
36 #include "tr_context.h"
37 #include "tr_screen.h"
39 #include "util/u_inlines.h"
40 #include "pipe/p_format.h"
43 static boolean trace
= FALSE
;
44 static boolean rbug
= FALSE
;
47 trace_screen_get_name(struct pipe_screen
*_screen
)
49 struct trace_screen
*tr_scr
= trace_screen(_screen
);
50 struct pipe_screen
*screen
= tr_scr
->screen
;
53 trace_dump_call_begin("pipe_screen", "get_name");
55 trace_dump_arg(ptr
, screen
);
57 result
= screen
->get_name(screen
);
59 trace_dump_ret(string
, result
);
61 trace_dump_call_end();
68 trace_screen_get_vendor(struct pipe_screen
*_screen
)
70 struct trace_screen
*tr_scr
= trace_screen(_screen
);
71 struct pipe_screen
*screen
= tr_scr
->screen
;
74 trace_dump_call_begin("pipe_screen", "get_vendor");
76 trace_dump_arg(ptr
, screen
);
78 result
= screen
->get_vendor(screen
);
80 trace_dump_ret(string
, result
);
82 trace_dump_call_end();
89 trace_screen_get_param(struct pipe_screen
*_screen
,
92 struct trace_screen
*tr_scr
= trace_screen(_screen
);
93 struct pipe_screen
*screen
= tr_scr
->screen
;
96 trace_dump_call_begin("pipe_screen", "get_param");
98 trace_dump_arg(ptr
, screen
);
99 trace_dump_arg(int, param
);
101 result
= screen
->get_param(screen
, param
);
103 trace_dump_ret(int, result
);
105 trace_dump_call_end();
112 trace_screen_get_paramf(struct pipe_screen
*_screen
,
115 struct trace_screen
*tr_scr
= trace_screen(_screen
);
116 struct pipe_screen
*screen
= tr_scr
->screen
;
119 trace_dump_call_begin("pipe_screen", "get_paramf");
121 trace_dump_arg(ptr
, screen
);
122 trace_dump_arg(int, param
);
124 result
= screen
->get_paramf(screen
, param
);
126 trace_dump_ret(float, result
);
128 trace_dump_call_end();
135 trace_screen_is_format_supported(struct pipe_screen
*_screen
,
136 enum pipe_format format
,
137 enum pipe_texture_target target
,
141 struct trace_screen
*tr_scr
= trace_screen(_screen
);
142 struct pipe_screen
*screen
= tr_scr
->screen
;
145 trace_dump_call_begin("pipe_screen", "is_format_supported");
147 trace_dump_arg(ptr
, screen
);
148 trace_dump_arg(format
, format
);
149 trace_dump_arg(int, target
);
150 trace_dump_arg(uint
, tex_usage
);
151 trace_dump_arg(uint
, geom_flags
);
153 result
= screen
->is_format_supported(screen
, format
, target
, tex_usage
, geom_flags
);
155 trace_dump_ret(bool, result
);
157 trace_dump_call_end();
163 static struct pipe_context
*
164 trace_screen_context_create(struct pipe_screen
*_screen
, void *priv
)
166 struct trace_screen
*tr_scr
= trace_screen(_screen
);
167 struct pipe_screen
*screen
= tr_scr
->screen
;
168 struct pipe_context
*result
;
170 trace_dump_call_begin("pipe_screen", "context_create");
172 trace_dump_arg(ptr
, screen
);
174 result
= screen
->context_create(screen
, priv
);
176 trace_dump_ret(ptr
, result
);
178 trace_dump_call_end();
180 result
= trace_context_create(tr_scr
, result
);
187 trace_screen_flush_frontbuffer(struct pipe_screen
*_screen
,
188 struct pipe_surface
*_surface
,
189 void *context_private
)
191 struct trace_screen
*tr_scr
= trace_screen(_screen
);
192 struct trace_surface
*tr_surf
= trace_surface(_surface
);
193 struct pipe_screen
*screen
= tr_scr
->screen
;
194 struct pipe_surface
*surface
= tr_surf
->surface
;
196 trace_dump_call_begin("pipe_screen", "flush_frontbuffer");
198 trace_dump_arg(ptr
, screen
);
199 trace_dump_arg(ptr
, surface
);
200 /* XXX: hide, as there is nothing we can do with this
201 trace_dump_arg(ptr, context_private);
204 screen
->flush_frontbuffer(screen
, surface
, context_private
);
206 trace_dump_call_end();
210 /********************************************************************
215 static struct pipe_texture
*
216 trace_screen_texture_create(struct pipe_screen
*_screen
,
217 const struct pipe_texture
*templat
)
219 struct trace_screen
*tr_scr
= trace_screen(_screen
);
220 struct pipe_screen
*screen
= tr_scr
->screen
;
221 struct pipe_texture
*result
;
223 trace_dump_call_begin("pipe_screen", "texture_create");
225 trace_dump_arg(ptr
, screen
);
226 trace_dump_arg(template, templat
);
228 result
= screen
->texture_create(screen
, templat
);
230 trace_dump_ret(ptr
, result
);
232 trace_dump_call_end();
234 result
= trace_texture_create(tr_scr
, result
);
239 static struct pipe_texture
*
240 trace_screen_texture_from_handle(struct pipe_screen
*_screen
,
241 const struct pipe_texture
*templ
,
242 struct winsys_handle
*handle
)
244 struct trace_screen
*tr_screen
= trace_screen(_screen
);
245 struct pipe_screen
*screen
= tr_screen
->screen
;
246 struct pipe_texture
*result
;
248 /* TODO trace call */
250 result
= screen
->texture_from_handle(screen
, templ
, handle
);
252 result
= trace_texture_create(trace_screen(_screen
), result
);
258 trace_screen_texture_get_handle(struct pipe_screen
*_screen
,
259 struct pipe_texture
*_texture
,
260 struct winsys_handle
*handle
)
262 struct trace_screen
*tr_screen
= trace_screen(_screen
);
263 struct trace_texture
*tr_texture
= trace_texture(_texture
);
264 struct pipe_screen
*screen
= tr_screen
->screen
;
265 struct pipe_texture
*texture
= tr_texture
->texture
;
267 /* TODO trace call */
269 return screen
->texture_get_handle(screen
, texture
, handle
);
272 static struct pipe_texture
*
273 trace_screen_texture_blanket(struct pipe_screen
*_screen
,
274 const struct pipe_texture
*templat
,
275 const unsigned *ppitch
,
276 struct pipe_buffer
*_buffer
)
278 struct trace_screen
*tr_scr
= trace_screen(_screen
);
279 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
280 struct pipe_screen
*screen
= tr_scr
->screen
;
281 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
282 unsigned pitch
= *ppitch
;
283 struct pipe_texture
*result
;
285 trace_dump_call_begin("pipe_screen", "texture_blanket");
287 trace_dump_arg(ptr
, screen
);
288 trace_dump_arg(template, templat
);
289 trace_dump_arg(uint
, pitch
);
290 trace_dump_arg(ptr
, buffer
);
292 result
= screen
->texture_blanket(screen
, templat
, ppitch
, buffer
);
294 trace_dump_ret(ptr
, result
);
296 trace_dump_call_end();
298 result
= trace_texture_create(tr_scr
, result
);
305 trace_screen_texture_destroy(struct pipe_texture
*_texture
)
307 struct trace_screen
*tr_scr
= trace_screen(_texture
->screen
);
308 struct trace_texture
*tr_tex
= trace_texture(_texture
);
309 struct pipe_screen
*screen
= tr_scr
->screen
;
310 struct pipe_texture
*texture
= tr_tex
->texture
;
312 assert(texture
->screen
== screen
);
314 trace_dump_call_begin("pipe_screen", "texture_destroy");
316 trace_dump_arg(ptr
, screen
);
317 trace_dump_arg(ptr
, texture
);
319 trace_dump_call_end();
321 trace_texture_destroy(tr_tex
);
325 /********************************************************************
330 static struct pipe_surface
*
331 trace_screen_get_tex_surface(struct pipe_screen
*_screen
,
332 struct pipe_texture
*_texture
,
333 unsigned face
, unsigned level
,
337 struct trace_screen
*tr_scr
= trace_screen(_screen
);
338 struct trace_texture
*tr_tex
= trace_texture(_texture
);
339 struct pipe_screen
*screen
= tr_scr
->screen
;
340 struct pipe_texture
*texture
= tr_tex
->texture
;
341 struct pipe_surface
*result
= NULL
;
343 assert(texture
->screen
== screen
);
345 trace_dump_call_begin("pipe_screen", "get_tex_surface");
347 trace_dump_arg(ptr
, screen
);
348 trace_dump_arg(ptr
, texture
);
349 trace_dump_arg(uint
, face
);
350 trace_dump_arg(uint
, level
);
351 trace_dump_arg(uint
, zslice
);
352 trace_dump_arg(uint
, usage
);
354 result
= screen
->get_tex_surface(screen
, texture
, face
, level
, zslice
, usage
);
356 trace_dump_ret(ptr
, result
);
358 trace_dump_call_end();
360 result
= trace_surface_create(tr_tex
, result
);
367 trace_screen_tex_surface_destroy(struct pipe_surface
*_surface
)
369 struct trace_screen
*tr_scr
= trace_screen(_surface
->texture
->screen
);
370 struct trace_surface
*tr_surf
= trace_surface(_surface
);
371 struct pipe_screen
*screen
= tr_scr
->screen
;
372 struct pipe_surface
*surface
= tr_surf
->surface
;
374 trace_dump_call_begin("pipe_screen", "tex_surface_destroy");
376 trace_dump_arg(ptr
, screen
);
377 trace_dump_arg(ptr
, surface
);
379 trace_dump_call_end();
381 trace_surface_destroy(tr_surf
);
385 /********************************************************************
390 static struct pipe_transfer
*
391 trace_screen_get_tex_transfer(struct pipe_screen
*_screen
,
392 struct pipe_texture
*_texture
,
393 unsigned face
, unsigned level
,
395 enum pipe_transfer_usage usage
,
396 unsigned x
, unsigned y
, unsigned w
, unsigned h
)
398 struct trace_screen
*tr_scr
= trace_screen(_screen
);
399 struct trace_texture
*tr_tex
= trace_texture(_texture
);
400 struct pipe_screen
*screen
= tr_scr
->screen
;
401 struct pipe_texture
*texture
= tr_tex
->texture
;
402 struct pipe_transfer
*result
= NULL
;
404 assert(texture
->screen
== screen
);
406 trace_dump_call_begin("pipe_screen", "get_tex_transfer");
408 trace_dump_arg(ptr
, screen
);
409 trace_dump_arg(ptr
, texture
);
410 trace_dump_arg(uint
, face
);
411 trace_dump_arg(uint
, level
);
412 trace_dump_arg(uint
, zslice
);
413 trace_dump_arg(uint
, usage
);
415 trace_dump_arg(uint
, x
);
416 trace_dump_arg(uint
, y
);
417 trace_dump_arg(uint
, w
);
418 trace_dump_arg(uint
, h
);
420 result
= screen
->get_tex_transfer(screen
, texture
, face
, level
, zslice
, usage
,
423 trace_dump_ret(ptr
, result
);
425 trace_dump_call_end();
428 result
= trace_transfer_create(tr_tex
, result
);
435 trace_screen_tex_transfer_destroy(struct pipe_transfer
*_transfer
)
437 struct trace_screen
*tr_scr
= trace_screen(_transfer
->texture
->screen
);
438 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
439 struct pipe_screen
*screen
= tr_scr
->screen
;
440 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
442 trace_dump_call_begin("pipe_screen", "tex_transfer_destroy");
444 trace_dump_arg(ptr
, screen
);
445 trace_dump_arg(ptr
, transfer
);
447 trace_dump_call_end();
449 trace_transfer_destroy(tr_trans
);
454 trace_screen_transfer_map(struct pipe_screen
*_screen
,
455 struct pipe_transfer
*_transfer
)
457 struct trace_screen
*tr_scr
= trace_screen(_screen
);
458 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
459 struct pipe_screen
*screen
= tr_scr
->screen
;
460 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
463 map
= screen
->transfer_map(screen
, transfer
);
465 if(transfer
->usage
& PIPE_TRANSFER_WRITE
) {
466 assert(!tr_trans
->map
);
476 trace_screen_transfer_unmap(struct pipe_screen
*_screen
,
477 struct pipe_transfer
*_transfer
)
479 struct trace_screen
*tr_scr
= trace_screen(_screen
);
480 struct trace_transfer
*tr_trans
= trace_transfer(_transfer
);
481 struct pipe_screen
*screen
= tr_scr
->screen
;
482 struct pipe_transfer
*transfer
= tr_trans
->transfer
;
485 size_t size
= util_format_get_nblocksy(transfer
->texture
->format
, transfer
->height
) * transfer
->stride
;
487 trace_dump_call_begin("pipe_screen", "transfer_write");
489 trace_dump_arg(ptr
, screen
);
491 trace_dump_arg(ptr
, transfer
);
493 trace_dump_arg_begin("stride");
494 trace_dump_uint(transfer
->stride
);
495 trace_dump_arg_end();
497 trace_dump_arg_begin("data");
498 trace_dump_bytes(tr_trans
->map
, size
);
499 trace_dump_arg_end();
501 trace_dump_arg_begin("size");
502 trace_dump_uint(size
);
503 trace_dump_arg_end();
505 trace_dump_call_end();
507 tr_trans
->map
= NULL
;
510 screen
->transfer_unmap(screen
, transfer
);
514 /********************************************************************
519 static struct pipe_buffer
*
520 trace_screen_surface_buffer_create(struct pipe_screen
*_screen
,
521 unsigned width
, unsigned height
,
522 enum pipe_format format
,
527 struct trace_screen
*tr_scr
= trace_screen(_screen
);
528 struct pipe_screen
*screen
= tr_scr
->screen
;
530 struct pipe_buffer
*result
;
532 trace_dump_call_begin("pipe_screen", "surface_buffer_create");
534 trace_dump_arg(ptr
, screen
);
535 trace_dump_arg(uint
, width
);
536 trace_dump_arg(uint
, height
);
537 trace_dump_arg(format
, format
);
538 trace_dump_arg(uint
, usage
);
539 trace_dump_arg(uint
, tex_usage
);
541 result
= screen
->surface_buffer_create(screen
,
550 trace_dump_arg(uint
, stride
);
552 trace_dump_ret(ptr
, result
);
554 trace_dump_call_end();
556 return trace_buffer_create(tr_scr
, result
);
560 static struct pipe_buffer
*
561 trace_screen_buffer_create(struct pipe_screen
*_screen
,
566 struct trace_screen
*tr_scr
= trace_screen(_screen
);
567 struct pipe_screen
*screen
= tr_scr
->screen
;
568 struct pipe_buffer
*result
;
570 trace_dump_call_begin("pipe_screen", "buffer_create");
572 trace_dump_arg(ptr
, screen
);
573 trace_dump_arg(uint
, alignment
);
574 trace_dump_arg(uint
, usage
);
575 trace_dump_arg(uint
, size
);
577 result
= screen
->buffer_create(screen
, alignment
, usage
, size
);
579 trace_dump_ret(ptr
, result
);
581 trace_dump_call_end();
583 /* Zero the buffer to avoid dumping uninitialized memory */
584 if(result
->usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
586 map
= pipe_buffer_map(screen
, result
, PIPE_BUFFER_USAGE_CPU_WRITE
);
588 memset(map
, 0, result
->size
);
589 screen
->buffer_unmap(screen
, result
);
593 return trace_buffer_create(tr_scr
, result
);
597 static struct pipe_buffer
*
598 trace_screen_user_buffer_create(struct pipe_screen
*_screen
,
602 struct trace_screen
*tr_scr
= trace_screen(_screen
);
603 struct pipe_screen
*screen
= tr_scr
->screen
;
604 struct pipe_buffer
*result
;
606 trace_dump_call_begin("pipe_screen", "user_buffer_create");
608 trace_dump_arg(ptr
, screen
);
609 trace_dump_arg_begin("data");
610 trace_dump_bytes(data
, size
);
611 trace_dump_arg_end();
612 trace_dump_arg(uint
, size
);
614 result
= screen
->user_buffer_create(screen
, data
, size
);
616 trace_dump_ret(ptr
, result
);
618 trace_dump_call_end();
621 assert(!(result
->usage
& TRACE_BUFFER_USAGE_USER
));
622 result
->usage
|= TRACE_BUFFER_USAGE_USER
;
625 return trace_buffer_create(tr_scr
, result
);
630 * This function is used to track if data has been changed on a user buffer
631 * without map/unmap being called.
634 trace_screen_user_buffer_update(struct pipe_screen
*_screen
,
635 struct pipe_buffer
*_buffer
)
638 struct trace_screen
*tr_scr
= trace_screen(_screen
);
639 struct pipe_screen
*screen
= tr_scr
->screen
;
642 if(buffer
&& buffer
->usage
& TRACE_BUFFER_USAGE_USER
) {
643 map
= screen
->buffer_map(screen
, buffer
, PIPE_BUFFER_USAGE_CPU_READ
);
645 trace_dump_call_begin("pipe_winsys", "buffer_write");
647 trace_dump_arg(ptr
, screen
);
649 trace_dump_arg(ptr
, buffer
);
651 trace_dump_arg_begin("data");
652 trace_dump_bytes(map
, buffer
->size
);
653 trace_dump_arg_end();
655 trace_dump_arg_begin("size");
656 trace_dump_uint(buffer
->size
);
657 trace_dump_arg_end();
659 trace_dump_call_end();
661 screen
->buffer_unmap(screen
, buffer
);
669 trace_screen_buffer_map(struct pipe_screen
*_screen
,
670 struct pipe_buffer
*_buffer
,
673 struct trace_screen
*tr_scr
= trace_screen(_screen
);
674 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
675 struct pipe_screen
*screen
= tr_scr
->screen
;
676 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
679 assert(screen
->buffer_map
);
680 map
= screen
->buffer_map(screen
, buffer
, usage
);
682 if(usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
692 trace_screen_buffer_map_range(struct pipe_screen
*_screen
,
693 struct pipe_buffer
*_buffer
,
698 struct trace_screen
*tr_scr
= trace_screen(_screen
);
699 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
700 struct pipe_screen
*screen
= tr_scr
->screen
;
701 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
704 assert(screen
->buffer_map_range
);
705 map
= screen
->buffer_map_range(screen
, buffer
, offset
, length
, usage
);
707 if(usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
717 buffer_write(struct pipe_screen
*screen
,
718 struct pipe_buffer
*buffer
,
725 trace_dump_call_begin("pipe_screen", "buffer_write");
727 trace_dump_arg(ptr
, screen
);
729 trace_dump_arg(ptr
, buffer
);
731 trace_dump_arg(uint
, offset
);
733 trace_dump_arg_begin("data");
734 trace_dump_bytes(map
+ offset
, size
);
735 trace_dump_arg_end();
737 trace_dump_arg(uint
, size
);
739 trace_dump_call_end();
745 trace_screen_buffer_flush_mapped_range(struct pipe_screen
*_screen
,
746 struct pipe_buffer
*_buffer
,
750 struct trace_screen
*tr_scr
= trace_screen(_screen
);
751 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
752 struct pipe_screen
*screen
= tr_scr
->screen
;
753 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
756 buffer_write(screen
, buffer
, offset
, tr_buf
->map
, length
);
757 tr_buf
->range_flushed
= TRUE
;
758 screen
->buffer_flush_mapped_range(screen
, buffer
, offset
, length
);
763 trace_screen_buffer_unmap(struct pipe_screen
*_screen
,
764 struct pipe_buffer
*_buffer
)
766 struct trace_screen
*tr_scr
= trace_screen(_screen
);
767 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
768 struct pipe_screen
*screen
= tr_scr
->screen
;
769 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
771 if (tr_buf
->map
&& !tr_buf
->range_flushed
)
772 buffer_write(screen
, buffer
, 0, tr_buf
->map
, buffer
->size
);
774 tr_buf
->range_flushed
= FALSE
;
775 screen
->buffer_unmap(screen
, buffer
);
780 trace_screen_buffer_destroy(struct pipe_buffer
*_buffer
)
782 struct trace_screen
*tr_scr
= trace_screen(_buffer
->screen
);
783 struct trace_buffer
*tr_buf
= trace_buffer(_buffer
);
784 struct pipe_screen
*screen
= tr_scr
->screen
;
785 struct pipe_buffer
*buffer
= tr_buf
->buffer
;
787 trace_dump_call_begin("pipe_screen", "buffer_destroy");
789 trace_dump_arg(ptr
, screen
);
790 trace_dump_arg(ptr
, buffer
);
792 trace_dump_call_end();
794 trace_buffer_destroy(tr_scr
, _buffer
);
798 /********************************************************************
804 trace_screen_fence_reference(struct pipe_screen
*_screen
,
805 struct pipe_fence_handle
**pdst
,
806 struct pipe_fence_handle
*src
)
808 struct trace_screen
*tr_scr
= trace_screen(_screen
);
809 struct pipe_screen
*screen
= tr_scr
->screen
;
810 struct pipe_fence_handle
*dst
;
815 trace_dump_call_begin("pipe_screen", "fence_reference");
817 trace_dump_arg(ptr
, screen
);
818 trace_dump_arg(ptr
, dst
);
819 trace_dump_arg(ptr
, src
);
821 screen
->fence_reference(screen
, pdst
, src
);
823 trace_dump_call_end();
828 trace_screen_fence_signalled(struct pipe_screen
*_screen
,
829 struct pipe_fence_handle
*fence
,
832 struct trace_screen
*tr_scr
= trace_screen(_screen
);
833 struct pipe_screen
*screen
= tr_scr
->screen
;
836 trace_dump_call_begin("pipe_screen", "fence_signalled");
838 trace_dump_arg(ptr
, screen
);
839 trace_dump_arg(ptr
, fence
);
840 trace_dump_arg(uint
, flags
);
842 result
= screen
->fence_signalled(screen
, fence
, flags
);
844 trace_dump_ret(int, result
);
846 trace_dump_call_end();
853 trace_screen_fence_finish(struct pipe_screen
*_screen
,
854 struct pipe_fence_handle
*fence
,
857 struct trace_screen
*tr_scr
= trace_screen(_screen
);
858 struct pipe_screen
*screen
= tr_scr
->screen
;
861 trace_dump_call_begin("pipe_screen", "fence_finish");
863 trace_dump_arg(ptr
, screen
);
864 trace_dump_arg(ptr
, fence
);
865 trace_dump_arg(uint
, flags
);
867 result
= screen
->fence_finish(screen
, fence
, flags
);
869 trace_dump_ret(int, result
);
871 trace_dump_call_end();
877 /********************************************************************
882 trace_screen_destroy(struct pipe_screen
*_screen
)
884 struct trace_screen
*tr_scr
= trace_screen(_screen
);
885 struct pipe_screen
*screen
= tr_scr
->screen
;
887 trace_dump_call_begin("pipe_screen", "destroy");
888 trace_dump_arg(ptr
, screen
);
889 trace_dump_call_end();
890 trace_dump_trace_end();
893 trace_rbug_stop(tr_scr
->rbug
);
895 screen
->destroy(screen
);
903 static boolean firstrun
= TRUE
;
911 if(trace_dump_trace_begin()) {
912 trace_dumping_start();
916 if (debug_get_bool_option("GALLIUM_RBUG", FALSE
)) {
925 trace_screen_create(struct pipe_screen
*screen
)
927 struct trace_screen
*tr_scr
;
928 struct pipe_winsys
*winsys
;
933 if (!trace_enabled())
936 trace_dump_call_begin("", "pipe_screen_create");
938 tr_scr
= CALLOC_STRUCT(trace_screen
);
943 winsys
= trace_winsys_create(screen
->winsys
);
947 winsys
= screen
->winsys
;
949 pipe_mutex_init(tr_scr
->list_mutex
);
950 make_empty_list(&tr_scr
->buffers
);
951 make_empty_list(&tr_scr
->contexts
);
952 make_empty_list(&tr_scr
->textures
);
953 make_empty_list(&tr_scr
->surfaces
);
954 make_empty_list(&tr_scr
->transfers
);
956 tr_scr
->base
.winsys
= winsys
;
957 tr_scr
->base
.destroy
= trace_screen_destroy
;
958 tr_scr
->base
.get_name
= trace_screen_get_name
;
959 tr_scr
->base
.get_vendor
= trace_screen_get_vendor
;
960 tr_scr
->base
.get_param
= trace_screen_get_param
;
961 tr_scr
->base
.get_paramf
= trace_screen_get_paramf
;
962 tr_scr
->base
.is_format_supported
= trace_screen_is_format_supported
;
963 assert(screen
->context_create
);
964 tr_scr
->base
.context_create
= trace_screen_context_create
;
965 tr_scr
->base
.texture_create
= trace_screen_texture_create
;
966 tr_scr
->base
.texture_from_handle
= trace_screen_texture_from_handle
;
967 tr_scr
->base
.texture_get_handle
= trace_screen_texture_get_handle
;
968 tr_scr
->base
.texture_blanket
= trace_screen_texture_blanket
;
969 tr_scr
->base
.texture_destroy
= trace_screen_texture_destroy
;
970 tr_scr
->base
.get_tex_surface
= trace_screen_get_tex_surface
;
971 tr_scr
->base
.tex_surface_destroy
= trace_screen_tex_surface_destroy
;
972 tr_scr
->base
.get_tex_transfer
= trace_screen_get_tex_transfer
;
973 tr_scr
->base
.tex_transfer_destroy
= trace_screen_tex_transfer_destroy
;
974 tr_scr
->base
.transfer_map
= trace_screen_transfer_map
;
975 tr_scr
->base
.transfer_unmap
= trace_screen_transfer_unmap
;
976 tr_scr
->base
.buffer_create
= trace_screen_buffer_create
;
977 tr_scr
->base
.user_buffer_create
= trace_screen_user_buffer_create
;
978 tr_scr
->base
.surface_buffer_create
= trace_screen_surface_buffer_create
;
979 if (screen
->buffer_map
)
980 tr_scr
->base
.buffer_map
= trace_screen_buffer_map
;
981 if (screen
->buffer_map_range
)
982 tr_scr
->base
.buffer_map_range
= trace_screen_buffer_map_range
;
983 if (screen
->buffer_flush_mapped_range
)
984 tr_scr
->base
.buffer_flush_mapped_range
= trace_screen_buffer_flush_mapped_range
;
985 if (screen
->buffer_unmap
)
986 tr_scr
->base
.buffer_unmap
= trace_screen_buffer_unmap
;
987 tr_scr
->base
.buffer_destroy
= trace_screen_buffer_destroy
;
988 tr_scr
->base
.fence_reference
= trace_screen_fence_reference
;
989 tr_scr
->base
.fence_signalled
= trace_screen_fence_signalled
;
990 tr_scr
->base
.fence_finish
= trace_screen_fence_finish
;
991 tr_scr
->base
.flush_frontbuffer
= trace_screen_flush_frontbuffer
;
992 tr_scr
->screen
= screen
;
994 trace_dump_ret(ptr
, screen
);
995 trace_dump_call_end();
998 tr_scr
->rbug
= trace_rbug_start(tr_scr
);
1000 return &tr_scr
->base
;
1007 trace_dump_ret(ptr
, screen
);
1008 trace_dump_call_end();
1009 trace_dump_trace_end();
1015 struct trace_screen
*
1016 trace_screen(struct pipe_screen
*screen
)
1019 assert(screen
->destroy
== trace_screen_destroy
);
1020 return (struct trace_screen
*)screen
;