summaryrefslogtreecommitdiff
path: root/src/video_core/macro_interpreter.cpp
diff options
context:
space:
mode:
authorGravatar Hexagon122019-05-19 15:14:41 +0100
committerGravatar GitHub2019-05-19 15:14:41 +0100
commit9175bffbdbccce15e40c345d13207e53a43a7663 (patch)
tree8636b77dceb0213f354144aeb64755965983ad03 /src/video_core/macro_interpreter.cpp
parentMerge pull request #2468 from lioncash/deduction (diff)
parentGPU/MMEInterpreter: Ignore the 'exit' flag when it's executed inside a delay ... (diff)
downloadyuzu-9175bffbdbccce15e40c345d13207e53a43a7663.tar.gz
yuzu-9175bffbdbccce15e40c345d13207e53a43a7663.tar.xz
yuzu-9175bffbdbccce15e40c345d13207e53a43a7663.zip
Merge pull request #2466 from yuzu-emu/mme-exit-delay-slot
GPU/MMEInterpreter: Ignore the 'exit' flag when it's executed inside a delay slot.
Diffstat (limited to 'src/video_core/macro_interpreter.cpp')
-rw-r--r--src/video_core/macro_interpreter.cpp6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/video_core/macro_interpreter.cpp b/src/video_core/macro_interpreter.cpp
index 524d9ea5a..fbea107ca 100644
--- a/src/video_core/macro_interpreter.cpp
+++ b/src/video_core/macro_interpreter.cpp
@@ -118,10 +118,10 @@ bool MacroInterpreter::Step(u32 offset, bool is_delay_slot) {
118 static_cast<u32>(opcode.operation.Value())); 118 static_cast<u32>(opcode.operation.Value()));
119 } 119 }
120 120
121 if (opcode.is_exit) { 121 // An instruction with the Exit flag will not actually
122 // cause an exit if it's executed inside a delay slot.
123 if (opcode.is_exit && !is_delay_slot) {
122 // Exit has a delay slot, execute the next instruction 124 // Exit has a delay slot, execute the next instruction
123 // Note: Executing an exit during a branch delay slot will cause the instruction at the
124 // branch target to be executed before exiting.
125 Step(offset, true); 125 Step(offset, true);
126 return false; 126 return false;
127 } 127 }