summaryrefslogtreecommitdiffstats
path: root/src/shader_recompiler/backend/spirv/emit_spirv_special.cpp
diff options
context:
space:
mode:
authorNarr the Reg <juangerman-13@hotmail.com>2024-02-22 18:30:26 +0100
committerGitHub <noreply@github.com>2024-02-22 18:30:26 +0100
commit4f95ee52097762fcd53c135fcf07511898c48194 (patch)
tree1773373bf6c4b9b2556e7352b5de469bd9859695 /src/shader_recompiler/backend/spirv/emit_spirv_special.cpp
parentMerge pull request #13105 from t895/connection-fix (diff)
parentshader_recompiler: throw on missing geometry streams in geometry shaders (diff)
downloadyuzu-4f95ee52097762fcd53c135fcf07511898c48194.tar
yuzu-4f95ee52097762fcd53c135fcf07511898c48194.tar.gz
yuzu-4f95ee52097762fcd53c135fcf07511898c48194.tar.bz2
yuzu-4f95ee52097762fcd53c135fcf07511898c48194.tar.lz
yuzu-4f95ee52097762fcd53c135fcf07511898c48194.tar.xz
yuzu-4f95ee52097762fcd53c135fcf07511898c48194.tar.zst
yuzu-4f95ee52097762fcd53c135fcf07511898c48194.zip
Diffstat (limited to 'src/shader_recompiler/backend/spirv/emit_spirv_special.cpp')
-rw-r--r--src/shader_recompiler/backend/spirv/emit_spirv_special.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/shader_recompiler/backend/spirv/emit_spirv_special.cpp b/src/shader_recompiler/backend/spirv/emit_spirv_special.cpp
index 9f7b6bb4b..f60da758e 100644
--- a/src/shader_recompiler/backend/spirv/emit_spirv_special.cpp
+++ b/src/shader_recompiler/backend/spirv/emit_spirv_special.cpp
@@ -129,7 +129,9 @@ void EmitEmitVertex(EmitContext& ctx, const IR::Value& stream) {
if (ctx.runtime_info.convert_depth_mode && !ctx.profile.support_native_ndc) {
ConvertDepthMode(ctx);
}
- if (stream.IsImmediate()) {
+ if (!ctx.profile.support_geometry_streams) {
+ throw NotImplementedException("Geometry streams");
+ } else if (stream.IsImmediate()) {
ctx.OpEmitStreamVertex(ctx.Def(stream));
} else {
LOG_WARNING(Shader_SPIRV, "Stream is not immediate");
@@ -140,7 +142,9 @@ void EmitEmitVertex(EmitContext& ctx, const IR::Value& stream) {
}
void EmitEndPrimitive(EmitContext& ctx, const IR::Value& stream) {
- if (stream.IsImmediate()) {
+ if (!ctx.profile.support_geometry_streams) {
+ throw NotImplementedException("Geometry streams");
+ } else if (stream.IsImmediate()) {
ctx.OpEndStreamPrimitive(ctx.Def(stream));
} else {
LOG_WARNING(Shader_SPIRV, "Stream is not immediate");