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"
33 #include "tr_dump_state.h"
34 #include "tr_texture.h"
35 #include "tr_context.h"
36 #include "tr_screen.h"
37 #include "tr_public.h"
39 #include "pipe/p_format.h"
42 static boolean trace
= 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_shader_param(struct pipe_screen
*_screen
, unsigned shader
,
111 enum pipe_shader_cap param
)
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_shader_param");
119 trace_dump_arg(ptr
, screen
);
120 trace_dump_arg(uint
, shader
);
121 trace_dump_arg(int, param
);
123 result
= screen
->get_shader_param(screen
, shader
, param
);
125 trace_dump_ret(int, result
);
127 trace_dump_call_end();
134 trace_screen_get_paramf(struct pipe_screen
*_screen
,
135 enum pipe_capf param
)
137 struct trace_screen
*tr_scr
= trace_screen(_screen
);
138 struct pipe_screen
*screen
= tr_scr
->screen
;
141 trace_dump_call_begin("pipe_screen", "get_paramf");
143 trace_dump_arg(ptr
, screen
);
144 trace_dump_arg(int, param
);
146 result
= screen
->get_paramf(screen
, param
);
148 trace_dump_ret(float, result
);
150 trace_dump_call_end();
157 trace_screen_is_format_supported(struct pipe_screen
*_screen
,
158 enum pipe_format format
,
159 enum pipe_texture_target target
,
160 unsigned sample_count
,
163 struct trace_screen
*tr_scr
= trace_screen(_screen
);
164 struct pipe_screen
*screen
= tr_scr
->screen
;
167 trace_dump_call_begin("pipe_screen", "is_format_supported");
169 trace_dump_arg(ptr
, screen
);
170 trace_dump_arg(format
, format
);
171 trace_dump_arg(int, target
);
172 trace_dump_arg(uint
, sample_count
);
173 trace_dump_arg(uint
, tex_usage
);
175 result
= screen
->is_format_supported(screen
, format
, target
, sample_count
,
178 trace_dump_ret(bool, result
);
180 trace_dump_call_end();
186 static struct pipe_context
*
187 trace_screen_context_create(struct pipe_screen
*_screen
, void *priv
)
189 struct trace_screen
*tr_scr
= trace_screen(_screen
);
190 struct pipe_screen
*screen
= tr_scr
->screen
;
191 struct pipe_context
*result
;
193 trace_dump_call_begin("pipe_screen", "context_create");
195 trace_dump_arg(ptr
, screen
);
197 result
= screen
->context_create(screen
, priv
);
199 trace_dump_ret(ptr
, result
);
201 trace_dump_call_end();
203 result
= trace_context_create(tr_scr
, result
);
210 trace_screen_flush_frontbuffer(struct pipe_screen
*_screen
,
211 struct pipe_resource
*_resource
,
212 unsigned level
, unsigned layer
,
213 void *context_private
)
215 struct trace_screen
*tr_scr
= trace_screen(_screen
);
216 struct trace_resource
*tr_res
= trace_resource(_resource
);
217 struct pipe_screen
*screen
= tr_scr
->screen
;
218 struct pipe_resource
*resource
= tr_res
->resource
;
220 trace_dump_call_begin("pipe_screen", "flush_frontbuffer");
222 trace_dump_arg(ptr
, screen
);
223 trace_dump_arg(ptr
, resource
);
224 trace_dump_arg(uint
, level
);
225 trace_dump_arg(uint
, layer
);
226 /* XXX: hide, as there is nothing we can do with this
227 trace_dump_arg(ptr, context_private);
230 screen
->flush_frontbuffer(screen
, resource
, level
, layer
, context_private
);
232 trace_dump_call_end();
236 /********************************************************************
241 static struct pipe_resource
*
242 trace_screen_resource_create(struct pipe_screen
*_screen
,
243 const struct pipe_resource
*templat
)
245 struct trace_screen
*tr_scr
= trace_screen(_screen
);
246 struct pipe_screen
*screen
= tr_scr
->screen
;
247 struct pipe_resource
*result
;
249 trace_dump_call_begin("pipe_screen", "resource_create");
251 trace_dump_arg(ptr
, screen
);
252 trace_dump_arg(resource_template
, templat
);
254 result
= screen
->resource_create(screen
, templat
);
256 trace_dump_ret(ptr
, result
);
258 trace_dump_call_end();
260 result
= trace_resource_create(tr_scr
, result
);
265 static struct pipe_resource
*
266 trace_screen_resource_from_handle(struct pipe_screen
*_screen
,
267 const struct pipe_resource
*templ
,
268 struct winsys_handle
*handle
)
270 struct trace_screen
*tr_screen
= trace_screen(_screen
);
271 struct pipe_screen
*screen
= tr_screen
->screen
;
272 struct pipe_resource
*result
;
274 /* TODO trace call */
276 result
= screen
->resource_from_handle(screen
, templ
, handle
);
278 result
= trace_resource_create(trace_screen(_screen
), result
);
284 trace_screen_resource_get_handle(struct pipe_screen
*_screen
,
285 struct pipe_resource
*_resource
,
286 struct winsys_handle
*handle
)
288 struct trace_screen
*tr_screen
= trace_screen(_screen
);
289 struct trace_resource
*tr_resource
= trace_resource(_resource
);
290 struct pipe_screen
*screen
= tr_screen
->screen
;
291 struct pipe_resource
*resource
= tr_resource
->resource
;
293 /* TODO trace call */
295 return screen
->resource_get_handle(screen
, resource
, handle
);
301 trace_screen_resource_destroy(struct pipe_screen
*_screen
,
302 struct pipe_resource
*_resource
)
304 struct trace_screen
*tr_scr
= trace_screen(_screen
);
305 struct trace_resource
*tr_res
= trace_resource(_resource
);
306 struct pipe_screen
*screen
= tr_scr
->screen
;
307 struct pipe_resource
*resource
= tr_res
->resource
;
309 assert(resource
->screen
== screen
);
311 trace_dump_call_begin("pipe_screen", "resource_destroy");
313 trace_dump_arg(ptr
, screen
);
314 trace_dump_arg(ptr
, resource
);
316 trace_dump_call_end();
318 trace_resource_destroy(tr_scr
, tr_res
);
323 /********************************************************************
329 static struct pipe_resource
*
330 trace_screen_user_buffer_create(struct pipe_screen
*_screen
,
335 struct trace_screen
*tr_scr
= trace_screen(_screen
);
336 struct pipe_screen
*screen
= tr_scr
->screen
;
337 struct pipe_resource
*result
;
339 trace_dump_call_begin("pipe_screen", "user_buffer_create");
341 trace_dump_arg(ptr
, screen
);
342 trace_dump_arg_begin("data");
343 trace_dump_bytes(data
, size
);
344 trace_dump_arg_end();
345 trace_dump_arg(uint
, size
);
346 trace_dump_arg(uint
, usage
);
348 result
= screen
->user_buffer_create(screen
, data
, size
, usage
);
350 trace_dump_ret(ptr
, result
);
352 trace_dump_call_end();
355 assert(!(result
->flags
& TRACE_FLAG_USER_BUFFER
));
356 result
->flags
|= TRACE_FLAG_USER_BUFFER
;
359 return trace_resource_create(tr_scr
, result
);
365 /********************************************************************
371 trace_screen_fence_reference(struct pipe_screen
*_screen
,
372 struct pipe_fence_handle
**pdst
,
373 struct pipe_fence_handle
*src
)
375 struct trace_screen
*tr_scr
= trace_screen(_screen
);
376 struct pipe_screen
*screen
= tr_scr
->screen
;
377 struct pipe_fence_handle
*dst
;
382 trace_dump_call_begin("pipe_screen", "fence_reference");
384 trace_dump_arg(ptr
, screen
);
385 trace_dump_arg(ptr
, dst
);
386 trace_dump_arg(ptr
, src
);
388 screen
->fence_reference(screen
, pdst
, src
);
390 trace_dump_call_end();
395 trace_screen_fence_signalled(struct pipe_screen
*_screen
,
396 struct pipe_fence_handle
*fence
)
398 struct trace_screen
*tr_scr
= trace_screen(_screen
);
399 struct pipe_screen
*screen
= tr_scr
->screen
;
402 trace_dump_call_begin("pipe_screen", "fence_signalled");
404 trace_dump_arg(ptr
, screen
);
405 trace_dump_arg(ptr
, fence
);
407 result
= screen
->fence_signalled(screen
, fence
);
409 trace_dump_ret(bool, result
);
411 trace_dump_call_end();
418 trace_screen_fence_finish(struct pipe_screen
*_screen
,
419 struct pipe_fence_handle
*fence
,
422 struct trace_screen
*tr_scr
= trace_screen(_screen
);
423 struct pipe_screen
*screen
= tr_scr
->screen
;
426 trace_dump_call_begin("pipe_screen", "fence_finish");
428 trace_dump_arg(ptr
, screen
);
429 trace_dump_arg(ptr
, fence
);
430 trace_dump_arg(uint
, timeout
);
432 result
= screen
->fence_finish(screen
, fence
, timeout
);
434 trace_dump_ret(bool, result
);
436 trace_dump_call_end();
442 /********************************************************************
447 trace_screen_destroy(struct pipe_screen
*_screen
)
449 struct trace_screen
*tr_scr
= trace_screen(_screen
);
450 struct pipe_screen
*screen
= tr_scr
->screen
;
452 trace_dump_call_begin("pipe_screen", "destroy");
453 trace_dump_arg(ptr
, screen
);
454 trace_dump_call_end();
455 trace_dump_trace_end();
457 screen
->destroy(screen
);
465 static boolean firstrun
= TRUE
;
471 if(trace_dump_trace_begin()) {
472 trace_dumping_start();
480 trace_screen_create(struct pipe_screen
*screen
)
482 struct trace_screen
*tr_scr
;
483 struct pipe_winsys
*winsys
;
488 if (!trace_enabled())
491 trace_dump_call_begin("", "pipe_screen_create");
493 tr_scr
= CALLOC_STRUCT(trace_screen
);
498 winsys
= trace_winsys_create(screen
->winsys
);
502 winsys
= screen
->winsys
;
504 tr_scr
->base
.winsys
= winsys
;
505 tr_scr
->base
.destroy
= trace_screen_destroy
;
506 tr_scr
->base
.get_name
= trace_screen_get_name
;
507 tr_scr
->base
.get_vendor
= trace_screen_get_vendor
;
508 tr_scr
->base
.get_param
= trace_screen_get_param
;
509 tr_scr
->base
.get_shader_param
= trace_screen_get_shader_param
;
510 tr_scr
->base
.get_paramf
= trace_screen_get_paramf
;
511 tr_scr
->base
.is_format_supported
= trace_screen_is_format_supported
;
512 assert(screen
->context_create
);
513 tr_scr
->base
.context_create
= trace_screen_context_create
;
514 tr_scr
->base
.resource_create
= trace_screen_resource_create
;
515 tr_scr
->base
.resource_from_handle
= trace_screen_resource_from_handle
;
516 tr_scr
->base
.resource_get_handle
= trace_screen_resource_get_handle
;
517 tr_scr
->base
.resource_destroy
= trace_screen_resource_destroy
;
518 tr_scr
->base
.user_buffer_create
= trace_screen_user_buffer_create
;
519 tr_scr
->base
.fence_reference
= trace_screen_fence_reference
;
520 tr_scr
->base
.fence_signalled
= trace_screen_fence_signalled
;
521 tr_scr
->base
.fence_finish
= trace_screen_fence_finish
;
522 tr_scr
->base
.flush_frontbuffer
= trace_screen_flush_frontbuffer
;
524 tr_scr
->screen
= screen
;
526 trace_dump_ret(ptr
, screen
);
527 trace_dump_call_end();
529 return &tr_scr
->base
;
532 trace_dump_ret(ptr
, screen
);
533 trace_dump_call_end();
534 trace_dump_trace_end();
540 struct trace_screen
*
541 trace_screen(struct pipe_screen
*screen
)
544 assert(screen
->destroy
== trace_screen_destroy
);
545 return (struct trace_screen
*)screen
;