Signed-off-by: Zebediah Figura <z.figura12(a)gmail.com>
---
Used by "Atelier Lydie & Suelle ~The Alchemists and the Mysterious
Paintings~".
dlls/wined3d/glsl_shader.c | 6 ++++++
dlls/wined3d/shader.c | 5 +++++
dlls/wined3d/wined3d_private.h | 1 +
3 files changed, 12 insertions(+)
diff --git a/dlls/wined3d/glsl_shader.c b/dlls/wined3d/glsl_shader.c
index c68bb2e9b06..605dc130e0c 100644
--- a/dlls/wined3d/glsl_shader.c
+++ b/dlls/wined3d/glsl_shader.c
@@ -5744,6 +5744,12 @@ static void shader_glsl_sync(const struct
wined3d_shader_instruction *ins)
sync_flags &= ~WINED3DSSF_GROUP_SHARED_MEMORY;
}
+ if (sync_flags & WINED3DSSF_GLOBAL_UAV)
+ {
+ shader_addline(buffer, "memoryBarrier();\n");
+ sync_flags &= ~WINED3DSSF_GLOBAL_UAV;
+ }
+
if (sync_flags)
FIXME("Unhandled sync flags %#x.\n", sync_flags);
}
diff --git a/dlls/wined3d/shader.c b/dlls/wined3d/shader.c
index 8843e6883fc..9052d217148 100644
--- a/dlls/wined3d/shader.c
+++ b/dlls/wined3d/shader.c
@@ -1910,6 +1910,11 @@ static void shader_dump_global_flags(struct wined3d_string_buffer
*buffer, DWORD
static void shader_dump_sync_flags(struct wined3d_string_buffer *buffer, DWORD
sync_flags)
{
+ if (sync_flags & WINED3DSSF_GLOBAL_UAV)
+ {
+ shader_addline(buffer, "_uglobal");
+ sync_flags &= ~WINED3DSSF_GLOBAL_UAV;
+ }
if (sync_flags & WINED3DSSF_GROUP_SHARED_MEMORY)
{
shader_addline(buffer, "_g");
diff --git a/dlls/wined3d/wined3d_private.h b/dlls/wined3d/wined3d_private.h
index b3934f0d8e4..4fcfd2fb7c7 100644
--- a/dlls/wined3d/wined3d_private.h
+++ b/dlls/wined3d/wined3d_private.h
@@ -656,6 +656,7 @@ enum wined3d_shader_sync_flags
{
WINED3DSSF_THREAD_GROUP = 0x1,
WINED3DSSF_GROUP_SHARED_MEMORY = 0x2,
+ WINED3DSSF_GLOBAL_UAV = 0x8,
};
enum wined3d_shader_uav_flags
--
2.29.2
Show replies by date
Signed-off-by: Henri Verbeet <hverbeet(a)codeweavers.com>