summaryrefslogtreecommitdiffstats
path: root/src/video_core/engines
diff options
context:
space:
mode:
authorReinUsesLisp <reinuseslisp@airmail.cc>2019-01-06 07:58:43 +0100
committerReinUsesLisp <reinuseslisp@airmail.cc>2019-01-07 20:13:12 +0100
commit0ab17ab4062278ceed3a3dc28796493280e6d0a1 (patch)
tree26c4be1650fd1f554047f6179f31d3f2f8ddf528 /src/video_core/engines
parentMerge pull request #1988 from lioncash/res (diff)
downloadyuzu-0ab17ab4062278ceed3a3dc28796493280e6d0a1.tar
yuzu-0ab17ab4062278ceed3a3dc28796493280e6d0a1.tar.gz
yuzu-0ab17ab4062278ceed3a3dc28796493280e6d0a1.tar.bz2
yuzu-0ab17ab4062278ceed3a3dc28796493280e6d0a1.tar.lz
yuzu-0ab17ab4062278ceed3a3dc28796493280e6d0a1.tar.xz
yuzu-0ab17ab4062278ceed3a3dc28796493280e6d0a1.tar.zst
yuzu-0ab17ab4062278ceed3a3dc28796493280e6d0a1.zip
Diffstat (limited to 'src/video_core/engines')
-rw-r--r--src/video_core/engines/maxwell_3d.cpp8
-rw-r--r--src/video_core/engines/maxwell_3d.h3
2 files changed, 11 insertions, 0 deletions
diff --git a/src/video_core/engines/maxwell_3d.cpp b/src/video_core/engines/maxwell_3d.cpp
index b19b3a75a..0ed7bc5d8 100644
--- a/src/video_core/engines/maxwell_3d.cpp
+++ b/src/video_core/engines/maxwell_3d.cpp
@@ -135,6 +135,14 @@ void Maxwell3D::CallMethod(const GPU::MethodCall& method_call) {
if (regs.reg_array[method_call.method] != method_call.argument) {
regs.reg_array[method_call.method] = method_call.argument;
+ // Shader
+ constexpr u32 shader_registers_count =
+ sizeof(regs.shader_config[0]) * Regs::MaxShaderProgram / sizeof(u32);
+ if (method_call.method >= MAXWELL3D_REG_INDEX(shader_config[0]) &&
+ method_call.method < MAXWELL3D_REG_INDEX(shader_config[0]) + shader_registers_count) {
+ dirty_flags.shaders = true;
+ }
+
// Vertex format
if (method_call.method >= MAXWELL3D_REG_INDEX(vertex_attrib_format) &&
method_call.method <
diff --git a/src/video_core/engines/maxwell_3d.h b/src/video_core/engines/maxwell_3d.h
index 0faff6fdf..d50e5a126 100644
--- a/src/video_core/engines/maxwell_3d.h
+++ b/src/video_core/engines/maxwell_3d.h
@@ -1089,10 +1089,13 @@ public:
MemoryManager& memory_manager;
struct DirtyFlags {
+ bool shaders = true;
+
bool vertex_attrib_format = true;
u32 vertex_array = 0xFFFFFFFF;
void OnMemoryWrite() {
+ shaders = true;
vertex_array = 0xFFFFFFFF;
}
};