summaryrefslogtreecommitdiff
path: root/src/shader_recompiler/backend/spirv
diff options
context:
space:
mode:
authorGravatar Narr the Reg2022-11-20 09:31:20 -0600
committerGravatar GitHub2022-11-20 09:31:20 -0600
commitdb7bcd51ae09c4ef25e08096de563903f61e2380 (patch)
tree5ae9977b48e1aff118fae3ebffb215b0b4afa887 /src/shader_recompiler/backend/spirv
parentservice: nfc: Implement nfc user (diff)
parentMerge pull request #9238 from german77/cabinet_applet (diff)
downloadyuzu-db7bcd51ae09c4ef25e08096de563903f61e2380.tar.gz
yuzu-db7bcd51ae09c4ef25e08096de563903f61e2380.tar.xz
yuzu-db7bcd51ae09c4ef25e08096de563903f61e2380.zip
Merge branch 'master' into nfc_impl
Diffstat (limited to 'src/shader_recompiler/backend/spirv')
-rw-r--r--src/shader_recompiler/backend/spirv/emit_spirv_context_get_set.cpp2
-rw-r--r--src/shader_recompiler/backend/spirv/spirv_emit_context.cpp5
2 files changed, 7 insertions, 0 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 5b3b5d1f3..01f6ec9b5 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
@@ -315,6 +315,8 @@ Id EmitGetAttribute(EmitContext& ctx, IR::Attribute attr, Id vertex) {
315 switch (attr) { 315 switch (attr) {
316 case IR::Attribute::PrimitiveId: 316 case IR::Attribute::PrimitiveId:
317 return ctx.OpBitcast(ctx.F32[1], ctx.OpLoad(ctx.U32[1], ctx.primitive_id)); 317 return ctx.OpBitcast(ctx.F32[1], ctx.OpLoad(ctx.U32[1], ctx.primitive_id));
318 case IR::Attribute::Layer:
319 return ctx.OpBitcast(ctx.F32[1], ctx.OpLoad(ctx.U32[1], ctx.layer));
318 case IR::Attribute::PositionX: 320 case IR::Attribute::PositionX:
319 case IR::Attribute::PositionY: 321 case IR::Attribute::PositionY:
320 case IR::Attribute::PositionZ: 322 case IR::Attribute::PositionZ:
diff --git a/src/shader_recompiler/backend/spirv/spirv_emit_context.cpp b/src/shader_recompiler/backend/spirv/spirv_emit_context.cpp
index 0bfc2dd89..8e3e40cd5 100644
--- a/src/shader_recompiler/backend/spirv/spirv_emit_context.cpp
+++ b/src/shader_recompiler/backend/spirv/spirv_emit_context.cpp
@@ -1359,6 +1359,11 @@ void EmitContext::DefineInputs(const IR::Program& program) {
1359 if (loads[IR::Attribute::PrimitiveId]) { 1359 if (loads[IR::Attribute::PrimitiveId]) {
1360 primitive_id = DefineInput(*this, U32[1], false, spv::BuiltIn::PrimitiveId); 1360 primitive_id = DefineInput(*this, U32[1], false, spv::BuiltIn::PrimitiveId);
1361 } 1361 }
1362 if (loads[IR::Attribute::Layer]) {
1363 AddCapability(spv::Capability::Geometry);
1364 layer = DefineInput(*this, U32[1], false, spv::BuiltIn::Layer);
1365 Decorate(layer, spv::Decoration::Flat);
1366 }
1362 if (loads.AnyComponent(IR::Attribute::PositionX)) { 1367 if (loads.AnyComponent(IR::Attribute::PositionX)) {
1363 const bool is_fragment{stage != Stage::Fragment}; 1368 const bool is_fragment{stage != Stage::Fragment};
1364 const spv::BuiltIn built_in{is_fragment ? spv::BuiltIn::Position : spv::BuiltIn::FragCoord}; 1369 const spv::BuiltIn built_in{is_fragment ? spv::BuiltIn::Position : spv::BuiltIn::FragCoord};