diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/gallium/drivers/r600/evergreen_state.c | 25 | ||||
| -rw-r--r-- | src/gallium/drivers/r600/r600_pipe.h | 6 | ||||
| -rw-r--r-- | src/gallium/drivers/r600/r600_state.c | 25 | 
3 files changed, 42 insertions, 14 deletions
| diff --git a/src/gallium/drivers/r600/evergreen_state.c b/src/gallium/drivers/r600/evergreen_state.c index 935496c04a..ce34ed4ad3 100644 --- a/src/gallium/drivers/r600/evergreen_state.c +++ b/src/gallium/drivers/r600/evergreen_state.c @@ -500,15 +500,27 @@ static void evergreen_set_ps_sampler_view(struct pipe_context *ctx, unsigned cou  {  	struct r600_pipe_context *rctx = (struct r600_pipe_context *)ctx;  	struct r600_pipe_sampler_view **resource = (struct r600_pipe_sampler_view **)views; +	int i; -	rctx->ps_samplers.views = resource; -	rctx->ps_samplers.n_views = count; +	for (i = 0; i < count; i++) { +		if (&rctx->ps_samplers.views[i]->base != views[i]) { +			if (resource[i]) +				evergreen_context_pipe_state_set_ps_resource(&rctx->ctx, &resource[i]->state, i); +			else +				evergreen_context_pipe_state_set_ps_resource(&rctx->ctx, NULL, i); -	for (int i = 0; i < count; i++) { -		if (resource[i]) { -			evergreen_context_pipe_state_set_ps_resource(&rctx->ctx, &resource[i]->state, i); +			pipe_sampler_view_reference( +				(struct pipe_sampler_view **)&rctx->ps_samplers.views[i], +				views[i]);  		}  	} +	for (i = count; i < NUM_TEX_UNITS; i++) { +		if (rctx->ps_samplers.views[i]) { +			evergreen_context_pipe_state_set_ps_resource(&rctx->ctx, NULL, i); +			pipe_sampler_view_reference((struct pipe_sampler_view **)&rctx->ps_samplers.views[i], NULL); +		} +	} +	rctx->ps_samplers.n_views = count;  }  static void evergreen_bind_state(struct pipe_context *ctx, void *state) @@ -527,7 +539,8 @@ static void evergreen_bind_ps_sampler(struct pipe_context *ctx, unsigned count,  	struct r600_pipe_context *rctx = (struct r600_pipe_context *)ctx;  	struct r600_pipe_state **rstates = (struct r600_pipe_state **)states; -	rctx->ps_samplers.samplers = states; + +	memcpy(rctx->ps_samplers.samplers, states, sizeof(void*) * count);  	rctx->ps_samplers.n_samplers = count;  	for (int i = 0; i < count; i++) { diff --git a/src/gallium/drivers/r600/r600_pipe.h b/src/gallium/drivers/r600/r600_pipe.h index 35548329e4..e7c4b60d00 100644 --- a/src/gallium/drivers/r600/r600_pipe.h +++ b/src/gallium/drivers/r600/r600_pipe.h @@ -94,10 +94,12 @@ struct r600_pipe_shader {  };  /* needed for blitter save */ +#define NUM_TEX_UNITS 16 +  struct r600_textures_info { -	struct r600_pipe_sampler_view   **views; +	struct r600_pipe_sampler_view   *views[NUM_TEX_UNITS];  	unsigned                        n_views; -	void				**samplers; +	void				*samplers[NUM_TEX_UNITS];  	unsigned                        n_samplers;  }; diff --git a/src/gallium/drivers/r600/r600_state.c b/src/gallium/drivers/r600/r600_state.c index 00234f956a..a95e2c6590 100644 --- a/src/gallium/drivers/r600/r600_state.c +++ b/src/gallium/drivers/r600/r600_state.c @@ -710,15 +710,28 @@ static void r600_set_ps_sampler_view(struct pipe_context *ctx, unsigned count,  {  	struct r600_pipe_context *rctx = (struct r600_pipe_context *)ctx;  	struct r600_pipe_sampler_view **resource = (struct r600_pipe_sampler_view **)views; +	int i; -	rctx->ps_samplers.views = resource; -	rctx->ps_samplers.n_views = count; +	for (i = 0; i < count; i++) { +		if (&rctx->ps_samplers.views[i]->base != views[i]) { +			if (resource[i]) +				r600_context_pipe_state_set_ps_resource(&rctx->ctx, &resource[i]->state, i); +			else +				r600_context_pipe_state_set_ps_resource(&rctx->ctx, NULL, i); + +			pipe_sampler_view_reference( +				(struct pipe_sampler_view **)&rctx->ps_samplers.views[i], +				views[i]); -	for (int i = 0; i < count; i++) { -		if (resource[i]) { -			r600_context_pipe_state_set_ps_resource(&rctx->ctx, &resource[i]->state, i);  		}  	} +	for (i = count; i < NUM_TEX_UNITS; i++) { +		if (rctx->ps_samplers.views[i]) { +			r600_context_pipe_state_set_ps_resource(&rctx->ctx, NULL, i); +			pipe_sampler_view_reference((struct pipe_sampler_view **)&rctx->ps_samplers.views[i], NULL); +		} +	} +	rctx->ps_samplers.n_views = count;  }  static void r600_bind_state(struct pipe_context *ctx, void *state) @@ -737,7 +750,7 @@ static void r600_bind_ps_sampler(struct pipe_context *ctx, unsigned count, void  	struct r600_pipe_context *rctx = (struct r600_pipe_context *)ctx;  	struct r600_pipe_state **rstates = (struct r600_pipe_state **)states; -	rctx->ps_samplers.samplers = states; +	memcpy(rctx->ps_samplers.samplers, states, sizeof(void*) * count);  	rctx->ps_samplers.n_samplers = count;  	for (int i = 0; i < count; i++) { | 
