-
Notifications
You must be signed in to change notification settings - Fork 6k
[Impeller] Check the correct stencil coverage when deciding whether to elide a restore #39023
[Impeller] Check the correct stencil coverage when deciding whether to elide a restore #39023
Conversation
…o elide a restore
Correction: This wouldn't result in excess culling of draw calls -- it actually results in some stuff getting inverse clipped by anything above the restored value because the stencil check uses strict equality (as can be seen in the playground screenshot). Mercury really needs to be in retrograde for an app to be affected by this, so it's not as much of an emergency, but could cause big weird problems for the poor soul that runs into it:
|
… whether to elide a restore (flutter/engine#39023)
…118869) * 7bbe79e10 Extract WideToUTF16String/UTF16StringToWide to FML (flutter/engine#39006) * acca56ce0 Revert "Extract WideToUTF16String/UTF16StringToWide to FML (#39006)" (flutter/engine#39019) * 730e88fb6 [Impeller] Check the correct stencil coverage when deciding whether to elide a restore (flutter/engine#39023)
@zanderso Should we do a cherry pick for this one too? This isn't present on gallery/wondrous, but I won't say it doesn't worry me. |
@bdero Yeah, we can. I only hadn't because I interpreted #39023 (comment) as saying that it wasn't worth a CP. I'll draw up the issue. |
…o elide a restore (flutter#39023)
@zanderso Makes sense, thanks. When this came across my mind today I realized this doesn't seem terribly rare. Any restore from empty stencil coverage will break subsequent draws (including clips). The stencil buffer will basically be in a bad state that will only recover the next time a restore happens from non-empty stencil coverage. The fact that it'll only happen when restoring from an empty clip is what's saving us. I bet stuff that regularly animates clips (e.g. rive animations) will trigger this. |
…o elide a restore (flutter#39023)
…o elide a restore (#39023) (#39096) Co-authored-by: Brandon DeRosier <[email protected]>
Just noticed this while carefully reviewing the stencil coverage stack again today. This is much more rare/a subset of the original issue that was fixed by #38964, but could still result in lots of draw calls getting culled. Slightly modified the playground to detect this case too.
Before
data:image/s3,"s3://crabby-images/ee66d/ee66da6013fcab4cffc7d367ba8ec27f4297f2da" alt="Screenshot 2023-01-19 at 5 49 35 PM"
After
data:image/s3,"s3://crabby-images/accf0/accf0b21ab48d645f12030d5eb542779ff9d36dd" alt="Screenshot 2023-01-19 at 5 51 42 PM"