summaryrefslogtreecommitdiffstats
path: root/src/gallium/drivers/rbug
diff options
context:
space:
mode:
authorBrian Paul <brianp@vmware.com>2013-09-12 15:08:04 -0600
committerBrian Paul <brianp@vmware.com>2013-10-03 14:05:26 -0600
commite64112b1f95e2ce4d7172e286f6c097d82387f01 (patch)
tree6e169c9a87b06c86e7d226ef17d885a51b23fc57 /src/gallium/drivers/rbug
parentbd1514849b02297693f293df79b47352445f9a51 (diff)
downloadexternal_mesa3d-e64112b1f95e2ce4d7172e286f6c097d82387f01.zip
external_mesa3d-e64112b1f95e2ce4d7172e286f6c097d82387f01.tar.gz
external_mesa3d-e64112b1f95e2ce4d7172e286f6c097d82387f01.tar.bz2
rbug: implement pipe_context::bind_sampler_states()
Diffstat (limited to 'src/gallium/drivers/rbug')
-rw-r--r--src/gallium/drivers/rbug/rbug_context.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/gallium/drivers/rbug/rbug_context.c b/src/gallium/drivers/rbug/rbug_context.c
index a103dfb..be1f561 100644
--- a/src/gallium/drivers/rbug/rbug_context.c
+++ b/src/gallium/drivers/rbug/rbug_context.c
@@ -263,6 +263,39 @@ rbug_create_sampler_state(struct pipe_context *_pipe,
}
static void
+rbug_bind_sampler_states(struct pipe_context *_pipe, unsigned shader,
+ unsigned start, unsigned count,
+ void **samplers)
+{
+ struct rbug_context *rb_pipe = rbug_context(_pipe);
+ struct pipe_context *pipe = rb_pipe->pipe;
+
+ pipe_mutex_lock(rb_pipe->call_mutex);
+ if (pipe->bind_sampler_states) {
+ pipe->bind_sampler_states(pipe, shader, start, count, samplers);
+ }
+ else {
+ assert(start == 0);
+ switch (shader) {
+ case PIPE_SHADER_VERTEX:
+ pipe->bind_vertex_sampler_states(pipe, count, samplers);
+ break;
+ case PIPE_SHADER_FRAGMENT:
+ pipe->bind_fragment_sampler_states(pipe, count, samplers);
+ break;
+ case PIPE_SHADER_GEOMETRY:
+ pipe->bind_geometry_sampler_states(pipe, count, samplers);
+ break;
+ default:
+ ;
+ }
+ }
+
+ pipe_mutex_unlock(rb_pipe->call_mutex);
+}
+
+
+static void
rbug_bind_fragment_sampler_states(struct pipe_context *_pipe,
unsigned num_samplers,
void **samplers)
@@ -1160,6 +1193,7 @@ rbug_context_create(struct pipe_screen *_screen, struct pipe_context *pipe)
rb_pipe->base.bind_blend_state = rbug_bind_blend_state;
rb_pipe->base.delete_blend_state = rbug_delete_blend_state;
rb_pipe->base.create_sampler_state = rbug_create_sampler_state;
+ rb_pipe->base.bind_sampler_states = rbug_bind_sampler_states;
rb_pipe->base.bind_fragment_sampler_states = rbug_bind_fragment_sampler_states;
rb_pipe->base.bind_vertex_sampler_states = rbug_bind_vertex_sampler_states;
rb_pipe->base.delete_sampler_state = rbug_delete_sampler_state;