aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/video_core
diff options
context:
space:
mode:
authorGravatar bunnei <bunneidev@gmail.com>2014-12-28 22:39:17 -0500
committerGravatar bunnei <bunneidev@gmail.com>2014-12-28 22:39:17 -0500
commit487a80f9f70f5972aaf53fd855e17c07deb4819f (patch)
tree2ce60ca2c34aca3e4c19395562df0dbbeb7c19f6 /src/video_core
parentdf728cb4c219ab8932983a7294ace50ccdba92d5 (diff)
parent3b9d181b8e0f1c3c2452497bdf65bbb65ab7c213 (diff)
Merge pull request #347 from bunnei/frameskip
Frameskip
Diffstat (limited to 'src/video_core')
-rw-r--r--src/video_core/command_processor.cpp5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/video_core/command_processor.cpp b/src/video_core/command_processor.cpp
index 2083357f..9602779f 100644
--- a/src/video_core/command_processor.cpp
+++ b/src/video_core/command_processor.cpp
@@ -9,6 +9,7 @@
#include "primitive_assembly.h"
#include "vertex_shader.h"
#include "core/hle/service/gsp_gpu.h"
+#include "core/hw/gpu.h"
#include "debug_utils/debug_utils.h"
@@ -31,6 +32,10 @@ static inline void WritePicaReg(u32 id, u32 value, u32 mask) {
if (id >= registers.NumIds())
return;
+ // If we're skipping this frame, only allow trigger IRQ
+ if (GPU::g_skip_frame && id != PICA_REG_INDEX(trigger_irq))
+ return;
+
// TODO: Figure out how register masking acts on e.g. vs_uniform_setup.set_value
u32 old_value = registers[id];
registers[id] = (old_value & ~mask) | (value & mask);