summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2018-11-23 17:48:57 +0100
committerGitHub <noreply@github.com>2018-11-23 17:48:57 +0100
commitd77af9f8fd04a3b1635ecc5f2a4dd76c319e137c (patch)
treec5b030e1ff9d5de3576228dd181037866141b999
parentMerge pull request #1762 from bunnei/getgputime (diff)
parentProperly Implemented TXQ Instruction (diff)
downloadyuzu-d77af9f8fd04a3b1635ecc5f2a4dd76c319e137c.tar
yuzu-d77af9f8fd04a3b1635ecc5f2a4dd76c319e137c.tar.gz
yuzu-d77af9f8fd04a3b1635ecc5f2a4dd76c319e137c.tar.bz2
yuzu-d77af9f8fd04a3b1635ecc5f2a4dd76c319e137c.tar.lz
yuzu-d77af9f8fd04a3b1635ecc5f2a4dd76c319e137c.tar.xz
yuzu-d77af9f8fd04a3b1635ecc5f2a4dd76c319e137c.tar.zst
yuzu-d77af9f8fd04a3b1635ecc5f2a4dd76c319e137c.zip
-rw-r--r--src/video_core/renderer_opengl/gl_shader_decompiler.cpp14
1 files changed, 12 insertions, 2 deletions
diff --git a/src/video_core/renderer_opengl/gl_shader_decompiler.cpp b/src/video_core/renderer_opengl/gl_shader_decompiler.cpp
index 90a88b91a..7d7df0712 100644
--- a/src/video_core/renderer_opengl/gl_shader_decompiler.cpp
+++ b/src/video_core/renderer_opengl/gl_shader_decompiler.cpp
@@ -2885,6 +2885,8 @@ private:
UNIMPLEMENTED_IF_MSG(instr.txq.UsesMiscMode(Tegra::Shader::TextureMiscMode::NODEP),
"NODEP is not implemented");
+ ++shader.scope;
+ shader.AddLine('{');
// TODO: the new commits on the texture refactor, change the way samplers work.
// Sadly, not all texture instructions specify the type of texture their sampler
// uses. This must be fixed at a later instance.
@@ -2892,8 +2894,14 @@ private:
GetSampler(instr.sampler, Tegra::Shader::TextureType::Texture2D, false, false);
switch (instr.txq.query_type) {
case Tegra::Shader::TextureQueryType::Dimension: {
- const std::string texture = "textureQueryLevels(" + sampler + ')';
- regs.SetRegisterToInteger(instr.gpr0, true, 0, texture, 1, 1);
+ const std::string texture = "textureSize(" + sampler + ", " +
+ regs.GetRegisterAsInteger(instr.gpr8) + ')';
+ const std::string mip_level = "textureQueryLevels(" + sampler + ')';
+ shader.AddLine("ivec2 sizes = " + texture + ';');
+ regs.SetRegisterToInteger(instr.gpr0, true, 0, "sizes.x", 1, 1);
+ regs.SetRegisterToInteger(instr.gpr0.Value() + 1, true, 0, "sizes.y", 1, 1);
+ regs.SetRegisterToInteger(instr.gpr0.Value() + 2, true, 0, "0", 1, 1);
+ regs.SetRegisterToInteger(instr.gpr0.Value() + 3, true, 0, mip_level, 1, 1);
break;
}
default: {
@@ -2901,6 +2909,8 @@ private:
static_cast<u32>(instr.txq.query_type.Value()));
}
}
+ --shader.scope;
+ shader.AddLine('}');
break;
}
case OpCode::Id::TMML: {