diff options
| author | Liam <byteslice@airmail.cc> | 2022-03-11 17:16:56 -0500 |
|---|---|---|
| committer | Liam <byteslice@airmail.cc> | 2022-03-11 19:42:12 -0500 |
| commit | 56c646d82cdb78557cac7a527247bb46c6028e97 (patch) | |
| tree | 3f43e2861450343ee07b93a30931bc332621ed06 /src/video_core/engines/maxwell_3d.cpp | |
| parent | 70e632f1537d2e087af0b055c80e9124e0aa7c85 (diff) | |
Maxwell3D: Restrict topology override effect to after the register is set
Diffstat (limited to 'src/video_core/engines/maxwell_3d.cpp')
| -rw-r--r-- | src/video_core/engines/maxwell_3d.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/src/video_core/engines/maxwell_3d.cpp b/src/video_core/engines/maxwell_3d.cpp index 94711ad6b..92baba4e8 100644 --- a/src/video_core/engines/maxwell_3d.cpp +++ b/src/video_core/engines/maxwell_3d.cpp @@ -214,6 +214,9 @@ void Maxwell3D::ProcessMethodCall(u32 method, u32 argument, u32 nonshadow_argume regs.index_array.first = regs.small_index.first; dirty.flags[VideoCommon::Dirty::IndexBuffer] = true; return DrawArrays(); + case MAXWELL3D_REG_INDEX(topology_override): + use_topology_override = true; + return; case MAXWELL3D_REG_INDEX(clear_buffers): return ProcessClearBuffers(); case MAXWELL3D_REG_INDEX(query.query_get): @@ -367,7 +370,7 @@ void Maxwell3D::CallMethodFromMME(u32 method, u32 method_argument) { } void Maxwell3D::ProcessTopologyOverride() { - if (regs.draw.topology != regs.topology_override) { + if (use_topology_override) { regs.draw.topology.Assign(regs.topology_override); } } |
