summaryrefslogtreecommitdiff
path: root/src/shader_recompiler/backend/spirv
diff options
context:
space:
mode:
authorGravatar ReinUsesLisp2021-02-14 01:24:32 -0300
committerGravatar ameerj2021-07-22 21:51:22 -0400
commit8af9297f0972d0aaa8306369c5d04926b886a89e (patch)
tree43bb3f50d694b615d2ae821eef84e417166d4890 /src/shader_recompiler/backend/spirv
parentshader: Initial implementation of an AST (diff)
downloadyuzu-8af9297f0972d0aaa8306369c5d04926b886a89e.tar.gz
yuzu-8af9297f0972d0aaa8306369c5d04926b886a89e.tar.xz
yuzu-8af9297f0972d0aaa8306369c5d04926b886a89e.zip
shader: Misc fixes
Diffstat (limited to 'src/shader_recompiler/backend/spirv')
-rw-r--r--src/shader_recompiler/backend/spirv/emit_spirv.cpp6
-rw-r--r--src/shader_recompiler/backend/spirv/emit_spirv.h5
2 files changed, 11 insertions, 0 deletions
diff --git a/src/shader_recompiler/backend/spirv/emit_spirv.cpp b/src/shader_recompiler/backend/spirv/emit_spirv.cpp
index 5022b5159..e29e448c7 100644
--- a/src/shader_recompiler/backend/spirv/emit_spirv.cpp
+++ b/src/shader_recompiler/backend/spirv/emit_spirv.cpp
@@ -25,6 +25,9 @@ EmitContext::EmitContext(IR::Program& program) {
25 f16.Define(*this, TypeFloat(16), "f16"); 25 f16.Define(*this, TypeFloat(16), "f16");
26 f64.Define(*this, TypeFloat(64), "f64"); 26 f64.Define(*this, TypeFloat(64), "f64");
27 27
28 true_value = ConstantTrue(u1);
29 false_value = ConstantFalse(u1);
30
28 for (const IR::Function& function : program.functions) { 31 for (const IR::Function& function : program.functions) {
29 for (IR::Block* const block : function.blocks) { 32 for (IR::Block* const block : function.blocks) {
30 block_label_map.emplace_back(block, OpLabel()); 33 block_label_map.emplace_back(block, OpLabel());
@@ -58,6 +61,7 @@ EmitSPIRV::EmitSPIRV(IR::Program& program) {
58 std::fclose(file); 61 std::fclose(file);
59 std::system("spirv-dis shader.spv"); 62 std::system("spirv-dis shader.spv");
60 std::system("spirv-val shader.spv"); 63 std::system("spirv-val shader.spv");
64 std::system("spirv-cross shader.spv");
61} 65}
62 66
63template <auto method> 67template <auto method>
@@ -109,6 +113,8 @@ static Id TypeId(const EmitContext& ctx, IR::Type type) {
109 switch (type) { 113 switch (type) {
110 case IR::Type::U1: 114 case IR::Type::U1:
111 return ctx.u1; 115 return ctx.u1;
116 case IR::Type::U32:
117 return ctx.u32[1];
112 default: 118 default:
113 throw NotImplementedException("Phi node type {}", type); 119 throw NotImplementedException("Phi node type {}", type);
114 } 120 }
diff --git a/src/shader_recompiler/backend/spirv/emit_spirv.h b/src/shader_recompiler/backend/spirv/emit_spirv.h
index 9aa83b5de..46ec7a1bb 100644
--- a/src/shader_recompiler/backend/spirv/emit_spirv.h
+++ b/src/shader_recompiler/backend/spirv/emit_spirv.h
@@ -79,6 +79,8 @@ public:
79 return def_map.Consume(value.Inst()); 79 return def_map.Consume(value.Inst());
80 } 80 }
81 switch (value.Type()) { 81 switch (value.Type()) {
82 case IR::Type::U1:
83 return value.U1() ? true_value : false_value;
82 case IR::Type::U32: 84 case IR::Type::U32:
83 return Constant(u32[1], value.U32()); 85 return Constant(u32[1], value.U32());
84 case IR::Type::F32: 86 case IR::Type::F32:
@@ -108,6 +110,9 @@ public:
108 VectorTypes f16; 110 VectorTypes f16;
109 VectorTypes f64; 111 VectorTypes f64;
110 112
113 Id true_value{};
114 Id false_value{};
115
111 Id workgroup_id{}; 116 Id workgroup_id{};
112 Id local_invocation_id{}; 117 Id local_invocation_id{};
113 118