summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorIan Romanick <ian.d.romanick@intel.com>2009-09-16 07:39:58 -0700
committerIan Romanick <ian.d.romanick@intel.com>2009-09-16 07:39:58 -0700
commit2921a2555d0a76fa649b23c31e3264bbc78b2ff5 (patch)
tree7a3e2dd4006e17d8027e43cb151548d362ecdbc6 /src
parentd9ddbc3f4762d05ef2c4e651f3164ead92e85cd5 (diff)
downloadexternal_mesa3d-2921a2555d0a76fa649b23c31e3264bbc78b2ff5.zip
external_mesa3d-2921a2555d0a76fa649b23c31e3264bbc78b2ff5.tar.gz
external_mesa3d-2921a2555d0a76fa649b23c31e3264bbc78b2ff5.tar.bz2
intel: Deassociated drawables from private context struct in intelUnbindContext
The generic DRI infrastructure makes sure that __DRIcontextRec::driDrawablePriv and __DRIcontextRec::driReadablePriv are set to NULL after unbinding a context. However, the intel_context structure keeps cached copies of these pointers. If these cached pointers are not NULLed and the drawable is actually destroyed after unbinding the context (typically by way of glXDestroyWindow), freed memory will be dereferenced in intelDestroyContext. This should fix bug #23418.
Diffstat (limited to 'src')
-rw-r--r--src/mesa/drivers/dri/intel/intel_context.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/mesa/drivers/dri/intel/intel_context.c b/src/mesa/drivers/dri/intel/intel_context.c
index aecb317..7fa70e4 100644
--- a/src/mesa/drivers/dri/intel/intel_context.c
+++ b/src/mesa/drivers/dri/intel/intel_context.c
@@ -840,6 +840,14 @@ intelDestroyContext(__DRIcontextPrivate * driContextPriv)
GLboolean
intelUnbindContext(__DRIcontextPrivate * driContextPriv)
{
+ struct intel_context *intel =
+ (struct intel_context *) driContextPriv->driverPrivate;
+
+ /* Deassociate the context with the drawables.
+ */
+ intel->driDrawable = NULL;
+ intel->driReadDrawable = NULL;
+
return GL_TRUE;
}