mirror of
https://git.suyu.dev/suyu/suyu
synced 2025-01-09 16:03:21 +00:00
Merge pull request #1766 from FernandoS27/fix-txq
Properly Implemented TXQ Instruction
This commit is contained in:
commit
d77af9f8fd
1 changed files with 12 additions and 2 deletions
|
@ -2885,6 +2885,8 @@ private:
|
||||||
UNIMPLEMENTED_IF_MSG(instr.txq.UsesMiscMode(Tegra::Shader::TextureMiscMode::NODEP),
|
UNIMPLEMENTED_IF_MSG(instr.txq.UsesMiscMode(Tegra::Shader::TextureMiscMode::NODEP),
|
||||||
"NODEP is not implemented");
|
"NODEP is not implemented");
|
||||||
|
|
||||||
|
++shader.scope;
|
||||||
|
shader.AddLine('{');
|
||||||
// TODO: the new commits on the texture refactor, change the way samplers work.
|
// 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
|
// Sadly, not all texture instructions specify the type of texture their sampler
|
||||||
// uses. This must be fixed at a later instance.
|
// uses. This must be fixed at a later instance.
|
||||||
|
@ -2892,8 +2894,14 @@ private:
|
||||||
GetSampler(instr.sampler, Tegra::Shader::TextureType::Texture2D, false, false);
|
GetSampler(instr.sampler, Tegra::Shader::TextureType::Texture2D, false, false);
|
||||||
switch (instr.txq.query_type) {
|
switch (instr.txq.query_type) {
|
||||||
case Tegra::Shader::TextureQueryType::Dimension: {
|
case Tegra::Shader::TextureQueryType::Dimension: {
|
||||||
const std::string texture = "textureQueryLevels(" + sampler + ')';
|
const std::string texture = "textureSize(" + sampler + ", " +
|
||||||
regs.SetRegisterToInteger(instr.gpr0, true, 0, texture, 1, 1);
|
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;
|
break;
|
||||||
}
|
}
|
||||||
default: {
|
default: {
|
||||||
|
@ -2901,6 +2909,8 @@ private:
|
||||||
static_cast<u32>(instr.txq.query_type.Value()));
|
static_cast<u32>(instr.txq.query_type.Value()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
--shader.scope;
|
||||||
|
shader.AddLine('}');
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case OpCode::Id::TMML: {
|
case OpCode::Id::TMML: {
|
||||||
|
|
Loading…
Reference in a new issue