Commit c82da7d9 authored by Stefan Dösinger's avatar Stefan Dösinger Committed by Alexandre Julliard

wined3d: Don't dirtify too many shader constants.

If we have start = 4, count = 3, the highest dirty constant is the one with index 6. start + count gives 7, so it already includes the zero-based array correction. Don't add an additional 1. Additionally to the inefficiency of looking at one extra constant, this causes problems if the driver rejects loading 257 constants on the initial load. In this case no constant is loaded if GL_EXT_gpu_program_parameters is used.
parent bbfe59bc
...@@ -515,7 +515,7 @@ static void shader_arb_update_float_vertex_constants(IWineD3DDevice *iface, UINT ...@@ -515,7 +515,7 @@ static void shader_arb_update_float_vertex_constants(IWineD3DDevice *iface, UINT
* context. On a context switch the old context will be fully dirtified */ * context. On a context switch the old context will be fully dirtified */
memset(This->activeContext->vshader_const_dirty + start, 1, memset(This->activeContext->vshader_const_dirty + start, 1,
sizeof(*This->activeContext->vshader_const_dirty) * count); sizeof(*This->activeContext->vshader_const_dirty) * count);
This->highest_dirty_vs_const = max(This->highest_dirty_vs_const, start + count + 1); This->highest_dirty_vs_const = max(This->highest_dirty_vs_const, start + count);
} }
static void shader_arb_update_float_pixel_constants(IWineD3DDevice *iface, UINT start, UINT count) static void shader_arb_update_float_pixel_constants(IWineD3DDevice *iface, UINT start, UINT count)
...@@ -526,7 +526,7 @@ static void shader_arb_update_float_pixel_constants(IWineD3DDevice *iface, UINT ...@@ -526,7 +526,7 @@ static void shader_arb_update_float_pixel_constants(IWineD3DDevice *iface, UINT
* context. On a context switch the old context will be fully dirtified */ * context. On a context switch the old context will be fully dirtified */
memset(This->activeContext->pshader_const_dirty + start, 1, memset(This->activeContext->pshader_const_dirty + start, 1,
sizeof(*This->activeContext->pshader_const_dirty) * count); sizeof(*This->activeContext->pshader_const_dirty) * count);
This->highest_dirty_ps_const = max(This->highest_dirty_ps_const, start + count + 1); This->highest_dirty_ps_const = max(This->highest_dirty_ps_const, start + count);
} }
static DWORD *local_const_mapping(IWineD3DBaseShaderImpl *This) static DWORD *local_const_mapping(IWineD3DBaseShaderImpl *This)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment