diff options
author | Brian Paul <[email protected]> | 2013-09-12 15:08:04 -0600 |
---|---|---|
committer | Brian Paul <[email protected]> | 2013-10-03 14:05:26 -0600 |
commit | e64112b1f95e2ce4d7172e286f6c097d82387f01 (patch) | |
tree | 6e169c9a87b06c86e7d226ef17d885a51b23fc57 /src/gallium/drivers | |
parent | bd1514849b02297693f293df79b47352445f9a51 (diff) |
rbug: implement pipe_context::bind_sampler_states()
Diffstat (limited to 'src/gallium/drivers')
-rw-r--r-- | src/gallium/drivers/rbug/rbug_context.c | 34 |
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 a103dfb5a7e..be1f56144fe 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; |