Pinch-zooming can cause elements to be transiently or permanently mispositioned (macOS CA layer problem?)
Categories
(Core :: Graphics: WebRender, defect)
Tracking
()
Tracking | Status | |
---|---|---|
firefox83 | --- | fixed |
People
(Reporter: kats, Assigned: gw)
References
Details
Attachments
(3 files)
On a local debug build, WR enabled, desktop zoom enabled (both are on by default), go to https://staktrace.github.io/moz-pages/griddiv.html and pinch zoom in and out. While zooming bits of text get mispositioned or misrendered. It looks pretty bad.
While doing this I also ran into an assertion:
Assertion failure: mFrontSurface->mInvalidRegion.Intersect(mDisplayRect).IsEmpty() (Parts of the display rect are invalid! This shouldn't happen.), at /Users/kats/zspace/gecko-cleanup/gfx/layers/NativeLayerCA.mm:776
#01: mozilla::wr::RenderCompositorNative::UnbindNativeLayer()[/Users/kats/zspace/gecko-cleanup/obj-host-debugopt/dist/NightlyDebug.app/Contents/MacOS/XUL +0x17aad7c]
#02: webrender::renderer::Renderer::draw_frame::h8c74408e66db2d8d[/Users/kats/zspace/gecko-cleanup/obj-host-debugopt/dist/NightlyDebug.app/Contents/MacOS/XUL +0x7cdd314]
which makes me think this is related to the macOS compositor stuff in WR.
Reporter | ||
Updated•4 years ago
|
Reporter | ||
Comment 1•4 years ago
|
||
The red text above and below should always be the same size. It is not. Also you can clearly see things shifting around during zoom
Reporter | ||
Comment 2•4 years ago
|
||
Setting gfx.webrender.compositor to false seems to resolve the issues, it certainly seems related to the CA layer thing. Markus, thoughts?
Comment 3•4 years ago
|
||
The assertion means that WR called RenderCompositorNativeOGL::Bind
with an aValidRect
argument that is too large or an aDirtyRect
argument that is too small. For the TileId that is hitting the assertion, if you log those two rects for all calls to Bind with that TileId, you should be able to see what's wrong. Two potential causes would be: 1. calling Bind for the first time with aDirtyRect smaller than aValidRect, or 2. calling Bind again with an enlarged aValidRect without including the added area in aDirtyRect.
Reporter | ||
Comment 4•4 years ago
|
||
Note that I only hit the assertion once. I don't think I can trigger it reliably.
Updated•4 years ago
|
Comment 5•4 years ago
|
||
I can try it reliably with my patch in bug 1642308 -- see https://treeherder.mozilla.org/#/jobs?repo=try&revision=f3cdedaa47975518765bcce06eb61b6395b635f8&selectedTaskRun=ax6_sCScQm-FjSOCmNmowg.0
Note that we appear to be running these tests with WR enabled, and the envvar isn't set (or was somehow broken).
Reporter | ||
Comment 6•4 years ago
•
|
||
Markus wrote a patch that emits the CA layer tree in HTML form so it can be inspecting in a browser. Here is one such capture using the STR in comment 0: https://mozilla.staktrace.com/bug/1667124.html
The red text that says it's below the div is not where it's supposed to be. It looks like the tile in question is mostly transparent, but with a few bits of opaque stuff - the text, the back button, and the tab from the tab bar. The transform is correctly isolating the text piece, but the position on the enclosing div/layer is not what it should be.
Reporter | ||
Comment 7•4 years ago
|
||
Glenn, are you able to reproduce this problem? (Steps are in comment 0). I think the assertion is a red herring, as I haven't seen the assertion again since I reported this bug, but I can easily reproduce the visual problem.
Assignee | ||
Comment 8•4 years ago
|
||
I can reproduce the problem, and confirm it only occurs with WR + CA compositor mode enabled (WR + normal picture caching works fine). I'll take a look today. Do you happen to know if the same bug occurs on Windows + DC?
Reporter | ||
Comment 9•4 years ago
|
||
I don't know, unfortunately. The Windows device on which I can do pinch-zooming is an arm64 laptop and WR doesn't run there.
Assignee | ||
Comment 10•4 years ago
|
||
I was able to reproduce this on a Win10 desktop machine with pinch zooming. I think the problem relates to the picture cache code not correctly invalidating a slice that is attached to a zoom spatial node, when the scale changes. Working on a test and fix for this now.
Assignee | ||
Comment 11•4 years ago
|
||
Detect when the scale of the root spatial node of a picture cache
changes, and invalidate tiles when that occurs.
Updated•4 years ago
|
Assignee | ||
Updated•4 years ago
|
Assignee | ||
Updated•4 years ago
|
Reporter | ||
Comment 12•4 years ago
|
||
Comment 13•4 years ago
|
||
Comment 14•4 years ago
|
||
Backed out 2 changesets (bug 1667124) for reftest failures.
Backout link: https://hg.mozilla.org/integration/autoland/rev/6319812430c53bcbc154934dc364ef7ad917eafb
Failure log: https://treeherder.mozilla.org/logviewer.html#/jobs?job_id=318123613&repo=autoland&lineNumber=6270
[task 2020-10-09T01:58:57.547Z] 01:58:57 INFO - REFTEST TEST-START | gfx/tests/reftest/picture-caching-on-async-zoom.html == gfx/tests/reftest/picture-caching-on-async-zoom.html?ref
[task 2020-10-09T01:58:57.548Z] 01:58:57 INFO - REFTEST TEST-LOAD | http://10.0.2.2:8854/tests/gfx/tests/reftest/picture-caching-on-async-zoom.html | 825 / 7101 (11%)
[task 2020-10-09T01:58:57.549Z] 01:58:57 INFO - REFTEST TEST-LOAD | http://10.0.2.2:8854/tests/gfx/tests/reftest/picture-caching-on-async-zoom.html?ref | 825 / 7101 (11%)
[task 2020-10-09T01:58:57.552Z] 01:58:57 WARNING - REFTEST TEST-UNEXPECTED-FAIL | gfx/tests/reftest/picture-caching-on-async-zoom.html == gfx/tests/reftest/picture-caching-on-async-zoom.html?ref | image comparison, max difference: 255, number of differing pixels: 61934
[task 2020-10-09T01:58:57.569Z] 01:58:57 INFO - REFTEST IMAGE 1 (TEST): ...
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST IMAGE 2 (REFERENCE): ...
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: START http://10.0.2.2:8854/tests/gfx/tests/reftest/picture-caching-on-async-zoom.html
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] OnDocumentLoad triggering WaitForTestEnd
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] WaitForTestEnd: Adding listeners
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: Initializing canvas snapshot
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: DoDrawWindow 0,0,800,1000
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] AttrModifiedListener fired
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] AttrModifiedListener fired
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] AfterPaintListener in http://10.0.2.2:8854/tests/gfx/tests/reftest/picture-caching-on-async-zoom.html
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: STATE_WAITING_TO_FIRE_INVALIDATE_EVENT
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: waiting for MozAfterPaint
[task 2020-10-09T01:58:57.580Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: waiting for updateCanvasPending
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] HandlePendingTasksAfterMakeProgress waiting for a MozAfterPaint
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] AfterPaintListener in http://10.0.2.2:8854/tests/gfx/tests/reftest/picture-caching-on-async-zoom.html
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] HandlePendingTasksAfterMakeProgress updating canvas
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] Webrender enabled, sending update whole canvas for invalidation
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: Updating entire canvas for invalidation
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: DoDrawWindow 0,0,800,1000
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: STATE_WAITING_TO_FIRE_INVALIDATE_EVENT
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: dispatching MozReftestInvalidate
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress
[task 2020-10-09T01:58:57.581Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: STATE_WAITING_FOR_REFTEST_WAIT_REMOVAL
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: STATE_WAITING_FOR_SPELL_CHECKS
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: STATE_WAITING_FOR_APZ_FLUSH
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: done requesting APZ flush
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: apz-repaints-flushed fired
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: STATE_WAITING_TO_FINISH
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: waiting for MozAfterPaint
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] HandlePendingTasksAfterMakeProgress waiting for a MozAfterPaint
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] AfterPaintListener in http://10.0.2.2:8854/tests/gfx/tests/reftest/picture-caching-on-async-zoom.html
[task 2020-10-09T01:58:57.582Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] HandlePendingTasksAfterMakeProgress updating canvas
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] Webrender enabled, sending update whole canvas for invalidation
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: Updating entire canvas for invalidation
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: DoDrawWindow 0,0,800,1000
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: STATE_WAITING_TO_FINISH
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] MakeProgress: Completed
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] RecordResult fired
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: RecordResult fired
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: START http://10.0.2.2:8854/tests/gfx/tests/reftest/picture-caching-on-async-zoom.html?ref
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] OnDocumentLoad triggering AfterOnLoadScripts
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: Initializing canvas snapshot
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: DoDrawWindow 0,0,800,1000
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: [CONTENT] RecordResult fired
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST INFO | Saved log: RecordResult fired
[task 2020-10-09T01:58:57.583Z] 01:58:57 INFO - REFTEST TEST-END | gfx/tests/reftest/picture-caching-on-async-zoom.html == gfx/tests/reftest/picture-caching-on-async-zoom.html?ref
Reporter | ||
Comment 16•4 years ago
|
||
(In reply to Kartikaya Gupta (email:kats@mozilla.com) from comment #15)
Oh, Android. I can take care of this.
Part of the problem is that apz.allow_zooming is not true by default on Android reftests, so I flipped that on. But now I get a failure that's the reverse - the test image is zoomed while the reference is not. Which means that the CSS transform is not taking effect.. whereas it was in the version of the test that bounced. Not sure what's going on there, but for now I'll skip the test on Android and reland.
Comment 17•4 years ago
|
||
Comment 18•4 years ago
|
||
bugherder |
https://hg.mozilla.org/mozilla-central/rev/654d8a949539
https://hg.mozilla.org/mozilla-central/rev/5c2816e0436d
Description
•