1 /**************************************************************************
3 * Copyright 2008 VMware, Inc.
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 VMWARE 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/simple_list.h"
33 #include "tr_dump_defines.h"
34 #include "tr_dump_state.h"
35 #include "tr_texture.h"
36 #include "tr_context.h"
37 #include "tr_screen.h"
38 #include "tr_public.h"
41 static bool trace
= false;
44 trace_screen_get_name(struct pipe_screen
*_screen
)
46 struct trace_screen
*tr_scr
= trace_screen(_screen
);
47 struct pipe_screen
*screen
= tr_scr
->screen
;
50 trace_dump_call_begin("pipe_screen", "get_name");
52 trace_dump_arg(ptr
, screen
);
54 result
= screen
->get_name(screen
);
56 trace_dump_ret(string
, result
);
58 trace_dump_call_end();
65 trace_screen_get_vendor(struct pipe_screen
*_screen
)
67 struct trace_screen
*tr_scr
= trace_screen(_screen
);
68 struct pipe_screen
*screen
= tr_scr
->screen
;
71 trace_dump_call_begin("pipe_screen", "get_vendor");
73 trace_dump_arg(ptr
, screen
);
75 result
= screen
->get_vendor(screen
);
77 trace_dump_ret(string
, result
);
79 trace_dump_call_end();
86 trace_screen_get_device_vendor(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_device_vendor");
94 trace_dump_arg(ptr
, screen
);
96 result
= screen
->get_device_vendor(screen
);
98 trace_dump_ret(string
, result
);
100 trace_dump_call_end();
106 static struct disk_cache
*
107 trace_screen_get_disk_shader_cache(struct pipe_screen
*_screen
)
109 struct trace_screen
*tr_scr
= trace_screen(_screen
);
110 struct pipe_screen
*screen
= tr_scr
->screen
;
112 trace_dump_call_begin("pipe_screen", "get_disk_shader_cache");
114 trace_dump_arg(ptr
, screen
);
116 struct disk_cache
*result
= screen
->get_disk_shader_cache(screen
);
118 trace_dump_ret(ptr
, result
);
120 trace_dump_call_end();
127 trace_screen_get_param(struct pipe_screen
*_screen
,
130 struct trace_screen
*tr_scr
= trace_screen(_screen
);
131 struct pipe_screen
*screen
= tr_scr
->screen
;
134 trace_dump_call_begin("pipe_screen", "get_param");
136 trace_dump_arg(ptr
, screen
);
137 trace_dump_arg(int, param
);
139 result
= screen
->get_param(screen
, param
);
141 trace_dump_ret(int, result
);
143 trace_dump_call_end();
150 trace_screen_get_shader_param(struct pipe_screen
*_screen
,
151 enum pipe_shader_type shader
,
152 enum pipe_shader_cap param
)
154 struct trace_screen
*tr_scr
= trace_screen(_screen
);
155 struct pipe_screen
*screen
= tr_scr
->screen
;
158 trace_dump_call_begin("pipe_screen", "get_shader_param");
160 trace_dump_arg(ptr
, screen
);
161 trace_dump_arg(uint
, shader
);
162 trace_dump_arg(int, param
);
164 result
= screen
->get_shader_param(screen
, shader
, param
);
166 trace_dump_ret(int, result
);
168 trace_dump_call_end();
175 trace_screen_get_paramf(struct pipe_screen
*_screen
,
176 enum pipe_capf param
)
178 struct trace_screen
*tr_scr
= trace_screen(_screen
);
179 struct pipe_screen
*screen
= tr_scr
->screen
;
182 trace_dump_call_begin("pipe_screen", "get_paramf");
184 trace_dump_arg(ptr
, screen
);
185 trace_dump_arg(int, param
);
187 result
= screen
->get_paramf(screen
, param
);
189 trace_dump_ret(float, result
);
191 trace_dump_call_end();
198 trace_screen_get_compute_param(struct pipe_screen
*_screen
,
199 enum pipe_shader_ir ir_type
,
200 enum pipe_compute_cap param
, void *data
)
202 struct trace_screen
*tr_scr
= trace_screen(_screen
);
203 struct pipe_screen
*screen
= tr_scr
->screen
;
206 trace_dump_call_begin("pipe_screen", "get_compute_param");
208 trace_dump_arg(ptr
, screen
);
209 trace_dump_arg(int, ir_type
);
210 trace_dump_arg(int, param
);
211 trace_dump_arg(ptr
, data
);
213 result
= screen
->get_compute_param(screen
, ir_type
, param
, data
);
215 trace_dump_ret(int, result
);
217 trace_dump_call_end();
224 trace_screen_is_format_supported(struct pipe_screen
*_screen
,
225 enum pipe_format format
,
226 enum pipe_texture_target target
,
227 unsigned sample_count
,
228 unsigned storage_sample_count
,
231 struct trace_screen
*tr_scr
= trace_screen(_screen
);
232 struct pipe_screen
*screen
= tr_scr
->screen
;
235 trace_dump_call_begin("pipe_screen", "is_format_supported");
237 trace_dump_arg(ptr
, screen
);
238 trace_dump_arg(format
, format
);
239 trace_dump_arg(int, target
);
240 trace_dump_arg(uint
, sample_count
);
241 trace_dump_arg(uint
, tex_usage
);
243 result
= screen
->is_format_supported(screen
, format
, target
, sample_count
,
244 storage_sample_count
, tex_usage
);
246 trace_dump_ret(bool, result
);
248 trace_dump_call_end();
254 static struct pipe_context
*
255 trace_screen_context_create(struct pipe_screen
*_screen
, void *priv
,
258 struct trace_screen
*tr_scr
= trace_screen(_screen
);
259 struct pipe_screen
*screen
= tr_scr
->screen
;
260 struct pipe_context
*result
;
262 trace_dump_call_begin("pipe_screen", "context_create");
264 trace_dump_arg(ptr
, screen
);
265 trace_dump_arg(ptr
, priv
);
266 trace_dump_arg(uint
, flags
);
268 result
= screen
->context_create(screen
, priv
, flags
);
270 trace_dump_ret(ptr
, result
);
272 trace_dump_call_end();
274 result
= trace_context_create(tr_scr
, result
);
281 trace_screen_flush_frontbuffer(struct pipe_screen
*_screen
,
282 struct pipe_resource
*resource
,
283 unsigned level
, unsigned layer
,
284 void *context_private
,
285 struct pipe_box
*sub_box
)
287 struct trace_screen
*tr_scr
= trace_screen(_screen
);
288 struct pipe_screen
*screen
= tr_scr
->screen
;
290 trace_dump_call_begin("pipe_screen", "flush_frontbuffer");
292 trace_dump_arg(ptr
, screen
);
293 trace_dump_arg(ptr
, resource
);
294 trace_dump_arg(uint
, level
);
295 trace_dump_arg(uint
, layer
);
296 /* XXX: hide, as there is nothing we can do with this
297 trace_dump_arg(ptr, context_private);
300 screen
->flush_frontbuffer(screen
, resource
, level
, layer
, context_private
, sub_box
);
302 trace_dump_call_end();
307 trace_screen_get_driver_uuid(struct pipe_screen
*_screen
, char *uuid
)
309 struct pipe_screen
*screen
= trace_screen(_screen
)->screen
;
311 trace_dump_call_begin("pipe_screen", "get_driver_uuid");
312 trace_dump_arg(ptr
, screen
);
314 screen
->get_driver_uuid(screen
, uuid
);
316 trace_dump_ret(string
, uuid
);
317 trace_dump_call_end();
321 trace_screen_get_device_uuid(struct pipe_screen
*_screen
, char *uuid
)
323 struct pipe_screen
*screen
= trace_screen(_screen
)->screen
;
325 trace_dump_call_begin("pipe_screen", "get_device_uuid");
326 trace_dump_arg(ptr
, screen
);
328 screen
->get_device_uuid(screen
, uuid
);
330 trace_dump_ret(string
, uuid
);
331 trace_dump_call_end();
335 /********************************************************************
340 static struct pipe_resource
*
341 trace_screen_resource_create(struct pipe_screen
*_screen
,
342 const struct pipe_resource
*templat
)
344 struct trace_screen
*tr_scr
= trace_screen(_screen
);
345 struct pipe_screen
*screen
= tr_scr
->screen
;
346 struct pipe_resource
*result
;
348 trace_dump_call_begin("pipe_screen", "resource_create");
350 trace_dump_arg(ptr
, screen
);
351 trace_dump_arg(resource_template
, templat
);
353 result
= screen
->resource_create(screen
, templat
);
355 trace_dump_ret(ptr
, result
);
357 trace_dump_call_end();
360 result
->screen
= _screen
;
364 static struct pipe_resource
*
365 trace_screen_resource_from_handle(struct pipe_screen
*_screen
,
366 const struct pipe_resource
*templ
,
367 struct winsys_handle
*handle
,
370 struct trace_screen
*tr_screen
= trace_screen(_screen
);
371 struct pipe_screen
*screen
= tr_screen
->screen
;
372 struct pipe_resource
*result
;
374 /* TODO trace call */
376 result
= screen
->resource_from_handle(screen
, templ
, handle
, usage
);
379 result
->screen
= _screen
;
384 trace_screen_check_resource_capability(struct pipe_screen
*_screen
,
385 struct pipe_resource
*resource
,
388 struct pipe_screen
*screen
= trace_screen(_screen
)->screen
;
390 return screen
->check_resource_capability(screen
, resource
, bind
);
394 trace_screen_resource_get_handle(struct pipe_screen
*_screen
,
395 struct pipe_context
*_pipe
,
396 struct pipe_resource
*resource
,
397 struct winsys_handle
*handle
,
400 struct trace_screen
*tr_screen
= trace_screen(_screen
);
401 struct trace_context
*tr_pipe
= _pipe
? trace_context(_pipe
) : NULL
;
402 struct pipe_screen
*screen
= tr_screen
->screen
;
404 /* TODO trace call */
406 return screen
->resource_get_handle(screen
, tr_pipe
? tr_pipe
->pipe
: NULL
,
407 resource
, handle
, usage
);
411 trace_screen_resource_get_param(struct pipe_screen
*_screen
,
412 struct pipe_context
*_pipe
,
413 struct pipe_resource
*resource
,
416 enum pipe_resource_param param
,
417 unsigned handle_usage
,
420 struct trace_screen
*tr_screen
= trace_screen(_screen
);
421 struct trace_context
*tr_pipe
= _pipe
? trace_context(_pipe
) : NULL
;
422 struct pipe_screen
*screen
= tr_screen
->screen
;
424 /* TODO trace call */
426 return screen
->resource_get_param(screen
, tr_pipe
? tr_pipe
->pipe
: NULL
,
427 resource
, plane
, layer
, param
,
428 handle_usage
, value
);
432 trace_screen_resource_get_info(struct pipe_screen
*_screen
,
433 struct pipe_resource
*resource
,
437 struct trace_screen
*tr_screen
= trace_screen(_screen
);
438 struct pipe_screen
*screen
= tr_screen
->screen
;
440 /* TODO trace call */
442 screen
->resource_get_info(screen
, resource
, stride
, offset
);
445 static struct pipe_resource
*
446 trace_screen_resource_from_memobj(struct pipe_screen
*_screen
,
447 const struct pipe_resource
*templ
,
448 struct pipe_memory_object
*memobj
,
451 struct pipe_screen
*screen
= trace_screen(_screen
)->screen
;
453 trace_dump_call_begin("pipe_screen", "resource_from_memobj");
454 trace_dump_arg(ptr
, screen
);
455 trace_dump_arg(resource_template
, templ
);
456 trace_dump_arg(ptr
, memobj
);
457 trace_dump_arg(uint
, offset
);
459 struct pipe_resource
*res
=
460 screen
->resource_from_memobj(screen
, templ
, memobj
, offset
);
464 res
->screen
= _screen
;
466 trace_dump_ret(ptr
, res
);
467 trace_dump_call_end();
472 trace_screen_resource_changed(struct pipe_screen
*_screen
,
473 struct pipe_resource
*resource
)
475 struct trace_screen
*tr_scr
= trace_screen(_screen
);
476 struct pipe_screen
*screen
= tr_scr
->screen
;
478 trace_dump_call_begin("pipe_screen", "resource_changed");
480 trace_dump_arg(ptr
, screen
);
481 trace_dump_arg(ptr
, resource
);
483 if (screen
->resource_changed
)
484 screen
->resource_changed(screen
, resource
);
486 trace_dump_call_end();
490 trace_screen_resource_destroy(struct pipe_screen
*_screen
,
491 struct pipe_resource
*resource
)
493 struct trace_screen
*tr_scr
= trace_screen(_screen
);
494 struct pipe_screen
*screen
= tr_scr
->screen
;
496 /* Don't trace this, because due to the lack of pipe_resource wrapping,
497 * we can get this call from inside of driver calls, which would try
498 * to lock an already-locked mutex.
500 screen
->resource_destroy(screen
, resource
);
504 /********************************************************************
510 trace_screen_fence_reference(struct pipe_screen
*_screen
,
511 struct pipe_fence_handle
**pdst
,
512 struct pipe_fence_handle
*src
)
514 struct trace_screen
*tr_scr
= trace_screen(_screen
);
515 struct pipe_screen
*screen
= tr_scr
->screen
;
516 struct pipe_fence_handle
*dst
;
521 trace_dump_call_begin("pipe_screen", "fence_reference");
523 trace_dump_arg(ptr
, screen
);
524 trace_dump_arg(ptr
, dst
);
525 trace_dump_arg(ptr
, src
);
527 screen
->fence_reference(screen
, pdst
, src
);
529 trace_dump_call_end();
534 trace_screen_fence_get_fd(struct pipe_screen
*_screen
,
535 struct pipe_fence_handle
*fence
)
537 struct trace_screen
*tr_scr
= trace_screen(_screen
);
538 struct pipe_screen
*screen
= tr_scr
->screen
;
541 trace_dump_call_begin("pipe_screen", "fence_get_fd");
543 trace_dump_arg(ptr
, screen
);
544 trace_dump_arg(ptr
, fence
);
546 result
= screen
->fence_get_fd(screen
, fence
);
548 trace_dump_ret(int, result
);
550 trace_dump_call_end();
557 trace_screen_fence_finish(struct pipe_screen
*_screen
,
558 struct pipe_context
*_ctx
,
559 struct pipe_fence_handle
*fence
,
562 struct trace_screen
*tr_scr
= trace_screen(_screen
);
563 struct pipe_screen
*screen
= tr_scr
->screen
;
564 struct pipe_context
*ctx
= _ctx
? trace_context(_ctx
)->pipe
: NULL
;
567 trace_dump_call_begin("pipe_screen", "fence_finish");
569 trace_dump_arg(ptr
, screen
);
570 trace_dump_arg(ptr
, ctx
);
571 trace_dump_arg(ptr
, fence
);
572 trace_dump_arg(uint
, timeout
);
574 result
= screen
->fence_finish(screen
, ctx
, fence
, timeout
);
576 trace_dump_ret(bool, result
);
578 trace_dump_call_end();
584 /********************************************************************
588 static struct pipe_memory_object
*
589 trace_screen_memobj_create_from_handle(struct pipe_screen
*_screen
,
590 struct winsys_handle
*handle
,
593 struct pipe_screen
*screen
= trace_screen(_screen
)->screen
;
595 trace_dump_call_begin("pipe_screen", "memobj_create_from_handle");
596 trace_dump_arg(ptr
, screen
);
597 trace_dump_arg(ptr
, handle
);
598 trace_dump_arg(bool, dedicated
);
600 struct pipe_memory_object
*res
=
601 screen
->memobj_create_from_handle(screen
, handle
, dedicated
);
603 trace_dump_ret(ptr
, res
);
604 trace_dump_call_end();
610 trace_screen_memobj_destroy(struct pipe_screen
*_screen
,
611 struct pipe_memory_object
*memobj
)
613 struct pipe_screen
*screen
= trace_screen(_screen
)->screen
;
615 trace_dump_call_begin("pipe_screen", "memobj_destroy");
616 trace_dump_arg(ptr
, screen
);
617 trace_dump_arg(ptr
, memobj
);
618 trace_dump_call_end();
620 screen
->memobj_destroy(screen
, memobj
);
624 /********************************************************************
629 trace_screen_get_timestamp(struct pipe_screen
*_screen
)
631 struct trace_screen
*tr_scr
= trace_screen(_screen
);
632 struct pipe_screen
*screen
= tr_scr
->screen
;
635 trace_dump_call_begin("pipe_screen", "get_timestamp");
636 trace_dump_arg(ptr
, screen
);
638 result
= screen
->get_timestamp(screen
);
640 trace_dump_ret(uint
, result
);
641 trace_dump_call_end();
647 trace_screen_finalize_nir(struct pipe_screen
*_screen
, void *nir
, bool optimize
)
649 struct pipe_screen
*screen
= trace_screen(_screen
)->screen
;
651 screen
->finalize_nir(screen
, nir
, optimize
);
655 trace_screen_destroy(struct pipe_screen
*_screen
)
657 struct trace_screen
*tr_scr
= trace_screen(_screen
);
658 struct pipe_screen
*screen
= tr_scr
->screen
;
660 trace_dump_call_begin("pipe_screen", "destroy");
661 trace_dump_arg(ptr
, screen
);
662 trace_dump_call_end();
664 screen
->destroy(screen
);
672 static bool firstrun
= true;
678 if(trace_dump_trace_begin()) {
679 trace_dumping_start();
687 trace_screen_create(struct pipe_screen
*screen
)
689 struct trace_screen
*tr_scr
;
691 if (!trace_enabled())
694 trace_dump_call_begin("", "pipe_screen_create");
696 tr_scr
= CALLOC_STRUCT(trace_screen
);
700 #define SCR_INIT(_member) \
701 tr_scr->base._member = screen->_member ? trace_screen_##_member : NULL
703 tr_scr
->base
.destroy
= trace_screen_destroy
;
704 tr_scr
->base
.get_name
= trace_screen_get_name
;
705 tr_scr
->base
.get_vendor
= trace_screen_get_vendor
;
706 tr_scr
->base
.get_device_vendor
= trace_screen_get_device_vendor
;
707 SCR_INIT(get_disk_shader_cache
);
708 tr_scr
->base
.get_param
= trace_screen_get_param
;
709 tr_scr
->base
.get_shader_param
= trace_screen_get_shader_param
;
710 tr_scr
->base
.get_paramf
= trace_screen_get_paramf
;
711 tr_scr
->base
.get_compute_param
= trace_screen_get_compute_param
;
712 tr_scr
->base
.is_format_supported
= trace_screen_is_format_supported
;
713 assert(screen
->context_create
);
714 tr_scr
->base
.context_create
= trace_screen_context_create
;
715 tr_scr
->base
.resource_create
= trace_screen_resource_create
;
716 tr_scr
->base
.resource_from_handle
= trace_screen_resource_from_handle
;
717 SCR_INIT(check_resource_capability
);
718 tr_scr
->base
.resource_get_handle
= trace_screen_resource_get_handle
;
719 SCR_INIT(resource_get_param
);
720 SCR_INIT(resource_get_info
);
721 SCR_INIT(resource_from_memobj
);
722 SCR_INIT(resource_changed
);
723 tr_scr
->base
.resource_destroy
= trace_screen_resource_destroy
;
724 tr_scr
->base
.fence_reference
= trace_screen_fence_reference
;
725 SCR_INIT(fence_get_fd
);
726 tr_scr
->base
.fence_finish
= trace_screen_fence_finish
;
727 SCR_INIT(memobj_create_from_handle
);
728 SCR_INIT(memobj_destroy
);
729 tr_scr
->base
.flush_frontbuffer
= trace_screen_flush_frontbuffer
;
730 tr_scr
->base
.get_timestamp
= trace_screen_get_timestamp
;
731 SCR_INIT(get_driver_uuid
);
732 SCR_INIT(get_device_uuid
);
733 SCR_INIT(finalize_nir
);
735 tr_scr
->screen
= screen
;
737 trace_dump_ret(ptr
, screen
);
738 trace_dump_call_end();
740 return &tr_scr
->base
;
743 trace_dump_ret(ptr
, screen
);
744 trace_dump_call_end();
750 struct trace_screen
*
751 trace_screen(struct pipe_screen
*screen
)
754 assert(screen
->destroy
== trace_screen_destroy
);
755 return (struct trace_screen
*)screen
;