summaryrefslogtreecommitdiffstats
path: root/src/video_core/shader/decode/predicate_set_register.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/video_core/shader/decode/predicate_set_register.cpp')
-rw-r--r--src/video_core/shader/decode/predicate_set_register.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/video_core/shader/decode/predicate_set_register.cpp b/src/video_core/shader/decode/predicate_set_register.cpp
index 6c58496c2..58d20ceb5 100644
--- a/src/video_core/shader/decode/predicate_set_register.cpp
+++ b/src/video_core/shader/decode/predicate_set_register.cpp
@@ -32,6 +32,12 @@ u32 ShaderIR::DecodePredicateSetRegister(BasicBlock& bb, u32 pc) {
const Node false_value = instr.pset.bf ? Immediate(0.0f) : Immediate(0);
const Node value =
Operation(OperationCode::Select, PRECISE, predicate, true_value, false_value);
+
+ if (instr.pset.bf) {
+ SetInternalFlagsFromFloat(bb, value, instr.generates_cc);
+ } else {
+ SetInternalFlagsFromInteger(bb, value, instr.generates_cc);
+ }
SetRegister(bb, instr.gpr0, value);
return pc;