diff --git a/src/shader_recompiler/backend/glasm/emit_glasm_memory.cpp b/src/shader_recompiler/backend/glasm/emit_glasm_memory.cpp
index 33af83212d..26b03587e7 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);