[cairo] [PATCH 3/4] dri2: Don't call the dri2 flush hook for swapbuffers unless we have a context.
Eric Anholt
eric at anholt.net
Mon Feb 21 14:41:08 PST 2011
The driver only has one reasonable place to look for its context to
flush anything, which is the current context. Don't bother it with
having to check.
---
src/glx/dri2_glx.c | 9 +++++++--
1 files changed, 7 insertions(+), 2 deletions(-)
diff --git a/src/glx/dri2_glx.c b/src/glx/dri2_glx.c
index a275ba5..2c28bc2 100644
--- a/src/glx/dri2_glx.c
+++ b/src/glx/dri2_glx.c
@@ -535,8 +535,13 @@ dri2SwapBuffers(__GLXDRIdrawable *pdraw, int64_t target_msc, int64_t divisor,
CARD64 ret = 0;
#ifdef __DRI2_FLUSH
- if (psc->f)
- (*psc->f->flush)(priv->driDrawable);
+ if (psc->f) {
+ struct glx_context *gc = __glXGetCurrentContext();
+
+ if (gc) {
+ (*psc->f->flush)(priv->driDrawable);
+ }
+ }
#endif
/* Old servers don't send invalidate events */
--
1.7.4.1
More information about the cairo
mailing list