summaryrefslogtreecommitdiffstats
path: root/src/shader_recompiler/backend/glasm
diff options
context:
space:
mode:
authorliamwhite <liamwhite@users.noreply.github.com>2022-11-19 04:04:18 +0100
committerGitHub <noreply@github.com>2022-11-19 04:04:18 +0100
commit9c67334031ba979db7e1596f9015b1c134c23876 (patch)
tree3e89f99a0f3823d1eb76551719e5ffcbbb95b989 /src/shader_recompiler/backend/glasm
parentMerge pull request #9234 from liamwhite/data-cash-money (diff)
parentshader: Implement miss attribute layer (diff)
downloadyuzu-9c67334031ba979db7e1596f9015b1c134c23876.tar
yuzu-9c67334031ba979db7e1596f9015b1c134c23876.tar.gz
yuzu-9c67334031ba979db7e1596f9015b1c134c23876.tar.bz2
yuzu-9c67334031ba979db7e1596f9015b1c134c23876.tar.lz
yuzu-9c67334031ba979db7e1596f9015b1c134c23876.tar.xz
yuzu-9c67334031ba979db7e1596f9015b1c134c23876.tar.zst
yuzu-9c67334031ba979db7e1596f9015b1c134c23876.zip
Diffstat (limited to 'src/shader_recompiler/backend/glasm')
-rw-r--r--src/shader_recompiler/backend/glasm/emit_glasm.cpp1
-rw-r--r--src/shader_recompiler/backend/glasm/emit_glasm_context_get_set.cpp3
2 files changed, 4 insertions, 0 deletions
diff --git a/src/shader_recompiler/backend/glasm/emit_glasm.cpp b/src/shader_recompiler/backend/glasm/emit_glasm.cpp
index 3b0176bf6..0cb1e193e 100644
--- a/src/shader_recompiler/backend/glasm/emit_glasm.cpp
+++ b/src/shader_recompiler/backend/glasm/emit_glasm.cpp
@@ -320,6 +320,7 @@ void SetupOptions(const IR::Program& program, const Profile& profile,
}
if (stage == Stage::Fragment) {
header += "OPTION ARB_draw_buffers;";
+ header += "OPTION ARB_fragment_layer_viewport;";
}
}
diff --git a/src/shader_recompiler/backend/glasm/emit_glasm_context_get_set.cpp b/src/shader_recompiler/backend/glasm/emit_glasm_context_get_set.cpp
index d6562c842..f0bd84ab2 100644
--- a/src/shader_recompiler/backend/glasm/emit_glasm_context_get_set.cpp
+++ b/src/shader_recompiler/backend/glasm/emit_glasm_context_get_set.cpp
@@ -104,6 +104,9 @@ void EmitGetAttribute(EmitContext& ctx, IR::Inst& inst, IR::Attribute attr, Scal
case IR::Attribute::PrimitiveId:
ctx.Add("MOV.F {}.x,primitive.id;", inst);
break;
+ case IR::Attribute::Layer:
+ ctx.Add("MOV.F {}.x,fragment.layer;", inst);
+ break;
case IR::Attribute::PositionX:
case IR::Attribute::PositionY:
case IR::Attribute::PositionZ: