diff options
| -rw-r--r-- | src/shader_recompiler/backend/glasm/emit_glasm_memory.cpp | 11 | 
1 files changed, 6 insertions, 5 deletions
| diff --git a/src/shader_recompiler/backend/glasm/emit_glasm_memory.cpp b/src/shader_recompiler/backend/glasm/emit_glasm_memory.cpp index 33af83212..26b03587e 100644 --- a/src/shader_recompiler/backend/glasm/emit_glasm_memory.cpp +++ b/src/shader_recompiler/backend/glasm/emit_glasm_memory.cpp @@ -37,8 +37,8 @@ void GlobalStorageOp(EmitContext& ctx, Register address, std::string_view then_e              continue;          }          const auto& ssbo{ctx.info.storage_buffers_descriptors[index]}; -        ctx.Add("LDC.U64 DC.x,c[{}];"     // ssbo_addr -                "LDC.U32 RC.x,c[{}];"     // ssbo_size_u32 +        ctx.Add("LDC.U64 DC.x,c{}[{}];"   // ssbo_addr +                "LDC.U32 RC.x,c{}[{}];"   // ssbo_size_u32                  "CVT.U64.U32 DC.y,RC.x;"  // ssbo_size = ssbo_size_u32                  "ADD.U64 DC.y,DC.y,DC.x;" // ssbo_end = ssbo_addr + ssbo_size                  "SGE.U64 RC.x,{}.x,DC.x;" // a = input_addr >= ssbo_addr ? -1 : 1 @@ -48,9 +48,10 @@ void GlobalStorageOp(EmitContext& ctx, Register address, std::string_view then_e                  "SUB.U64 DC.x,{}.x,DC.x;" // offset = input_addr - ssbo_addr                  "PK64.U DC.y,c[{}];"      // host_ssbo = cbuf                  "ADD.U64 DC.x,DC.x,DC.y;" // host_addr = host_ssbo + offset -                "{}", -                "ELSE;", index, index, ssbo.cbuf_offset, ssbo.cbuf_offset + 8, address, address, -                address, index, then_expr); +                "{}" +                "ELSE;", +                ssbo.cbuf_index, ssbo.cbuf_offset, ssbo.cbuf_index, ssbo.cbuf_offset + 8, address, +                address, address, index, then_expr);      }      if (!else_expr.empty()) {          ctx.Add("{}", else_expr); | 
