diff options
author | ReinUsesLisp <reinuseslisp@airmail.cc> | 2019-01-06 07:58:43 +0100 |
---|---|---|
committer | ReinUsesLisp <reinuseslisp@airmail.cc> | 2019-01-07 20:13:12 +0100 |
commit | 0ab17ab4062278ceed3a3dc28796493280e6d0a1 (patch) | |
tree | 26c4be1650fd1f554047f6179f31d3f2f8ddf528 /src/video_core/engines | |
parent | Merge pull request #1988 from lioncash/res (diff) | |
download | yuzu-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.cpp | 8 | ||||
-rw-r--r-- | src/video_core/engines/maxwell_3d.h | 3 |
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; } }; |