From bcf5d5ce403acb05035c42f29cde0000bb7e5d00 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Marek=20Ol=C5=A1=C3=A1k?= Date: Sat, 24 Jun 2017 03:16:06 +0200 Subject: [PATCH] mesa: fix clip plane enable breakage MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit Broken by: commit 00173d91b70ae4dcea7c6324ee4858c498cae14b Author: Marek Olšák Date: Sat Jun 10 12:09:43 2017 +0200 mesa: don't flag _NEW_TRANSFORM for st/mesa if possible It also optimizes the case slightly for GL core. It doesn't try to fix that glEnable might be a bad place to do the clip plane transformation. Reviewed-by: Nicolai Hähnle Tested-by: Michel Dänzer Reviewed-by: Roland Scheidegger --- src/mesa/main/enable.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/mesa/main/enable.c b/src/mesa/main/enable.c index e1293f9bf1e..18a288d35c2 100644 --- a/src/mesa/main/enable.c +++ b/src/mesa/main/enable.c @@ -361,8 +361,13 @@ _mesa_set_enable(struct gl_context *ctx, GLenum cap, GLboolean state) if (state) { ctx->Transform.ClipPlanesEnabled |= (1 << p); - if (ctx->API == API_OPENGL_COMPAT || ctx->API == API_OPENGLES) + + /* The projection matrix transforms the clip plane. */ + /* TODO: glEnable might not be the best place to do it. */ + if (ctx->API == API_OPENGL_COMPAT || ctx->API == API_OPENGLES) { _mesa_update_clip_plane(ctx, p); + ctx->NewDriverState |= ctx->DriverFlags.NewClipPlane; + } } else { ctx->Transform.ClipPlanesEnabled &= ~(1 << p); -- 2.30.2