diff options
| author | Mai M <mathew1800@gmail.com> | 2021-08-19 17:16:37 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-08-19 17:16:37 -0400 | 
| commit | 519978ce704606a6e56954f8eee90fdf88824185 (patch) | |
| tree | 9cb115784d035a282d205f4ffd9f7e4f94965061 | |
| parent | 0821d95399c1d7aa28d8333de5e44066dcc33472 (diff) | |
| parent | beb7305b73bff9046b12a4ffb9ae62ab228f5749 (diff) | |
Merge pull request #6887 from v1993/patch-2
SPIR-V: Merge two ifs in EmitGetAttribute
| -rw-r--r-- | src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp | 8 | 
1 files changed, 2 insertions, 6 deletions
| diff --git a/src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp b/src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp index fb8c02a77..14c77f162 100644 --- a/src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp +++ b/src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp @@ -298,14 +298,10 @@ Id EmitGetAttribute(EmitContext& ctx, IR::Attribute attr, Id vertex) {      if (IR::IsGeneric(attr)) {          const u32 index{IR::GenericAttributeIndex(attr)};          const std::optional<AttrInfo> type{AttrTypes(ctx, index)}; -        if (!type) { -            // Attribute is disabled +        if (!type || !ctx.runtime_info.previous_stage_stores.Generic(index, element)) { +            // Attribute is disabled or varying component is not written              return ctx.Const(element == 3 ? 1.0f : 0.0f);          } -        if (!ctx.runtime_info.previous_stage_stores.Generic(index, element)) { -            // Varying component is not written -            return ctx.Const(type && element == 3 ? 1.0f : 0.0f); -        }          const Id generic_id{ctx.input_generics.at(index)};          const Id pointer{AttrPointer(ctx, type->pointer, vertex, generic_id, ctx.Const(element))};          const Id value{ctx.OpLoad(type->id, pointer)}; | 
