diff options
| author | 2020-03-04 23:10:01 -0500 | |
|---|---|---|
| committer | 2020-03-04 23:10:01 -0500 | |
| commit | fa1d625eed5803e3b93ed5d848e8a241cbf37202 (patch) | |
| tree | f70d7e8e72ac421966df9ffd21c326f77b5a4a01 /src | |
| parent | Merge pull request #3478 from bunnei/a32 (diff) | |
| parent | nit: move comment to right place. (diff) | |
| download | yuzu-fa1d625eed5803e3b93ed5d848e8a241cbf37202.tar.gz yuzu-fa1d625eed5803e3b93ed5d848e8a241cbf37202.tar.xz yuzu-fa1d625eed5803e3b93ed5d848e8a241cbf37202.zip | |
Merge pull request #3469 from namkazt/patch-1
shader_decode: Fix LD, LDG when track constant buffer
Diffstat (limited to 'src')
| -rw-r--r-- | src/video_core/shader/track.cpp | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/src/video_core/shader/track.cpp b/src/video_core/shader/track.cpp index face8c943..15e22b9fa 100644 --- a/src/video_core/shader/track.cpp +++ b/src/video_core/shader/track.cpp | |||
| @@ -157,13 +157,21 @@ std::tuple<Node, u32, u32> ShaderIR::TrackCbuf(Node tracked, const NodeBlock& co | |||
| 157 | if (gpr->GetIndex() == Tegra::Shader::Register::ZeroIndex) { | 157 | if (gpr->GetIndex() == Tegra::Shader::Register::ZeroIndex) { |
| 158 | return {}; | 158 | return {}; |
| 159 | } | 159 | } |
| 160 | // Reduce the cursor in one to avoid infinite loops when the instruction sets the same | 160 | s64 current_cursor = cursor; |
| 161 | // register that it uses as operand | 161 | while (current_cursor > 0) { |
| 162 | const auto [source, new_cursor] = TrackRegister(gpr, code, cursor - 1); | 162 | // Reduce the cursor in one to avoid infinite loops when the instruction sets the same |
| 163 | if (!source) { | 163 | // register that it uses as operand |
| 164 | return {}; | 164 | const auto [source, new_cursor] = TrackRegister(gpr, code, current_cursor - 1); |
| 165 | current_cursor = new_cursor; | ||
| 166 | if (!source) { | ||
| 167 | continue; | ||
| 168 | } | ||
| 169 | const auto [base_address, index, offset] = TrackCbuf(source, code, current_cursor); | ||
| 170 | if (base_address != nullptr) { | ||
| 171 | return {base_address, index, offset}; | ||
| 172 | } | ||
| 165 | } | 173 | } |
| 166 | return TrackCbuf(source, code, new_cursor); | 174 | return {}; |
| 167 | } | 175 | } |
| 168 | if (const auto operation = std::get_if<OperationNode>(&*tracked)) { | 176 | if (const auto operation = std::get_if<OperationNode>(&*tracked)) { |
| 169 | for (std::size_t i = operation->GetOperandsCount(); i > 0; --i) { | 177 | for (std::size_t i = operation->GetOperandsCount(); i > 0; --i) { |