diff options
| author | Hexagon12 <Hexagon12@users.noreply.github.com> | 2019-05-19 15:14:41 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-05-19 15:14:41 +0100 | 
| commit | 9175bffbdbccce15e40c345d13207e53a43a7663 (patch) | |
| tree | 8636b77dceb0213f354144aeb64755965983ad03 | |
| parent | ac3775e6ae1b791f2a774369b83a50f072921c3e (diff) | |
| parent | 9ef45f00bf452170c95255f5a3a566d5af91c102 (diff) | |
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.
| -rw-r--r-- | src/video_core/macro_interpreter.cpp | 6 | 
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) {                            static_cast<u32>(opcode.operation.Value()));      } -    if (opcode.is_exit) { +    // An instruction with the Exit flag will not actually +    // cause an exit if it's executed inside a delay slot. +    if (opcode.is_exit && !is_delay_slot) {          // Exit has a delay slot, execute the next instruction -        // Note: Executing an exit during a branch delay slot will cause the instruction at the -        // branch target to be executed before exiting.          Step(offset, true);          return false;      }  | 
