Browse Source
Merge pull request #8038 from liamwhite/exit-register-detection
shader_recompiler/EXIT: increment output register on failed enable test
pull/15/merge
Ameer J
4 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with
9 additions and
0 deletions
-
src/shader_recompiler/frontend/maxwell/translate/impl/exit_program.cpp
-
src/shader_recompiler/program_header.h
|
|
|
@ -11,9 +11,13 @@ void ExitFragment(TranslatorVisitor& v) { |
|
|
|
const ProgramHeader sph{v.env.SPH()}; |
|
|
|
IR::Reg src_reg{IR::Reg::R0}; |
|
|
|
for (u32 render_target = 0; render_target < 8; ++render_target) { |
|
|
|
if (!sph.ps.HasOutputComponents(render_target)) { |
|
|
|
continue; |
|
|
|
} |
|
|
|
const std::array<bool, 4> mask{sph.ps.EnabledOutputComponents(render_target)}; |
|
|
|
for (u32 component = 0; component < 4; ++component) { |
|
|
|
if (!mask[component]) { |
|
|
|
++src_reg; |
|
|
|
continue; |
|
|
|
} |
|
|
|
v.ir.SetFragColor(render_target, component, v.F(src_reg)); |
|
|
|
|
|
|
|
@ -196,6 +196,11 @@ struct ProgramHeader { |
|
|
|
return {(bits & 1) != 0, (bits & 2) != 0, (bits & 4) != 0, (bits & 8) != 0}; |
|
|
|
} |
|
|
|
|
|
|
|
[[nodiscard]] bool HasOutputComponents(u32 rt) const noexcept { |
|
|
|
const u32 bits{omap.target >> (rt * 4)}; |
|
|
|
return (bits & 0xf) != 0; |
|
|
|
} |
|
|
|
|
|
|
|
[[nodiscard]] std::array<PixelImap, 4> GenericInputMap(u32 attribute) const { |
|
|
|
const auto& vector{imap_generic_vector[attribute]}; |
|
|
|
return {vector.x, vector.y, vector.z, vector.w}; |
|
|
|
|