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 "pipe/p_util.h"
30 #include "tr_stream.h"
33 #include "tr_winsys.h"
34 #include "tr_screen.h"
38 trace_screen_get_name(struct pipe_screen
*_screen
)
40 struct trace_screen
*tr_scr
= trace_screen(_screen
);
41 struct trace_stream
*stream
= tr_scr
->stream
;
42 struct pipe_screen
*screen
= tr_scr
->screen
;
45 trace_dump_call_begin(stream
, "pipe_screen", "get_name");
47 trace_dump_arg(stream
, ptr
, screen
);
49 result
= screen
->get_name(screen
);
51 trace_dump_ret(stream
, string
, result
);
53 trace_dump_call_end(stream
);
60 trace_screen_get_vendor(struct pipe_screen
*_screen
)
62 struct trace_screen
*tr_scr
= trace_screen(_screen
);
63 struct trace_stream
*stream
= tr_scr
->stream
;
64 struct pipe_screen
*screen
= tr_scr
->screen
;
67 trace_dump_call_begin(stream
, "pipe_screen", "get_vendor");
69 trace_dump_arg(stream
, ptr
, screen
);
71 result
= screen
->get_vendor(screen
);
73 trace_dump_ret(stream
, string
, result
);
75 trace_dump_call_end(stream
);
82 trace_screen_get_param(struct pipe_screen
*_screen
,
85 struct trace_screen
*tr_scr
= trace_screen(_screen
);
86 struct trace_stream
*stream
= tr_scr
->stream
;
87 struct pipe_screen
*screen
= tr_scr
->screen
;
90 trace_dump_call_begin(stream
, "pipe_screen", "get_param");
92 trace_dump_arg(stream
, ptr
, screen
);
93 trace_dump_arg(stream
, int, param
);
95 result
= screen
->get_param(screen
, param
);
97 trace_dump_ret(stream
, int, result
);
99 trace_dump_call_end(stream
);
106 trace_screen_get_paramf(struct pipe_screen
*_screen
,
109 struct trace_screen
*tr_scr
= trace_screen(_screen
);
110 struct trace_stream
*stream
= tr_scr
->stream
;
111 struct pipe_screen
*screen
= tr_scr
->screen
;
114 trace_dump_call_begin(stream
, "pipe_screen", "get_paramf");
116 trace_dump_arg(stream
, ptr
, screen
);
117 trace_dump_arg(stream
, int, param
);
119 result
= screen
->get_paramf(screen
, param
);
121 trace_dump_ret(stream
, float, result
);
123 trace_dump_call_end(stream
);
130 trace_screen_is_format_supported(struct pipe_screen
*_screen
,
131 enum pipe_format format
,
132 enum pipe_texture_target target
,
136 struct trace_screen
*tr_scr
= trace_screen(_screen
);
137 struct trace_stream
*stream
= tr_scr
->stream
;
138 struct pipe_screen
*screen
= tr_scr
->screen
;
141 trace_dump_call_begin(stream
, "pipe_screen", "is_format_supported");
143 trace_dump_arg(stream
, ptr
, screen
);
144 trace_dump_arg(stream
, format
, format
);
145 trace_dump_arg(stream
, int, target
);
146 trace_dump_arg(stream
, uint
, tex_usage
);
147 trace_dump_arg(stream
, uint
, geom_flags
);
149 result
= screen
->is_format_supported(screen
, format
, target
, tex_usage
, geom_flags
);
151 trace_dump_ret(stream
, bool, result
);
153 trace_dump_call_end(stream
);
159 static struct pipe_texture
*
160 trace_screen_texture_create(struct pipe_screen
*_screen
,
161 const struct pipe_texture
*templat
)
163 struct trace_screen
*tr_scr
= trace_screen(_screen
);
164 struct trace_stream
*stream
= tr_scr
->stream
;
165 struct pipe_screen
*screen
= tr_scr
->screen
;
166 struct pipe_texture
*result
;
168 trace_dump_call_begin(stream
, "pipe_screen", "texture_create");
170 trace_dump_arg(stream
, ptr
, screen
);
171 trace_dump_arg(stream
, template, templat
);
173 result
= screen
->texture_create(screen
, templat
);
175 trace_dump_ret(stream
, ptr
, result
);
177 trace_dump_call_end(stream
);
183 static struct pipe_texture
*
184 trace_screen_texture_blanket(struct pipe_screen
*_screen
,
185 const struct pipe_texture
*templat
,
186 const unsigned *ppitch
,
187 struct pipe_buffer
*buffer
)
189 struct trace_screen
*tr_scr
= trace_screen(_screen
);
190 struct trace_stream
*stream
= tr_scr
->stream
;
191 struct pipe_screen
*screen
= tr_scr
->screen
;
192 unsigned pitch
= *ppitch
;
193 struct pipe_texture
*result
;
195 trace_dump_call_begin(stream
, "pipe_screen", "texture_blanket");
197 trace_dump_arg(stream
, ptr
, screen
);
198 trace_dump_arg(stream
, template, templat
);
199 trace_dump_arg(stream
, uint
, pitch
);
200 trace_dump_arg(stream
, ptr
, buffer
);
202 result
= screen
->texture_blanket(screen
, templat
, ppitch
, buffer
);
204 trace_dump_ret(stream
, ptr
, result
);
206 trace_dump_call_end(stream
);
213 trace_screen_texture_release(struct pipe_screen
*_screen
,
214 struct pipe_texture
**ptexture
)
216 struct trace_screen
*tr_scr
= trace_screen(_screen
);
217 struct trace_stream
*stream
= tr_scr
->stream
;
218 struct pipe_screen
*screen
= tr_scr
->screen
;
219 struct pipe_texture
*texture
= *ptexture
;
221 trace_dump_call_begin(stream
, "pipe_screen", "texture_release");
223 trace_dump_arg(stream
, ptr
, screen
);
224 trace_dump_arg(stream
, ptr
, texture
);
226 screen
->texture_release(screen
, ptexture
);
228 trace_dump_call_end(stream
);
231 static struct pipe_surface
*
232 trace_screen_get_tex_surface(struct pipe_screen
*_screen
,
233 struct pipe_texture
*texture
,
234 unsigned face
, unsigned level
,
238 struct trace_screen
*tr_scr
= trace_screen(_screen
);
239 struct trace_stream
*stream
= tr_scr
->stream
;
240 struct pipe_screen
*screen
= tr_scr
->screen
;
241 struct pipe_surface
*result
;
243 trace_dump_call_begin(stream
, "pipe_screen", "get_tex_surface");
245 trace_dump_arg(stream
, ptr
, screen
);
246 trace_dump_arg(stream
, ptr
, texture
);
247 trace_dump_arg(stream
, uint
, face
);
248 trace_dump_arg(stream
, uint
, level
);
249 trace_dump_arg(stream
, uint
, zslice
);
250 trace_dump_arg(stream
, uint
, usage
);
252 result
= screen
->get_tex_surface(screen
, texture
, face
, level
, zslice
, usage
);
254 trace_dump_ret(stream
, ptr
, result
);
256 trace_dump_call_end(stream
);
263 trace_screen_tex_surface_release(struct pipe_screen
*_screen
,
264 struct pipe_surface
**psurface
)
266 struct trace_screen
*tr_scr
= trace_screen(_screen
);
267 struct trace_stream
*stream
= tr_scr
->stream
;
268 struct pipe_screen
*screen
= tr_scr
->screen
;
269 struct pipe_surface
*surface
= *psurface
;
271 trace_dump_call_begin(stream
, "pipe_screen", "tex_surface_release");
273 trace_dump_arg(stream
, ptr
, screen
);
274 trace_dump_arg(stream
, ptr
, surface
);
276 screen
->tex_surface_release(screen
, psurface
);
278 trace_dump_call_end(stream
);
283 trace_screen_surface_map(struct pipe_screen
*_screen
,
284 struct pipe_surface
*surface
,
287 struct trace_screen
*tr_scr
= trace_screen(_screen
);
288 struct trace_stream
*stream
= tr_scr
->stream
;
289 struct pipe_screen
*screen
= tr_scr
->screen
;
290 struct pipe_surface
*result
;
292 trace_dump_call_begin(stream
, "pipe_screen", "surface_map");
294 trace_dump_arg(stream
, ptr
, screen
);
295 trace_dump_arg(stream
, ptr
, surface
);
296 trace_dump_arg(stream
, uint
, flags
);
298 result
= screen
->surface_map(screen
, surface
, flags
);
300 trace_dump_ret(stream
, ptr
, result
);
302 trace_dump_call_end(stream
);
309 trace_screen_surface_unmap(struct pipe_screen
*_screen
,
310 struct pipe_surface
*surface
)
312 struct trace_screen
*tr_scr
= trace_screen(_screen
);
313 struct trace_stream
*stream
= tr_scr
->stream
;
314 struct pipe_screen
*screen
= tr_scr
->screen
;
316 trace_dump_call_begin(stream
, "pipe_screen", "surface_unmap");
318 trace_dump_arg(stream
, ptr
, screen
);
319 trace_dump_arg(stream
, ptr
, surface
);
321 screen
->surface_unmap(screen
, surface
);
323 trace_dump_call_end(stream
);
328 trace_screen_destroy(struct pipe_screen
*_screen
)
330 struct trace_screen
*tr_scr
= trace_screen(_screen
);
331 struct trace_stream
*stream
= tr_scr
->stream
;
332 struct pipe_screen
*screen
= tr_scr
->screen
;
334 trace_dump_call_begin(stream
, "pipe_screen", "destroy");
336 trace_dump_arg(stream
, ptr
, screen
);
338 screen
->destroy(screen
);
340 trace_dump_call_end(stream
);
347 trace_screen_create(struct pipe_screen
*screen
)
349 struct trace_stream
*stream
;
350 struct trace_screen
*tr_scr
;
352 if(!debug_get_bool_option("GALLIUM_TRACE", FALSE
))
355 tr_scr
= CALLOC_STRUCT(trace_screen
);
359 tr_scr
->base
.winsys
= screen
->winsys
;
360 tr_scr
->base
.destroy
= trace_screen_destroy
;
361 tr_scr
->base
.get_name
= trace_screen_get_name
;
362 tr_scr
->base
.get_vendor
= trace_screen_get_vendor
;
363 tr_scr
->base
.get_param
= trace_screen_get_param
;
364 tr_scr
->base
.get_paramf
= trace_screen_get_paramf
;
365 tr_scr
->base
.is_format_supported
= trace_screen_is_format_supported
;
366 tr_scr
->base
.texture_create
= trace_screen_texture_create
;
367 tr_scr
->base
.texture_blanket
= trace_screen_texture_blanket
;
368 tr_scr
->base
.texture_release
= trace_screen_texture_release
;
369 tr_scr
->base
.get_tex_surface
= trace_screen_get_tex_surface
;
370 tr_scr
->base
.tex_surface_release
= trace_screen_tex_surface_release
;
371 tr_scr
->base
.surface_map
= trace_screen_surface_map
;
372 tr_scr
->base
.surface_unmap
= trace_screen_surface_unmap
;
374 tr_scr
->screen
= screen
;
375 tr_scr
->stream
= stream
= trace_winsys(screen
->winsys
)->stream
;
377 /* We don't want to trace the internal pipe calls */
378 screen
->winsys
= trace_winsys(screen
->winsys
)->winsys
;
380 trace_dump_call_begin(stream
, "", "pipe_screen_create");
381 trace_dump_arg_begin(stream
, "winsys");
382 trace_dump_ptr(stream
, screen
->winsys
);
383 trace_dump_arg_end(stream
);
384 trace_dump_ret(stream
, ptr
, screen
);
385 trace_dump_call_end(stream
);
387 return &tr_scr
->base
;