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"
29 #include "pipe/p_state.h"
30 #include "util/u_hash_table.h"
32 #include "tr_stream.h"
35 #include "tr_winsys.h"
38 static unsigned trace_buffer_hash(void *buffer
)
40 return (unsigned)(uintptr_t)buffer
;
44 static int trace_buffer_compare(void *buffer1
, void *buffer2
)
46 return (char *)buffer2
- (char *)buffer1
;
51 trace_winsys_get_name(struct pipe_winsys
*_winsys
)
53 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
54 struct trace_stream
*stream
= tr_ws
->stream
;
55 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
58 trace_dump_call_begin(stream
, "pipe_winsys", "get_name");
60 trace_dump_arg(stream
, ptr
, winsys
);
62 result
= winsys
->get_name(winsys
);
64 trace_dump_ret(stream
, string
, result
);
66 trace_dump_call_end(stream
);
73 trace_winsys_flush_frontbuffer(struct pipe_winsys
*_winsys
,
74 struct pipe_surface
*surface
,
75 void *context_private
)
77 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
78 struct trace_stream
*stream
= tr_ws
->stream
;
79 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
81 trace_dump_call_begin(stream
, "pipe_winsys", "flush_frontbuffer");
83 trace_dump_arg(stream
, ptr
, winsys
);
84 trace_dump_arg(stream
, ptr
, surface
);
85 trace_dump_arg(stream
, ptr
, context_private
);
87 winsys
->flush_frontbuffer(winsys
, surface
, context_private
);
89 trace_dump_call_end(stream
);
93 static struct pipe_surface
*
94 trace_winsys_surface_alloc(struct pipe_winsys
*_winsys
)
96 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
97 struct trace_stream
*stream
= tr_ws
->stream
;
98 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
99 struct pipe_surface
*result
;
101 trace_dump_call_begin(stream
, "pipe_winsys", "surface_alloc");
103 trace_dump_arg(stream
, ptr
, winsys
);
105 result
= winsys
->surface_alloc(winsys
);
107 trace_dump_ret(stream
, ptr
, result
);
109 trace_dump_call_end(stream
);
116 trace_winsys_surface_alloc_storage(struct pipe_winsys
*_winsys
,
117 struct pipe_surface
*surface
,
118 unsigned width
, unsigned height
,
119 enum pipe_format format
,
123 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
124 struct trace_stream
*stream
= tr_ws
->stream
;
125 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
128 trace_dump_call_begin(stream
, "pipe_winsys", "surface_alloc_storage");
130 trace_dump_arg(stream
, ptr
, winsys
);
131 trace_dump_arg(stream
, ptr
, surface
);
132 trace_dump_arg(stream
, uint
, width
);
133 trace_dump_arg(stream
, uint
, height
);
134 trace_dump_arg(stream
, format
, format
);
135 trace_dump_arg(stream
, uint
, flags
);
136 trace_dump_arg(stream
, uint
, tex_usage
);
138 result
= winsys
->surface_alloc_storage(winsys
,
145 trace_dump_ret(stream
, int, result
);
147 trace_dump_call_end(stream
);
154 trace_winsys_surface_release(struct pipe_winsys
*_winsys
,
155 struct pipe_surface
**psurface
)
157 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
158 struct trace_stream
*stream
= tr_ws
->stream
;
159 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
160 struct pipe_surface
*surface
= *psurface
;
162 trace_dump_call_begin(stream
, "pipe_winsys", "surface_release");
164 trace_dump_arg(stream
, ptr
, winsys
);
165 trace_dump_arg(stream
, ptr
, surface
);
167 winsys
->surface_release(winsys
, psurface
);
169 trace_dump_call_end(stream
);
173 static struct pipe_buffer
*
174 trace_winsys_buffer_create(struct pipe_winsys
*_winsys
,
179 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
180 struct trace_stream
*stream
= tr_ws
->stream
;
181 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
182 struct pipe_buffer
*buffer
;
184 trace_dump_call_begin(stream
, "pipe_winsys", "buffer_create");
186 trace_dump_arg(stream
, ptr
, winsys
);
187 trace_dump_arg(stream
, uint
, alignment
);
188 trace_dump_arg(stream
, uint
, usage
);
189 trace_dump_arg(stream
, uint
, size
);
191 buffer
= winsys
->buffer_create(winsys
, alignment
, usage
, size
);
193 trace_dump_ret(stream
, ptr
, buffer
);
195 trace_dump_call_end(stream
);
197 /* Zero the buffer to avoid dumping uninitialized memory */
198 if(buffer
->usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
200 map
= winsys
->buffer_map(winsys
, buffer
, PIPE_BUFFER_USAGE_CPU_WRITE
);
202 memset(map
, 0, buffer
->size
);
203 winsys
->buffer_unmap(winsys
, buffer
);
211 static struct pipe_buffer
*
212 trace_winsys_user_buffer_create(struct pipe_winsys
*_winsys
,
216 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
217 struct trace_stream
*stream
= tr_ws
->stream
;
218 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
219 struct pipe_buffer
*result
;
221 trace_dump_call_begin(stream
, "pipe_winsys", "user_buffer_create");
223 trace_dump_arg(stream
, ptr
, winsys
);
224 trace_dump_arg(stream
, ptr
, ptr
);
225 trace_dump_arg(stream
, uint
, bytes
);
227 result
= winsys
->user_buffer_create(winsys
, ptr
, bytes
);
229 trace_dump_ret(stream
, ptr
, result
);
231 trace_dump_call_end(stream
);
238 trace_winsys_buffer_map(struct pipe_winsys
*_winsys
,
239 struct pipe_buffer
*buffer
,
242 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
243 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
246 map
= winsys
->buffer_map(winsys
, buffer
, usage
);
248 if(usage
& PIPE_BUFFER_USAGE_CPU_WRITE
) {
249 assert(!hash_table_get(tr_ws
->buffer_maps
, buffer
));
250 hash_table_set(tr_ws
->buffer_maps
, buffer
, map
);
259 trace_winsys_buffer_unmap(struct pipe_winsys
*_winsys
,
260 struct pipe_buffer
*buffer
)
262 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
263 struct trace_stream
*stream
= tr_ws
->stream
;
264 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
267 map
= hash_table_get(tr_ws
->buffer_maps
, buffer
);
269 trace_dump_call_begin(stream
, "pipe_winsys", "buffer_write");
271 trace_dump_arg(stream
, ptr
, buffer
);
273 trace_dump_arg_begin(stream
, "data");
274 trace_dump_bytes(stream
, map
, buffer
->size
);
275 trace_dump_arg_end(stream
);
277 trace_dump_arg_begin(stream
, "size");
278 trace_dump_uint(stream
, buffer
->size
);
279 trace_dump_arg_end(stream
);
281 trace_dump_call_end(stream
);
283 hash_table_remove(tr_ws
->buffer_maps
, buffer
);
286 winsys
->buffer_unmap(winsys
, buffer
);
291 trace_winsys_buffer_destroy(struct pipe_winsys
*_winsys
,
292 struct pipe_buffer
*buffer
)
294 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
295 struct trace_stream
*stream
= tr_ws
->stream
;
296 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
298 trace_dump_call_begin(stream
, "pipe_winsys", "buffer_destroy");
300 trace_dump_arg(stream
, ptr
, winsys
);
301 trace_dump_arg(stream
, ptr
, buffer
);
303 winsys
->buffer_destroy(winsys
, buffer
);
305 trace_dump_call_end(stream
);
310 trace_winsys_fence_reference(struct pipe_winsys
*_winsys
,
311 struct pipe_fence_handle
**pdst
,
312 struct pipe_fence_handle
*src
)
314 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
315 struct trace_stream
*stream
= tr_ws
->stream
;
316 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
317 struct pipe_fence_handle
*dst
= *pdst
;
319 trace_dump_call_begin(stream
, "pipe_winsys", "fence_reference");
321 trace_dump_arg(stream
, ptr
, winsys
);
322 trace_dump_arg(stream
, ptr
, dst
);
323 trace_dump_arg(stream
, ptr
, src
);
325 winsys
->fence_reference(winsys
, pdst
, src
);
327 trace_dump_call_end(stream
);
332 trace_winsys_fence_signalled(struct pipe_winsys
*_winsys
,
333 struct pipe_fence_handle
*fence
,
336 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
337 struct trace_stream
*stream
= tr_ws
->stream
;
338 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
341 trace_dump_call_begin(stream
, "pipe_winsys", "fence_signalled");
343 trace_dump_arg(stream
, ptr
, winsys
);
344 trace_dump_arg(stream
, ptr
, fence
);
345 trace_dump_arg(stream
, uint
, flag
);
347 result
= winsys
->fence_signalled(winsys
, fence
, flag
);
349 trace_dump_ret(stream
, int, result
);
351 trace_dump_call_end(stream
);
358 trace_winsys_fence_finish(struct pipe_winsys
*_winsys
,
359 struct pipe_fence_handle
*fence
,
362 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
363 struct trace_stream
*stream
= tr_ws
->stream
;
364 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
367 trace_dump_call_begin(stream
, "pipe_winsys", "fence_finish");
369 trace_dump_arg(stream
, ptr
, winsys
);
370 trace_dump_arg(stream
, ptr
, fence
);
371 trace_dump_arg(stream
, uint
, flag
);
373 result
= winsys
->fence_finish(winsys
, fence
, flag
);
375 trace_dump_ret(stream
, int, result
);
377 trace_dump_call_end(stream
);
384 trace_winsys_destroy(struct pipe_winsys
*_winsys
)
386 struct trace_winsys
*tr_ws
= trace_winsys(_winsys
);
387 struct trace_stream
*stream
= tr_ws
->stream
;
388 struct pipe_winsys
*winsys
= tr_ws
->winsys
;
390 trace_dump_call_begin(stream
, "pipe_winsys", "destroy");
392 trace_dump_arg(stream
, ptr
, winsys
);
394 winsys
->destroy(winsys
);
396 trace_dump_call_end(stream
);
398 trace_dump_trace_end(stream
);
400 hash_table_destroy(tr_ws
->buffer_maps
);
402 trace_stream_close(tr_ws
->stream
);
409 trace_winsys_create(struct pipe_winsys
*winsys
)
411 struct trace_stream
*stream
;
412 struct trace_winsys
*tr_ws
;
414 if(!debug_get_bool_option("GALLIUM_TRACE", FALSE
))
417 tr_ws
= CALLOC_STRUCT(trace_winsys
);
421 tr_ws
->base
.destroy
= trace_winsys_destroy
;
422 tr_ws
->base
.get_name
= trace_winsys_get_name
;
423 tr_ws
->base
.flush_frontbuffer
= trace_winsys_flush_frontbuffer
;
424 tr_ws
->base
.surface_alloc
= trace_winsys_surface_alloc
;
425 tr_ws
->base
.surface_alloc_storage
= trace_winsys_surface_alloc_storage
;
426 tr_ws
->base
.surface_release
= trace_winsys_surface_release
;
427 tr_ws
->base
.buffer_create
= trace_winsys_buffer_create
;
428 tr_ws
->base
.user_buffer_create
= trace_winsys_user_buffer_create
;
429 tr_ws
->base
.buffer_map
= trace_winsys_buffer_map
;
430 tr_ws
->base
.buffer_unmap
= trace_winsys_buffer_unmap
;
431 tr_ws
->base
.buffer_destroy
= trace_winsys_buffer_destroy
;
432 tr_ws
->base
.fence_reference
= trace_winsys_fence_reference
;
433 tr_ws
->base
.fence_signalled
= trace_winsys_fence_signalled
;
434 tr_ws
->base
.fence_finish
= trace_winsys_fence_finish
;
436 tr_ws
->winsys
= winsys
;
438 tr_ws
->stream
= stream
= trace_stream_create("gallium", "trace");
442 tr_ws
->buffer_maps
= hash_table_create(trace_buffer_hash
,
443 trace_buffer_compare
);
444 if(!tr_ws
->buffer_maps
)
447 trace_dump_trace_begin(tr_ws
->stream
, 0);
449 trace_dump_call_begin(stream
, "", "pipe_winsys_create");
450 trace_dump_ret(stream
, ptr
, winsys
);
451 trace_dump_call_end(stream
);