summaryrefslogtreecommitdiff
path: root/src/gallium/auxiliary/cso_cache
diff options
context:
space:
mode:
authorKeith Whitwell <keith@tungstengraphics.com>2008-04-21 20:25:47 +0100
committerKeith Whitwell <keith@tungstengraphics.com>2008-04-21 20:52:54 +0100
commit1dc5e56f3e48b629daa18c2d8631c96bda638eb6 (patch)
tree5c985861afe45bc653dc7081cd62e0fe1c90e1fa /src/gallium/auxiliary/cso_cache
parentc2afa182f31ed4a8be01078c2b8bedcd881cd157 (diff)
cso: provide functions to bind fs/vs handles directly
Diffstat (limited to 'src/gallium/auxiliary/cso_cache')
-rw-r--r--src/gallium/auxiliary/cso_cache/cso_context.c32
-rw-r--r--src/gallium/auxiliary/cso_cache/cso_context.h4
2 files changed, 28 insertions, 8 deletions
diff --git a/src/gallium/auxiliary/cso_cache/cso_context.c b/src/gallium/auxiliary/cso_cache/cso_context.c
index 87995c80c3..e6366e7b14 100644
--- a/src/gallium/auxiliary/cso_cache/cso_context.c
+++ b/src/gallium/auxiliary/cso_cache/cso_context.c
@@ -422,6 +422,16 @@ void cso_restore_rasterizer(struct cso_context *ctx)
}
+void cso_set_fragment_shader_handle(struct cso_context *ctx,
+ void *handle )
+{
+ if (ctx->fragment_shader != handle) {
+ ctx->fragment_shader = handle;
+ ctx->pipe->bind_fs_state(ctx->pipe, handle);
+ }
+}
+
+
void cso_set_fragment_shader(struct cso_context *ctx,
const struct pipe_shader_state *templ)
{
@@ -453,10 +463,7 @@ void cso_set_fragment_shader(struct cso_context *ctx,
handle = ((struct cso_fragment_shader *)cso_hash_iter_data(iter))->data;
}
- if (ctx->fragment_shader != handle) {
- ctx->fragment_shader = handle;
- ctx->pipe->bind_fs_state(ctx->pipe, handle);
- }
+ cso_set_fragment_shader_handle( ctx, handle );
}
void cso_save_fragment_shader(struct cso_context *ctx)
@@ -476,6 +483,16 @@ void cso_restore_fragment_shader(struct cso_context *ctx)
}
+void cso_set_vertex_shader_handle(struct cso_context *ctx,
+ void *handle )
+{
+ if (ctx->vertex_shader != handle) {
+ ctx->vertex_shader = handle;
+ ctx->pipe->bind_vs_state(ctx->pipe, handle);
+ }
+}
+
+
void cso_set_vertex_shader(struct cso_context *ctx,
const struct pipe_shader_state *templ)
@@ -503,12 +520,11 @@ void cso_set_vertex_shader(struct cso_context *ctx,
handle = ((struct cso_vertex_shader *)cso_hash_iter_data(iter))->data;
}
- if (ctx->vertex_shader != handle) {
- ctx->vertex_shader = handle;
- ctx->pipe->bind_vs_state(ctx->pipe, handle);
- }
+ cso_set_vertex_shader_handle( ctx, handle );
}
+
+
void cso_save_vertex_shader(struct cso_context *ctx)
{
assert(!ctx->vertex_shader_saved);
diff --git a/src/gallium/auxiliary/cso_cache/cso_context.h b/src/gallium/auxiliary/cso_cache/cso_context.h
index 665e8d9911..945f4881a8 100644
--- a/src/gallium/auxiliary/cso_cache/cso_context.h
+++ b/src/gallium/auxiliary/cso_cache/cso_context.h
@@ -96,6 +96,8 @@ void cso_restore_sampler_textures( struct cso_context *cso );
* (eg mesa's internall-generated texenv programs), it will be up to
* the state tracker to implement their own specialized caching.
*/
+void cso_set_fragment_shader_handle(struct cso_context *ctx,
+ void *handle );
void cso_set_fragment_shader( struct cso_context *cso,
const struct pipe_shader_state *shader );
void cso_save_fragment_shader(struct cso_context *cso);
@@ -103,6 +105,8 @@ void cso_restore_fragment_shader(struct cso_context *cso);
+void cso_set_vertex_shader_handle(struct cso_context *ctx,
+ void *handle );
void cso_set_vertex_shader( struct cso_context *cso,
const struct pipe_shader_state *shader );
void cso_save_vertex_shader(struct cso_context *cso);