diff options
author | bunnei <bunneidev@gmail.com> | 2020-10-12 21:53:57 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-12 21:53:57 +0200 |
commit | 4c348f406958a2d4f314a7ccecb310f902370e28 (patch) | |
tree | a0b262c5680cd8f6581768af86c2c8eac50311c8 /src/video_core | |
parent | Merge pull request #4775 from ReinUsesLisp/enforce-class-memaccess (diff) | |
parent | shader/texture: Implement CUBE texture type for TMML and fix arrays (diff) | |
download | yuzu-4c348f406958a2d4f314a7ccecb310f902370e28.tar yuzu-4c348f406958a2d4f314a7ccecb310f902370e28.tar.gz yuzu-4c348f406958a2d4f314a7ccecb310f902370e28.tar.bz2 yuzu-4c348f406958a2d4f314a7ccecb310f902370e28.tar.lz yuzu-4c348f406958a2d4f314a7ccecb310f902370e28.tar.xz yuzu-4c348f406958a2d4f314a7ccecb310f902370e28.tar.zst yuzu-4c348f406958a2d4f314a7ccecb310f902370e28.zip |
Diffstat (limited to 'src/video_core')
-rw-r--r-- | src/video_core/shader/decode/texture.cpp | 41 |
1 files changed, 22 insertions, 19 deletions
diff --git a/src/video_core/shader/decode/texture.cpp b/src/video_core/shader/decode/texture.cpp index a03b50e39..4e932a4b6 100644 --- a/src/video_core/shader/decode/texture.cpp +++ b/src/video_core/shader/decode/texture.cpp @@ -292,33 +292,36 @@ u32 ShaderIR::DecodeTexture(NodeBlock& bb, u32 pc) { break; } - std::vector<Node> coords; - - // TODO: Add coordinates for different samplers once other texture types are implemented. - switch (texture_type) { - case TextureType::Texture1D: - coords.push_back(GetRegister(instr.gpr8)); - break; - case TextureType::Texture2D: - coords.push_back(GetRegister(instr.gpr8.Value() + 0)); - coords.push_back(GetRegister(instr.gpr8.Value() + 1)); - break; - default: - UNIMPLEMENTED_MSG("Unhandled texture type {}", static_cast<int>(texture_type)); + const u64 base_index = is_array ? 1 : 0; + const u64 num_components = [texture_type] { + switch (texture_type) { + case TextureType::Texture1D: + return 1; + case TextureType::Texture2D: + return 2; + case TextureType::TextureCube: + return 3; + default: + UNIMPLEMENTED_MSG("Unhandled texture type {}", static_cast<int>(texture_type)); + return 2; + } + }(); + // TODO: What's the array component used for? - // Fallback to interpreting as a 2D texture for now - coords.push_back(GetRegister(instr.gpr8.Value() + 0)); - coords.push_back(GetRegister(instr.gpr8.Value() + 1)); + std::vector<Node> coords; + coords.reserve(num_components); + for (u64 component = 0; component < num_components; ++component) { + coords.push_back(GetRegister(instr.gpr8.Value() + base_index + component)); } + u32 indexer = 0; for (u32 element = 0; element < 2; ++element) { if (!instr.tmml.IsComponentEnabled(element)) { continue; } - auto params = coords; MetaTexture meta{*sampler, {}, {}, {}, {}, {}, {}, {}, {}, element, index_var}; - const Node value = Operation(OperationCode::TextureQueryLod, meta, std::move(params)); - SetTemporary(bb, indexer++, value); + Node value = Operation(OperationCode::TextureQueryLod, meta, coords); + SetTemporary(bb, indexer++, std::move(value)); } for (u32 i = 0; i < indexer; ++i) { SetRegister(bb, instr.gpr0.Value() + i, GetTemporary(i)); |