summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNguyen Dac Nam <nam.kazt.91@gmail.com>2020-03-22 10:38:24 +0700
committernamkazy <nam.kazt.91@gmail.com>2020-03-22 10:53:41 +0700
commit01af036c1f653e3e25ab270d3b2a3e33849da0fd (patch)
treef952cf6284473ca7f2ade5ea850d610f53f8b094 /src
parent63c2635e6fa3bcbff000cab7483cb94616db959e (diff)
marco_interpreter: write hw value when shadow ram requested
Diffstat (limited to 'src')
-rw-r--r--src/video_core/macro_interpreter.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/video_core/macro_interpreter.cpp b/src/video_core/macro_interpreter.cpp
index 42031d80a..181310606 100644
--- a/src/video_core/macro_interpreter.cpp
+++ b/src/video_core/macro_interpreter.cpp
@@ -328,6 +328,12 @@ void MacroInterpreter::SetMethodAddress(u32 address) {
}
void MacroInterpreter::Send(u32 value) {
+ // Use the tracked value in shadow_regs when requested.
+ if (method_address.address < Engines::Maxwell3D::Regs::NUM_REGS &&
+ maxwell3d.shadow_state.shadow_ram_control ==
+ Engines::Maxwell3D::Regs::ShadowRamControl::Replay) {
+ value = maxwell3d.shadow_state.reg_array[method_address.address];
+ }
maxwell3d.CallMethodFromMME({method_address.address, value});
// Increment the method address by the method increment.
method_address.address.Assign(method_address.address.Value() +