summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorBrian Paul <brianp@vmware.com>2011-01-12 16:13:13 -0700
committerBrian Paul <brianp@vmware.com>2011-01-18 14:02:01 -0700
commit42dbc2530b5a2263012f3fa0e48517a1b8db1c52 (patch)
treeb359a64e59044af89943db9fd6887c7e352adb06 /src
parentfb7a8dedfa5ef9e9dfbd7e728d4f75cfa9aefcfb (diff)
downloadexternal_mesa3d-42dbc2530b5a2263012f3fa0e48517a1b8db1c52.zip
external_mesa3d-42dbc2530b5a2263012f3fa0e48517a1b8db1c52.tar.gz
external_mesa3d-42dbc2530b5a2263012f3fa0e48517a1b8db1c52.tar.bz2
llvmpipe: make sure binning is active when we begin/end a query
This fixes a potential failure when a begin/end_query is the first thing to happen after flushing the scene. NOTE: This is a candidate for the 7.10 and 7.9 branches.
Diffstat (limited to 'src')
-rw-r--r--src/gallium/drivers/llvmpipe/lp_setup.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/src/gallium/drivers/llvmpipe/lp_setup.c b/src/gallium/drivers/llvmpipe/lp_setup.c
index 5d83a1e..7b7b272 100644
--- a/src/gallium/drivers/llvmpipe/lp_setup.c
+++ b/src/gallium/drivers/llvmpipe/lp_setup.c
@@ -1064,6 +1064,8 @@ lp_setup_begin_query(struct lp_setup_context *setup,
{
/* init the query to its beginning state */
assert(setup->active_query == NULL);
+
+ set_scene_state(setup, SETUP_ACTIVE, "begin_query");
if (setup->scene) {
if (!lp_scene_bin_everywhere(setup->scene,
@@ -1093,6 +1095,8 @@ lp_setup_end_query(struct lp_setup_context *setup, struct llvmpipe_query *pq)
{
union lp_rast_cmd_arg dummy = { 0 };
+ set_scene_state(setup, SETUP_ACTIVE, "end_query");
+
assert(setup->active_query == pq);
setup->active_query = NULL;