summaryrefslogtreecommitdiffstats
path: root/src/mesa/pipe
diff options
context:
space:
mode:
Diffstat (limited to 'src/mesa/pipe')
-rw-r--r--src/mesa/pipe/i915simple/i915_context.h2
-rw-r--r--src/mesa/pipe/i915simple/i915_state.c2
-rw-r--r--src/mesa/pipe/p_context.h5
-rw-r--r--src/mesa/pipe/p_state.h4
-rw-r--r--src/mesa/pipe/softpipe/sp_context.h4
-rw-r--r--src/mesa/pipe/softpipe/sp_state.h5
-rw-r--r--src/mesa/pipe/softpipe/sp_state_fs.c14
7 files changed, 23 insertions, 13 deletions
diff --git a/src/mesa/pipe/i915simple/i915_context.h b/src/mesa/pipe/i915simple/i915_context.h
index d69657daa9f..1e48485c568 100644
--- a/src/mesa/pipe/i915simple/i915_context.h
+++ b/src/mesa/pipe/i915simple/i915_context.h
@@ -105,7 +105,7 @@ struct i915_context
struct pipe_clip_state clip;
struct pipe_depth_state depth_test;
struct pipe_framebuffer_state framebuffer;
- struct pipe_fs_state fs;
+ struct pipe_shader_state fs;
struct pipe_poly_stipple poly_stipple;
struct pipe_scissor_state scissor;
struct pipe_sampler_state sampler[PIPE_MAX_SAMPLERS];
diff --git a/src/mesa/pipe/i915simple/i915_state.c b/src/mesa/pipe/i915simple/i915_state.c
index f874b210160..06fa716c4fa 100644
--- a/src/mesa/pipe/i915simple/i915_state.c
+++ b/src/mesa/pipe/i915simple/i915_state.c
@@ -111,7 +111,7 @@ static void i915_set_polygon_stipple( struct pipe_context *pipe,
static void i915_set_fs_state( struct pipe_context *pipe,
- const struct pipe_fs_state *fs )
+ const struct pipe_shader_state *fs )
{
struct i915_context *i915 = i915_context(pipe);
diff --git a/src/mesa/pipe/p_context.h b/src/mesa/pipe/p_context.h
index 6679aae089d..320b4877c3e 100644
--- a/src/mesa/pipe/p_context.h
+++ b/src/mesa/pipe/p_context.h
@@ -117,7 +117,10 @@ struct pipe_context {
const struct pipe_framebuffer_state * );
void (*set_fs_state)( struct pipe_context *,
- const struct pipe_fs_state * );
+ const struct pipe_shader_state * );
+
+ void (*set_vs_state)( struct pipe_context *,
+ const struct pipe_shader_state * );
void (*set_polygon_stipple)( struct pipe_context *,
const struct pipe_poly_stipple * );
diff --git a/src/mesa/pipe/p_state.h b/src/mesa/pipe/p_state.h
index 4878cb41bdf..c1972c56b30 100644
--- a/src/mesa/pipe/p_state.h
+++ b/src/mesa/pipe/p_state.h
@@ -121,8 +121,8 @@ struct pipe_constant_buffer {
};
-struct pipe_fs_state {
- unsigned inputs_read; /* FRAG_ATTRIB_* */
+struct pipe_shader_state {
+ unsigned inputs_read; /* FRAG/VERT_ATTRIB_* */
const struct tgsi_token *tokens;
struct pipe_constant_buffer *constants; /* XXX temporary? */
};
diff --git a/src/mesa/pipe/softpipe/sp_context.h b/src/mesa/pipe/softpipe/sp_context.h
index f45cb6fe2c4..8f184c644a2 100644
--- a/src/mesa/pipe/softpipe/sp_context.h
+++ b/src/mesa/pipe/softpipe/sp_context.h
@@ -63,6 +63,7 @@ enum interp_mode {
#define SP_NEW_TEXTURE 0x800
#define SP_NEW_STENCIL 0x1000
#define SP_NEW_VERTEX 0x2000
+#define SP_NEW_VS 0x4000
struct softpipe_context {
@@ -79,7 +80,8 @@ struct softpipe_context {
struct pipe_clip_state clip;
struct pipe_depth_state depth_test;
struct pipe_framebuffer_state framebuffer;
- struct pipe_fs_state fs;
+ struct pipe_shader_state fs;
+ struct pipe_shader_state vs;
struct pipe_poly_stipple poly_stipple;
struct pipe_scissor_state scissor;
struct pipe_sampler_state sampler[PIPE_MAX_SAMPLERS];
diff --git a/src/mesa/pipe/softpipe/sp_state.h b/src/mesa/pipe/softpipe/sp_state.h
index d754acaa38a..f25a20a5e3f 100644
--- a/src/mesa/pipe/softpipe/sp_state.h
+++ b/src/mesa/pipe/softpipe/sp_state.h
@@ -56,7 +56,10 @@ void softpipe_set_depth_test_state( struct pipe_context *,
const struct pipe_depth_state * );
void softpipe_set_fs_state( struct pipe_context *,
- const struct pipe_fs_state * );
+ const struct pipe_shader_state * );
+
+void softpipe_set_vs_state( struct pipe_context *,
+ const struct pipe_shader_state * );
void softpipe_set_polygon_stipple( struct pipe_context *,
const struct pipe_poly_stipple * );
diff --git a/src/mesa/pipe/softpipe/sp_state_fs.c b/src/mesa/pipe/softpipe/sp_state_fs.c
index c7ef1f1cfc9..3505c2f1fb6 100644
--- a/src/mesa/pipe/softpipe/sp_state_fs.c
+++ b/src/mesa/pipe/softpipe/sp_state_fs.c
@@ -31,7 +31,7 @@
void softpipe_set_fs_state( struct pipe_context *pipe,
- const struct pipe_fs_state *fs )
+ const struct pipe_shader_state *fs )
{
struct softpipe_context *softpipe = softpipe_context(pipe);
@@ -41,10 +41,12 @@ void softpipe_set_fs_state( struct pipe_context *pipe,
}
+void softpipe_set_vs_state( struct pipe_context *pipe,
+ const struct pipe_shader_state *vs )
+{
+ struct softpipe_context *softpipe = softpipe_context(pipe);
+ memcpy(&softpipe->vs, vs, sizeof(*vs));
-
-
-
-
-
+ softpipe->dirty |= SP_NEW_VS;
+}