summaryrefslogtreecommitdiff
path: root/src/shader_recompiler/backend/spirv
diff options
context:
space:
mode:
Diffstat (limited to 'src/shader_recompiler/backend/spirv')
-rw-r--r--src/shader_recompiler/backend/spirv/emit_spirv.cpp6
1 files changed, 4 insertions, 2 deletions
diff --git a/src/shader_recompiler/backend/spirv/emit_spirv.cpp b/src/shader_recompiler/backend/spirv/emit_spirv.cpp
index 7e7db9161..50c0f7243 100644
--- a/src/shader_recompiler/backend/spirv/emit_spirv.cpp
+++ b/src/shader_recompiler/backend/spirv/emit_spirv.cpp
@@ -124,10 +124,12 @@ void SetupDenormControl(const Profile& profile, const IR::Program& program, Emit
124 ctx.AddExtension("SPV_KHR_float_controls"); 124 ctx.AddExtension("SPV_KHR_float_controls");
125 125
126 if (info.uses_fp16 && profile.support_fp16_signed_zero_nan_preserve) { 126 if (info.uses_fp16 && profile.support_fp16_signed_zero_nan_preserve) {
127 ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve); 127 ctx.AddCapability(spv::Capability::SignedZeroInfNanPreserve);
128 ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve, 16U);
128 } 129 }
129 if (profile.support_fp32_signed_zero_nan_preserve) { 130 if (profile.support_fp32_signed_zero_nan_preserve) {
130 ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve); 131 ctx.AddCapability(spv::Capability::SignedZeroInfNanPreserve);
132 ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve, 32U);
131 } 133 }
132 if (info.uses_fp32_denorms_flush && info.uses_fp32_denorms_preserve) { 134 if (info.uses_fp32_denorms_flush && info.uses_fp32_denorms_preserve) {
133 // LOG_ERROR(HW_GPU, "Fp32 denorm flush and preserve on the same shader"); 135 // LOG_ERROR(HW_GPU, "Fp32 denorm flush and preserve on the same shader");