From: José Fonseca Date: Mon, 21 Apr 2008 11:44:45 +0000 (+0900) Subject: gallium: Do not mistake pipe state objects for state tracker state objects. X-Git-Tag: 062012170305~17580^2~390^2~1783 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=08717d94619802f7816420be155c0c92fa727109;p=profile%2Fivi%2Fmesa.git gallium: Do not mistake pipe state objects for state tracker state objects. --- diff --git a/src/gallium/auxiliary/cso_cache/cso_context.c b/src/gallium/auxiliary/cso_cache/cso_context.c index 746b176..4541be8 100644 --- a/src/gallium/auxiliary/cso_cache/cso_context.c +++ b/src/gallium/auxiliary/cso_cache/cso_context.c @@ -266,8 +266,9 @@ void cso_save_samplers(struct cso_context *ctx) void cso_restore_samplers(struct cso_context *ctx) { - cso_set_samplers(ctx, ctx->nr_samplers_saved, - (const struct pipe_sampler_state **) ctx->samplers_saved); + ctx->nr_samplers = ctx->nr_samplers_saved; + memcpy(ctx->samplers, ctx->samplers_saved, sizeof(ctx->samplers)); + cso_single_sampler_done( ctx ); } @@ -313,6 +314,8 @@ void cso_restore_sampler_textures( struct cso_context *ctx ) pipe_texture_reference(&ctx->textures[i], NULL); ctx->pipe->set_sampler_textures(ctx->pipe, ctx->nr_textures, ctx->textures); + + ctx->nr_textures_saved = 0; }