Skip to content

Commit

Permalink
Actually traverse the dependency chain through temporaries.
Browse files Browse the repository at this point in the history
Co-authored-by: Hans-Kristian Arntzen <[email protected]>
  • Loading branch information
mabaro and HansKristian-Work committed Dec 11, 2024
1 parent 022aad4 commit 67dfa0d
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions spirv_glsl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11766,10 +11766,10 @@ void CompilerGLSL::disallow_forwarding_in_expression_chain(const SPIRExpression
// Allow trivially forwarded expressions like OpLoad or trivial shuffles,
// these will be marked as having suppressed usage tracking.
// Our only concern is to make sure arithmetic operations are done in similar ways.
if (expression_is_forwarded(expr.self) && !expression_suppresses_usage_tracking(expr.self) &&
forced_invariant_temporaries.count(expr.self) == 0)
if (forced_invariant_temporaries.count(expr.self) == 0)
{
force_temporary_and_recompile(expr.self);
if (!expression_suppresses_usage_tracking(expr.self))
force_temporary_and_recompile(expr.self);
forced_invariant_temporaries.insert(expr.self);

for (auto &dependent : expr.invariance_dependencies)
Expand Down

0 comments on commit 67dfa0d

Please sign in to comment.