summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Anholt <eric@anholt.net>2011-02-14 18:57:49 -0800
committerEric Anholt <eric@anholt.net>2011-02-26 12:43:15 -0800
commitdea5e57861ec998cb7ee913a8819752cb9fa946b (patch)
treea82d9afdebe77e98afbb6bed53a7ce399232f063
parent74cde6505c233f388e902d1daa0e9f186dd012a9 (diff)
downloadexternal_mesa3d-dea5e57861ec998cb7ee913a8819752cb9fa946b.zip
external_mesa3d-dea5e57861ec998cb7ee913a8819752cb9fa946b.tar.gz
external_mesa3d-dea5e57861ec998cb7ee913a8819752cb9fa946b.tar.bz2
intel: Use the current context rather than last bound context for a drawable.
If another thread bound a context to the drawable then unbound it, the driContextPriv would end up NULL. With the previous two fixes, this fixes glx-multithread-makecurrent-2, despite the issue not being about the multithreaded makecurrent.
-rw-r--r--src/mesa/drivers/dri/intel/intel_screen.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/mesa/drivers/dri/intel/intel_screen.c b/src/mesa/drivers/dri/intel/intel_screen.c
index 356d5f7..746da46 100644
--- a/src/mesa/drivers/dri/intel/intel_screen.c
+++ b/src/mesa/drivers/dri/intel/intel_screen.c
@@ -104,7 +104,8 @@ static const __DRItexBufferExtension intelTexBufferExtension = {
static void
intelDRI2Flush(__DRIdrawable *drawable)
{
- struct intel_context *intel = drawable->driContextPriv->driverPrivate;
+ GET_CURRENT_CONTEXT(ctx);
+ struct intel_context *intel = intel_context(ctx);
if (intel->gen < 4)
INTEL_FIREVERTICES(intel);