[PATCH 05/10] wined3d: Acquire references to cleared render-target views for command lists by inspecting CS packets.

Henri Verbeet hverbeet at codeweavers.com
Mon Jan 24 06:59:02 CST 2022


From: Jan Sikorski <jsikorski at codeweavers.com>

Signed-off-by: Jan Sikorski <jsikorski at codeweavers.com>
Signed-off-by: Henri Verbeet <hverbeet at codeweavers.com>
---
 dlls/wined3d/cs.c | 28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)

diff --git a/dlls/wined3d/cs.c b/dlls/wined3d/cs.c
index ae120b1790d..9f7421e865f 100644
--- a/dlls/wined3d/cs.c
+++ b/dlls/wined3d/cs.c
@@ -3616,6 +3616,20 @@ static void wined3d_cs_packet_decref_objects(const struct wined3d_cs_packet *pac
             break;
         }
 
+        case WINED3D_CS_OP_CLEAR:
+        {
+            struct wined3d_cs_clear *op = (struct wined3d_cs_clear *)packet->data;
+
+            for (i = 0; i < op->rt_count; ++i)
+            {
+                if (op->fb.render_targets[i])
+                    wined3d_rendertarget_view_decref(op->fb.render_targets[i]);
+            }
+            if (op->fb.depth_stencil)
+                wined3d_rendertarget_view_decref(op->fb.depth_stencil);
+            break;
+        }
+
         default:
             break;
     }
@@ -3750,6 +3764,20 @@ static void wined3d_cs_packet_incref_objects(struct wined3d_cs_packet *packet)
             break;
         }
 
+        case WINED3D_CS_OP_CLEAR:
+        {
+            struct wined3d_cs_clear *op = (struct wined3d_cs_clear *)packet->data;
+
+            for (i = 0; i < op->rt_count; ++i)
+            {
+                if (op->fb.render_targets[i])
+                    wined3d_rendertarget_view_incref(op->fb.render_targets[i]);
+            }
+            if (op->fb.depth_stencil)
+                wined3d_rendertarget_view_incref(op->fb.depth_stencil);
+            break;
+        }
+
         default:
             break;
     }
-- 
2.30.2




More information about the wine-devel mailing list