trace: implement render_condition
authorMarek Olšák <maraeo@gmail.com>
Sun, 29 May 2011 01:32:54 +0000 (03:32 +0200)
committerMarek Olšák <maraeo@gmail.com>
Sun, 29 May 2011 14:17:11 +0000 (16:17 +0200)
src/gallium/drivers/trace/tr_context.c

index 4f0d6c4b97acfc2312689fd45fb29a8426f4823a..14e8b0ce8c4f20300d556e6e79e6db4139c49af2 100644 (file)
@@ -1422,6 +1422,25 @@ static void trace_redefine_user_buffer(struct pipe_context *_context,
 }
 
 
+static void trace_render_condition(struct pipe_context *_context,
+                                   struct pipe_query *query,
+                                   uint mode)
+{
+   struct trace_context *tr_context = trace_context(_context);
+   struct pipe_context *context = tr_context->pipe;
+
+   trace_dump_call_begin("pipe_context", "render_condition");
+
+   trace_dump_arg(ptr, context);
+   trace_dump_arg(ptr, query);
+   trace_dump_arg(uint, mode);
+
+   trace_dump_call_end();
+
+   context->render_condition(context, query, mode);
+}
+
+
 static const struct debug_named_value rbug_blocker_flags[] = {
    {"before", 1, NULL},
    {"after", 2, NULL},
@@ -1499,6 +1518,7 @@ trace_context_create(struct trace_screen *tr_scr,
    tr_ctx->base.clear_render_target = trace_context_clear_render_target;
    tr_ctx->base.clear_depth_stencil = trace_context_clear_depth_stencil;
    tr_ctx->base.flush = trace_context_flush;
+   tr_ctx->base.render_condition = pipe->render_condition ? trace_render_condition : NULL;
 
    tr_ctx->base.get_transfer = trace_context_get_transfer;
    tr_ctx->base.transfer_destroy = trace_context_transfer_destroy;