summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar bunnei2019-07-25 12:41:52 -0400
committerGravatar GitHub2019-07-25 12:41:52 -0400
commit4d26550f5faff5e1c52fd0fb1b17e03ca4144130 (patch)
treecda37600bdeddf5c0422263f76fcfedc80159557
parentMerge pull request #2689 from lioncash/tl (diff)
parentShader_Ir: Correct tracking to track from right to left (diff)
downloadyuzu-4d26550f5faff5e1c52fd0fb1b17e03ca4144130.tar.gz
yuzu-4d26550f5faff5e1c52fd0fb1b17e03ca4144130.tar.xz
yuzu-4d26550f5faff5e1c52fd0fb1b17e03ca4144130.zip
Merge pull request #2737 from FernandoS27/track-fix
Shader_Ir: Correct tracking to track from right to left
-rw-r--r--src/video_core/shader/track.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/video_core/shader/track.cpp b/src/video_core/shader/track.cpp
index a53e02253..55f5949e4 100644
--- a/src/video_core/shader/track.cpp
+++ b/src/video_core/shader/track.cpp
@@ -59,8 +59,8 @@ std::tuple<Node, u32, u32> ShaderIR::TrackCbuf(Node tracked, const NodeBlock& co
59 return TrackCbuf(source, code, new_cursor); 59 return TrackCbuf(source, code, new_cursor);
60 } 60 }
61 if (const auto operation = std::get_if<OperationNode>(&*tracked)) { 61 if (const auto operation = std::get_if<OperationNode>(&*tracked)) {
62 for (std::size_t i = 0; i < operation->GetOperandsCount(); ++i) { 62 for (std::size_t i = operation->GetOperandsCount(); i > 0; --i) {
63 if (auto found = TrackCbuf((*operation)[i], code, cursor); std::get<0>(found)) { 63 if (auto found = TrackCbuf((*operation)[i - 1], code, cursor); std::get<0>(found)) {
64 // Cbuf found in operand. 64 // Cbuf found in operand.
65 return found; 65 return found;
66 } 66 }