Merge branch 'master' into gallium-sampler-view
[mesa.git] / src / gallium / drivers / llvmpipe / lp_state_fs.c
index 2e018df05c08b061f4c5b4a9dbc00705160ee30e..3e681b561aa1de7d8bb51706b3652d1769661945 100644 (file)
@@ -974,6 +974,13 @@ llvmpipe_delete_fs_state(struct pipe_context *pipe, void *fs)
    assert(fs != llvmpipe->fs);
    (void) llvmpipe;
 
+   /*
+    * XXX: we need to flush the context until we have some sort of reference
+    * counting in fragment shaders as they may still be binned
+    */
+   draw_flush(llvmpipe->draw);
+   lp_setup_flush(llvmpipe->setup, 0);
+
    variant = shader->variants;
    while(variant) {
       struct lp_fragment_shader_variant *next = variant->next;