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 boolean 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
, unsigned shader
,
151 enum pipe_shader_cap param
)
153 struct trace_screen
*tr_scr
= trace_screen(_screen
);
154 struct pipe_screen
*screen
= tr_scr
->screen
;
157 trace_dump_call_begin("pipe_screen", "get_shader_param");
159 trace_dump_arg(ptr
, screen
);
160 trace_dump_arg(uint
, shader
);
161 trace_dump_arg(int, param
);
163 result
= screen
->get_shader_param(screen
, shader
, param
);
165 trace_dump_ret(int, result
);
167 trace_dump_call_end();
174 trace_screen_get_paramf(struct pipe_screen
*_screen
,
175 enum pipe_capf param
)
177 struct trace_screen
*tr_scr
= trace_screen(_screen
);
178 struct pipe_screen
*screen
= tr_scr
->screen
;
181 trace_dump_call_begin("pipe_screen", "get_paramf");
183 trace_dump_arg(ptr
, screen
);
184 trace_dump_arg(int, param
);
186 result
= screen
->get_paramf(screen
, param
);
188 trace_dump_ret(float, result
);
190 trace_dump_call_end();
197 trace_screen_get_compute_param(struct pipe_screen
*_screen
,
198 enum pipe_shader_ir ir_type
,
199 enum pipe_compute_cap param
, void *data
)
201 struct trace_screen
*tr_scr
= trace_screen(_screen
);
202 struct pipe_screen
*screen
= tr_scr
->screen
;
205 trace_dump_call_begin("pipe_screen", "get_compute_param");
207 trace_dump_arg(ptr
, screen
);
208 trace_dump_arg(int, ir_type
);
209 trace_dump_arg(int, param
);
210 trace_dump_arg(ptr
, data
);
212 result
= screen
->get_compute_param(screen
, ir_type
, param
, data
);
214 trace_dump_ret(int, result
);
216 trace_dump_call_end();
223 trace_screen_is_format_supported(struct pipe_screen
*_screen
,
224 enum pipe_format format
,
225 enum pipe_texture_target target
,
226 unsigned sample_count
,
229 struct trace_screen
*tr_scr
= trace_screen(_screen
);
230 struct pipe_screen
*screen
= tr_scr
->screen
;
233 trace_dump_call_begin("pipe_screen", "is_format_supported");
235 trace_dump_arg(ptr
, screen
);
236 trace_dump_arg(format
, format
);
237 trace_dump_arg(int, target
);
238 trace_dump_arg(uint
, sample_count
);
239 trace_dump_arg(uint
, tex_usage
);
241 result
= screen
->is_format_supported(screen
, format
, target
, sample_count
,
244 trace_dump_ret(bool, result
);
246 trace_dump_call_end();
252 static struct pipe_context
*
253 trace_screen_context_create(struct pipe_screen
*_screen
, void *priv
,
256 struct trace_screen
*tr_scr
= trace_screen(_screen
);
257 struct pipe_screen
*screen
= tr_scr
->screen
;
258 struct pipe_context
*result
;
260 trace_dump_call_begin("pipe_screen", "context_create");
262 trace_dump_arg(ptr
, screen
);
263 trace_dump_arg(ptr
, priv
);
264 trace_dump_arg(uint
, flags
);
266 result
= screen
->context_create(screen
, priv
, flags
);
268 trace_dump_ret(ptr
, result
);
270 trace_dump_call_end();
272 result
= trace_context_create(tr_scr
, result
);
279 trace_screen_flush_frontbuffer(struct pipe_screen
*_screen
,
280 struct pipe_resource
*_resource
,
281 unsigned level
, unsigned layer
,
282 void *context_private
,
283 struct pipe_box
*sub_box
)
285 struct trace_screen
*tr_scr
= trace_screen(_screen
);
286 struct trace_resource
*tr_res
= trace_resource(_resource
);
287 struct pipe_screen
*screen
= tr_scr
->screen
;
288 struct pipe_resource
*resource
= tr_res
->resource
;
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();
306 /********************************************************************
311 static struct pipe_resource
*
312 trace_screen_resource_create(struct pipe_screen
*_screen
,
313 const struct pipe_resource
*templat
)
315 struct trace_screen
*tr_scr
= trace_screen(_screen
);
316 struct pipe_screen
*screen
= tr_scr
->screen
;
317 struct pipe_resource
*result
;
319 trace_dump_call_begin("pipe_screen", "resource_create");
321 trace_dump_arg(ptr
, screen
);
322 trace_dump_arg(resource_template
, templat
);
324 result
= screen
->resource_create(screen
, templat
);
326 trace_dump_ret(ptr
, result
);
328 trace_dump_call_end();
330 result
= trace_resource_create(tr_scr
, result
);
335 static struct pipe_resource
*
336 trace_screen_resource_from_handle(struct pipe_screen
*_screen
,
337 const struct pipe_resource
*templ
,
338 struct winsys_handle
*handle
,
341 struct trace_screen
*tr_screen
= trace_screen(_screen
);
342 struct pipe_screen
*screen
= tr_screen
->screen
;
343 struct pipe_resource
*result
;
345 /* TODO trace call */
347 result
= screen
->resource_from_handle(screen
, templ
, handle
, usage
);
349 result
= trace_resource_create(trace_screen(_screen
), result
);
355 trace_screen_resource_get_handle(struct pipe_screen
*_screen
,
356 struct pipe_context
*_pipe
,
357 struct pipe_resource
*_resource
,
358 struct winsys_handle
*handle
,
361 struct trace_screen
*tr_screen
= trace_screen(_screen
);
362 struct trace_context
*tr_pipe
= _pipe
? trace_context(_pipe
) : NULL
;
363 struct trace_resource
*tr_resource
= trace_resource(_resource
);
364 struct pipe_screen
*screen
= tr_screen
->screen
;
365 struct pipe_resource
*resource
= tr_resource
->resource
;
367 /* TODO trace call */
369 return screen
->resource_get_handle(screen
, tr_pipe
? tr_pipe
->pipe
: NULL
,
370 resource
, handle
, usage
);
374 trace_screen_resource_changed(struct pipe_screen
*_screen
,
375 struct pipe_resource
*_resource
)
377 struct trace_screen
*tr_scr
= trace_screen(_screen
);
378 struct trace_resource
*tr_res
= trace_resource(_resource
);
379 struct pipe_screen
*screen
= tr_scr
->screen
;
380 struct pipe_resource
*resource
= tr_res
->resource
;
382 assert(resource
->screen
== screen
);
384 trace_dump_call_begin("pipe_screen", "resource_changed");
386 trace_dump_arg(ptr
, screen
);
387 trace_dump_arg(ptr
, resource
);
389 screen
->resource_changed(screen
, resource
);
391 trace_dump_call_end();
395 trace_screen_resource_destroy(struct pipe_screen
*_screen
,
396 struct pipe_resource
*_resource
)
398 struct trace_screen
*tr_scr
= trace_screen(_screen
);
399 struct trace_resource
*tr_res
= trace_resource(_resource
);
400 struct pipe_screen
*screen
= tr_scr
->screen
;
401 struct pipe_resource
*resource
= tr_res
->resource
;
403 assert(resource
->screen
== screen
);
405 trace_dump_call_begin("pipe_screen", "resource_destroy");
407 trace_dump_arg(ptr
, screen
);
408 trace_dump_arg(ptr
, resource
);
410 trace_dump_call_end();
412 trace_resource_destroy(tr_scr
, tr_res
);
416 /********************************************************************
422 trace_screen_fence_reference(struct pipe_screen
*_screen
,
423 struct pipe_fence_handle
**pdst
,
424 struct pipe_fence_handle
*src
)
426 struct trace_screen
*tr_scr
= trace_screen(_screen
);
427 struct pipe_screen
*screen
= tr_scr
->screen
;
428 struct pipe_fence_handle
*dst
;
433 trace_dump_call_begin("pipe_screen", "fence_reference");
435 trace_dump_arg(ptr
, screen
);
436 trace_dump_arg(ptr
, dst
);
437 trace_dump_arg(ptr
, src
);
439 screen
->fence_reference(screen
, pdst
, src
);
441 trace_dump_call_end();
446 trace_screen_fence_finish(struct pipe_screen
*_screen
,
447 struct pipe_context
*_ctx
,
448 struct pipe_fence_handle
*fence
,
451 struct trace_screen
*tr_scr
= trace_screen(_screen
);
452 struct pipe_screen
*screen
= tr_scr
->screen
;
453 struct pipe_context
*ctx
= _ctx
? trace_context(_ctx
)->pipe
: NULL
;
456 trace_dump_call_begin("pipe_screen", "fence_finish");
458 trace_dump_arg(ptr
, screen
);
459 trace_dump_arg(ptr
, ctx
);
460 trace_dump_arg(ptr
, fence
);
461 trace_dump_arg(uint
, timeout
);
463 result
= screen
->fence_finish(screen
, ctx
, fence
, timeout
);
465 trace_dump_ret(bool, result
);
467 trace_dump_call_end();
473 /********************************************************************
478 trace_screen_get_timestamp(struct pipe_screen
*_screen
)
480 struct trace_screen
*tr_scr
= trace_screen(_screen
);
481 struct pipe_screen
*screen
= tr_scr
->screen
;
484 trace_dump_call_begin("pipe_screen", "get_timestamp");
485 trace_dump_arg(ptr
, screen
);
487 result
= screen
->get_timestamp(screen
);
489 trace_dump_ret(uint
, result
);
490 trace_dump_call_end();
496 trace_screen_destroy(struct pipe_screen
*_screen
)
498 struct trace_screen
*tr_scr
= trace_screen(_screen
);
499 struct pipe_screen
*screen
= tr_scr
->screen
;
501 trace_dump_call_begin("pipe_screen", "destroy");
502 trace_dump_arg(ptr
, screen
);
503 trace_dump_call_end();
505 screen
->destroy(screen
);
513 static boolean firstrun
= TRUE
;
519 if(trace_dump_trace_begin()) {
520 trace_dumping_start();
528 trace_screen_create(struct pipe_screen
*screen
)
530 struct trace_screen
*tr_scr
;
532 if (!trace_enabled())
535 trace_dump_call_begin("", "pipe_screen_create");
537 tr_scr
= CALLOC_STRUCT(trace_screen
);
541 #define SCR_INIT(_member) \
542 tr_scr->base._member = screen->_member ? trace_screen_##_member : NULL
544 tr_scr
->base
.destroy
= trace_screen_destroy
;
545 tr_scr
->base
.get_name
= trace_screen_get_name
;
546 tr_scr
->base
.get_vendor
= trace_screen_get_vendor
;
547 tr_scr
->base
.get_device_vendor
= trace_screen_get_device_vendor
;
548 SCR_INIT(get_disk_shader_cache
);
549 tr_scr
->base
.get_param
= trace_screen_get_param
;
550 tr_scr
->base
.get_shader_param
= trace_screen_get_shader_param
;
551 tr_scr
->base
.get_paramf
= trace_screen_get_paramf
;
552 tr_scr
->base
.get_compute_param
= trace_screen_get_compute_param
;
553 tr_scr
->base
.is_format_supported
= trace_screen_is_format_supported
;
554 assert(screen
->context_create
);
555 tr_scr
->base
.context_create
= trace_screen_context_create
;
556 tr_scr
->base
.resource_create
= trace_screen_resource_create
;
557 tr_scr
->base
.resource_from_handle
= trace_screen_resource_from_handle
;
558 tr_scr
->base
.resource_get_handle
= trace_screen_resource_get_handle
;
559 SCR_INIT(resource_changed
);
560 tr_scr
->base
.resource_destroy
= trace_screen_resource_destroy
;
561 tr_scr
->base
.fence_reference
= trace_screen_fence_reference
;
562 tr_scr
->base
.fence_finish
= trace_screen_fence_finish
;
563 tr_scr
->base
.flush_frontbuffer
= trace_screen_flush_frontbuffer
;
564 tr_scr
->base
.get_timestamp
= trace_screen_get_timestamp
;
566 tr_scr
->screen
= screen
;
568 trace_dump_ret(ptr
, screen
);
569 trace_dump_call_end();
571 return &tr_scr
->base
;
574 trace_dump_ret(ptr
, screen
);
575 trace_dump_call_end();
581 struct trace_screen
*
582 trace_screen(struct pipe_screen
*screen
)
585 assert(screen
->destroy
== trace_screen_destroy
);
586 return (struct trace_screen
*)screen
;