Bug 229749

Summary: [CoordinatedGraphics] Schedule rendering after setLayerTreeStateIsFrozen(false) in non-AC mode
Product: WebKit Reporter: Tomoki Imai <tomoki.imai>
Component: WebKit2Assignee: Tomoki Imai <tomoki.imai>
Status: CLOSED FIXED    
Severity: Normal CC: cgarcia, cmarcelo, don.olmstead, ews-watchlist, gyuyoung.kim, Hironori.Fujii, kkinnunen, luiz, ryuan.choi, sergio, webkit-bug-importer, zdobersek, zeno
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
patch
cgarcia: review+, cgarcia: commit-queue-
patch none

Tomoki Imai
Reported 2021-08-31 20:54:50 PDT
We should schedule another rendering when the setLayerTreeStateIsFrozen(false) is called in non-AC mode. In some rare cases, the browser only shows the white page after the page transition, because the rendering is skipped while the layer tree is frozen and there was no guarantee that there is another rendering after setLayerTreeStateIsFrozen(false).
Attachments
patch (2.01 KB, patch)
2021-08-31 20:57 PDT, Tomoki Imai
cgarcia: review+
cgarcia: commit-queue-
patch (2.04 KB, patch)
2021-09-01 00:45 PDT, Tomoki Imai
no flags
Tomoki Imai
Comment 1 2021-08-31 20:57:51 PDT
Created attachment 436991 [details] patch Patch to schedule rendering when setLayerTreeStateIsFrozen(false) is called.
Fujii Hironori
Comment 2 2021-08-31 21:44:41 PDT
Do you have a test case?
Carlos Garcia Campos
Comment 3 2021-08-31 23:44:49 PDT
Comment on attachment 436991 [details] patch Wait, do we know for sure we are not in AC mode at that point?
Carlos Garcia Campos
Comment 4 2021-08-31 23:46:20 PDT
Comment on attachment 436991 [details] patch View in context: https://bugs.webkit.org/attachment.cgi?id=436991&action=review > Source/WebKit/WebProcess/WebPage/CoordinatedGraphics/DrawingAreaCoordinatedGraphics.cpp:246 > + else > + scheduleDisplay(); I think we should only call this if m_layerTreeHost is nullptr
Tomoki Imai
Comment 5 2021-09-01 00:36:41 PDT
(In reply to Fujii Hironori from comment #2) > Do you have a test case? Unfortunately no. On PlayStation, the issue is reproducible with the specific webpage (and sorry, I cannot paste url here..) but WinCairo/GTK cannot reproduce the issue even with the same page. I believe there is a chance where the GTK/WinCairo encounter the same issue, but it seems to depend on the timing.
Tomoki Imai
Comment 6 2021-09-01 00:45:20 PDT
Created attachment 437000 [details] patch (In reply to Carlos Garcia Campos from comment #4) > Comment on attachment 436991 [details] > patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=436991&action=review > > > Source/WebKit/WebProcess/WebPage/CoordinatedGraphics/DrawingAreaCoordinatedGraphics.cpp:246 > > + else > > + scheduleDisplay(); > > I think we should only call this if m_layerTreeHost is nullptr Thanks for pointing! You're correct, I added "if (!m_layerTreeHost)" guard there.
EWS
Comment 7 2021-09-01 01:32:21 PDT
EWS
Comment 8 2021-09-01 01:44:22 PDT
Committed r281841 (241174@main): <https://commits.webkit.org/241174@main> All reviewed patches have been landed. Closing bug and clearing flags on attachment 437000 [details].
Radar WebKit Bug Importer
Comment 9 2021-09-01 01:45:20 PDT
Tomoki Imai
Comment 10 2021-09-01 01:46:47 PDT
Thanks for your review and cq+! (Sorry, I should not have r+)
Note You need to log in before you can comment on or make changes to this bug.