[Mesa-dev] [PATCH] glShaderSource must not change compile status.
Ian Romanick
idr at freedesktop.org
Tue Apr 26 07:29:25 UTC 2016
On 04/26/2016 07:06 AM, Jamey Sharp wrote:
> OpenGL 4.5 Core Profile section 7.1, in the documentation for
> CompileShader, says: "Changing the source code of a shader object with
> ShaderSource does not change its compile status or the compiled shader
> code." (I haven't checked older versions of the spec.)
>
> According to Karol Herbst, the game "Divinity: Original Sin - Enhanced
> Edition" depends on this odd quirk of the spec. See:
> https://lists.freedesktop.org/archives/mesa-dev/2016-March/109789.html
>
> This patch, together with MESA_GL_VERSION_OVERRIDE=4.2, allows
> "Divinity" to start up successfully on i965, though rendering bugs
> remain.
>
> Signed-off-by: Jamey Sharp <jamey at minilop.net>
> Cc: Karol Herbst <nouveau at karolherbst.de>
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=93551
I think this is correct, but this might have some interactions with
Timothy's shader cache work.
Reviewed-by: Ian Romanick <ian.d.romanick at intel.com>
> ---
> src/mesa/main/shaderapi.c | 1 -
> 1 file changed, 1 deletion(-)
>
> diff --git a/src/mesa/main/shaderapi.c b/src/mesa/main/shaderapi.c
> index b28b5ce..fc2e885 100644
> --- a/src/mesa/main/shaderapi.c
> +++ b/src/mesa/main/shaderapi.c
> @@ -949,7 +949,6 @@ shader_source(struct gl_shader *sh, const GLchar *source)
> /* free old shader source string and install new one */
> free((void *)sh->Source);
> sh->Source = source;
> - sh->CompileStatus = GL_FALSE;
> #ifdef DEBUG
> sh->SourceChecksum = _mesa_str_checksum(sh->Source);
> #endif
>
More information about the mesa-dev
mailing list