From 3f0627c2ad605b006737312c478907859411ffa8 Mon Sep 17 00:00:00 2001 From: Brian Paul Date: Thu, 12 Sep 2013 18:09:33 -0600 Subject: nouveau: implement pipe_context::bind_sampler_states() --- src/gallium/drivers/nouveau/nvc0/nvc0_state.c | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'src/gallium/drivers/nouveau/nvc0') diff --git a/src/gallium/drivers/nouveau/nvc0/nvc0_state.c b/src/gallium/drivers/nouveau/nvc0/nvc0_state.c index e56ef0160f2..e3117d443a2 100644 --- a/src/gallium/drivers/nouveau/nvc0/nvc0_state.c +++ b/src/gallium/drivers/nouveau/nvc0/nvc0_state.c @@ -540,6 +540,32 @@ nvc0_cp_sampler_states_bind(struct pipe_context *pipe, nvc0_context(pipe)->dirty_cp |= NVC0_NEW_CP_SAMPLERS; } +static void +nvc0_bind_sampler_states(struct pipe_context *pipe, unsigned shader, + unsigned start, unsigned nr, void **s) +{ + switch (shader) { + case PIPE_SHADER_VERTEX: + assert(start == 0); + nvc0_stage_sampler_states_bind(nvc0_context(pipe), 0, nr, s); + break; + case PIPE_SHADER_GEOMETRY: + assert(start == 0); + nvc0_stage_sampler_states_bind(nvc0_context(pipe), 3, nr, s); + break; + case PIPE_SHADER_FRAGMENT: + assert(start == 0); + nvc0_stage_sampler_states_bind(nvc0_context(pipe), 4, nr, s); + break; + case PIPE_SHADER_COMPUTE: + nvc0_stage_sampler_states_bind_range(nvc0_context(pipe), 5, + start, nr, s); + nvc0_context(pipe)->dirty_cp |= NVC0_NEW_CP_SAMPLERS; + break; + } +} + + /* NOTE: only called when not referenced anywhere, won't be bound */ static void nvc0_sampler_view_destroy(struct pipe_context *pipe, @@ -1194,6 +1220,7 @@ nvc0_init_state_functions(struct nvc0_context *nvc0) pipe->create_sampler_state = nv50_sampler_state_create; pipe->delete_sampler_state = nvc0_sampler_state_delete; + pipe->bind_sampler_states = nvc0_bind_sampler_states; pipe->bind_vertex_sampler_states = nvc0_vp_sampler_states_bind; pipe->bind_fragment_sampler_states = nvc0_fp_sampler_states_bind; pipe->bind_geometry_sampler_states = nvc0_gp_sampler_states_bind; -- cgit v1.2.3