Matteo Bruni : wined3d: Optimize scanning changed render states in wined3d_device_apply_stateblock().

Alexandre Julliard julliard at winehq.org
Thu Feb 27 17:15:10 CST 2020


Module: wine
Branch: master
Commit: 3b27222aa2c1c85324ca0e03b119635dc031b435
URL:    https://source.winehq.org/git/wine.git/?a=commit;h=3b27222aa2c1c85324ca0e03b119635dc031b435

Author: Matteo Bruni <mbruni at codeweavers.com>
Date:   Thu Feb 27 13:31:13 2020 +0100

wined3d: Optimize scanning changed render states in wined3d_device_apply_stateblock().

Signed-off-by: Matteo Bruni <mbruni at codeweavers.com>
Signed-off-by: Henri Verbeet <hverbeet at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/wined3d/device.c | 29 ++++++++++++++++-------------
 1 file changed, 16 insertions(+), 13 deletions(-)

diff --git a/dlls/wined3d/device.c b/dlls/wined3d/device.c
index 64cc80780d..e706c830d3 100644
--- a/dlls/wined3d/device.c
+++ b/dlls/wined3d/device.c
@@ -3929,22 +3929,25 @@ void CDECL wined3d_device_apply_stateblock(struct wined3d_device *device,
         wined3d_device_set_blend_state(device, blend_state, &colour);
     }
 
-    for (i = 0; i < ARRAY_SIZE(state->rs); ++i)
+    for (i = 0; i < ARRAY_SIZE(changed->renderState); ++i)
     {
-        if (!wined3d_bitmap_is_set(changed->renderState, i))
-            continue;
-
-        if (i != WINED3D_RS_BLENDFACTOR)
+        map = changed->renderState[i];
+        while (map)
         {
-            wined3d_device_set_render_state(device, i, state->rs[i]);
-            continue;
-        }
+            j = wined3d_bit_scan(&map);
+            idx = i * word_bit_count + j;
+            if (idx != WINED3D_RS_BLENDFACTOR)
+            {
+                wined3d_device_set_render_state(device, idx, state->rs[idx]);
+                continue;
+            }
 
-        if (!set_blend_state)
-        {
-            blend_state = wined3d_device_get_blend_state(device, &colour);
-            wined3d_color_from_d3dcolor(&colour, state->rs[i]);
-            wined3d_device_set_blend_state(device, blend_state, &colour);
+            if (!set_blend_state)
+            {
+                blend_state = wined3d_device_get_blend_state(device, &colour);
+                wined3d_color_from_d3dcolor(&colour, state->rs[idx]);
+                wined3d_device_set_blend_state(device, blend_state, &colour);
+            }
         }
     }
 




More information about the wine-cvs mailing list