From 1e2a89d3061bbee3c73cd55fb8d580b56aabacec Mon Sep 17 00:00:00 2001
From: Feng Chen <vonchenplus@gmail.com>
Date: Thu, 2 Sep 2021 23:34:51 +0800
Subject: Add input/output location

---
 src/shader_recompiler/backend/spirv/emit_context.cpp | 18 +++++++++++++-----
 1 file changed, 13 insertions(+), 5 deletions(-)

(limited to 'src/shader_recompiler/backend/spirv/emit_context.cpp')

diff --git a/src/shader_recompiler/backend/spirv/emit_context.cpp b/src/shader_recompiler/backend/spirv/emit_context.cpp
index 89c75c52d4..ff0501b769 100644
--- a/src/shader_recompiler/backend/spirv/emit_context.cpp
+++ b/src/shader_recompiler/backend/spirv/emit_context.cpp
@@ -1202,10 +1202,14 @@ void EmitContext::DefineInputs(const IR::Program& program) {
         }
     }
     if (loads.AllComponents(IR::Attribute::ColorFrontDiffuseR)) {
-        input_front_color = DefineInput(*this, F32[4], true);
+        const Id id{DefineInput(*this, F32[4], true)};
+        Decorate(id, spv::Decoration::Location, static_cast<u32>(55));
+        input_front_color = id;
     }
-    if (loads.AllComponents(IR::Attribute::FixedFncTexture0S)) {
-        input_txt_coord = DefineInput(*this, F32[4], true);
+    if (loads.AnyComponent(IR::Attribute::FixedFncTexture0S)) {
+        const Id id{DefineInput(*this, F32[4], true)};
+        Decorate(id, spv::Decoration::Location, static_cast<u32>(56));
+        input_txt_coord = id;
     }
     if (loads[IR::Attribute::InstanceId]) {
         if (profile.support_vertex_instance_id) {
@@ -1289,7 +1293,9 @@ void EmitContext::DefineOutputs(const IR::Program& program) {
         output_position = DefineOutput(*this, F32[4], invocations, spv::BuiltIn::Position);
     }
     if (info.stores.AnyComponent(IR::Attribute::ColorFrontDiffuseR) || stage == Stage::VertexB) {
-        output_front_color = DefineOutput(*this, F32[4], invocations);
+        const Id id{DefineOutput(*this, F32[4], invocations)};
+        Decorate(id, spv::Decoration::Location, static_cast<u32>(55));
+        output_front_color = id;
     }
     if (info.stores[IR::Attribute::PointSize] || runtime_info.fixed_state_point_size) {
         if (stage == Stage::Fragment) {
@@ -1324,7 +1330,9 @@ void EmitContext::DefineOutputs(const IR::Program& program) {
     }
 
     if (info.stores.AnyComponent(IR::Attribute::FixedFncTexture0S)) {
-        output_txt_coord = DefineOutput(*this, F32[4], invocations);
+        const Id id{DefineOutput(*this, F32[4], invocations)};
+        Decorate(id, spv::Decoration::Location, static_cast<u32>(56));
+        output_txt_coord = id;
     }
 
     for (size_t index = 0; index < IR::NUM_GENERICS; ++index) {
-- 
cgit v1.2.3-70-g09d2