=?UTF-8?Q?J=C3=B3zef=20Kucia=20?=: wined3d: Do not generate FFP fragment shader when SM4 vertex shader is active.
Alexandre Julliard
julliard at winehq.org
Wed Mar 22 15:52:34 CDT 2017
Module: wine
Branch: master
Commit: 56ce1d3dec4b7a699a910983f1e255ee1c0c138d
URL: http://source.winehq.org/git/wine.git/?a=commit;h=56ce1d3dec4b7a699a910983f1e255ee1c0c138d
Author: Józef Kucia <jkucia at codeweavers.com>
Date: Wed Mar 22 09:40:57 2017 +0100
wined3d: Do not generate FFP fragment shader when SM4 vertex shader is active.
We should not ever generate fixed-function replacement shaders in
D3D10+. It is perfectly valid to draw with NULL pixel shader, e.g. for
stream output.
Signed-off-by: Józef Kucia <jkucia at codeweavers.com>
Signed-off-by: Henri Verbeet <hverbeet at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>
---
dlls/wined3d/glsl_shader.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/dlls/wined3d/glsl_shader.c b/dlls/wined3d/glsl_shader.c
index b24f512..3385d83 100644
--- a/dlls/wined3d/glsl_shader.c
+++ b/dlls/wined3d/glsl_shader.c
@@ -8869,7 +8869,8 @@ static void set_glsl_shader_program(const struct wined3d_context *context, const
pshader, &ps_compile_args, &np2fixup_info);
ps_list = &pshader->linked_programs;
}
- else if (priv->fragment_pipe == &glsl_fragment_pipe)
+ else if (priv->fragment_pipe == &glsl_fragment_pipe
+ && !(vshader && vshader->reg_maps.shader_version.major >= 4))
{
struct glsl_ffp_fragment_shader *ffp_shader;
struct ffp_frag_settings settings;
More information about the wine-cvs
mailing list