summaryrefslogtreecommitdiff
path: root/src/gallium/drivers/llvmpipe
diff options
context:
space:
mode:
Diffstat (limited to 'src/gallium/drivers/llvmpipe')
-rw-r--r--src/gallium/drivers/llvmpipe/lp_setup.c26
-rw-r--r--src/gallium/drivers/llvmpipe/lp_setup_context.h2
2 files changed, 28 insertions, 0 deletions
diff --git a/src/gallium/drivers/llvmpipe/lp_setup.c b/src/gallium/drivers/llvmpipe/lp_setup.c
index ba9d801032..8a9c169634 100644
--- a/src/gallium/drivers/llvmpipe/lp_setup.c
+++ b/src/gallium/drivers/llvmpipe/lp_setup.c
@@ -480,12 +480,36 @@ lp_setup_is_texture_referenced( struct setup_context *setup,
}
+static INLINE void
+lp_setup_update_shader_state( struct setup_context *setup )
+{
+
+ if(setup->fs.jit_context_dirty) {
+ if(!setup->fs.last_jc ||
+ memcmp(setup->fs.last_jc, &setup->fs.jit_context, sizeof *setup->fs.last_jc)) {
+ struct lp_jit_context *jc;
+
+ jc = get_data(&setup->data, sizeof *jc);
+ if(jc) {
+ memcpy(jc, &setup->fs.jit_context, sizeof *jc);
+ setup->fs.last_jc = jc;
+ }
+ }
+
+ setup->fs.jit_context_dirty = FALSE;
+ }
+
+ assert(setup->fs.last_jc);
+}
+
+
/* Stubs for lines & points for now:
*/
void
lp_setup_point(struct setup_context *setup,
const float (*v0)[4])
{
+ lp_setup_update_shader_state(setup);
setup->point( setup, v0 );
}
@@ -494,6 +518,7 @@ lp_setup_line(struct setup_context *setup,
const float (*v0)[4],
const float (*v1)[4])
{
+ lp_setup_update_shader_state(setup);
setup->line( setup, v0, v1 );
}
@@ -503,6 +528,7 @@ lp_setup_tri(struct setup_context *setup,
const float (*v1)[4],
const float (*v2)[4])
{
+ lp_setup_update_shader_state(setup);
setup->triangle( setup, v0, v1, v2 );
}
diff --git a/src/gallium/drivers/llvmpipe/lp_setup_context.h b/src/gallium/drivers/llvmpipe/lp_setup_context.h
index 2e2380dd80..747e90fe20 100644
--- a/src/gallium/drivers/llvmpipe/lp_setup_context.h
+++ b/src/gallium/drivers/llvmpipe/lp_setup_context.h
@@ -114,6 +114,8 @@ struct setup_context {
lp_jit_frag_func jit_function;
boolean jit_context_dirty;
+
+ const struct lp_jit_context *last_jc;
} fs;
void (*point)( struct setup_context *,