Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 2da185d5 authored by Evan Rosky's avatar Evan Rosky
Browse files

Don't updateSurfacePosition with invalid window frames

updateSurfacePosition runs pretty frequently (during
configuration update). However, the WindowState override
relies on mWindowFrames which is calculated during layout.
This means that surface positions are frequently calculated
with out-of-date mWindowFrames (most commonly when the
onConfigurationChange cascade is called). This can easily
cause visible glitching based on the timings of SFTransaction
applications -- particularly when mixed with syncTransactions
since those aren't serialized with layout.

This CL prevents WindowState's updateSurfacePosition from
running when layout is deferred or when the window is
goneForLayout.

Bug: 169035082
Test: With new split-screen transitions, launch a non-resizable
      task while in split-screen and observe that home surface
      doesn't get repositioned incorrectly.
Change-Id: If35fb3560eed83fe1c944a1cb7cbb685f58a3b90
parent 961f7375
Loading
Loading
Loading
Loading
+6 −0
Original line number Diff line number Diff line
@@ -5262,6 +5262,12 @@ class WindowState extends WindowContainer<WindowState> implements WindowManagerP
        if (mSurfaceControl == null) {
            return;
        }
        if (mWmService.mWindowPlacerLocked.isLayoutDeferred() || isGoneForLayout()) {
            // Since this relies on mWindowFrames, changes made while layout is deferred are
            // likely to be invalid. Similarly, if it's goneForLayout, mWindowFrames may not be
            // up-to-date and thus can't be relied on.
            return;
        }

        transformFrameToSurfacePosition(mWindowFrames.mFrame.left, mWindowFrames.mFrame.top,
                mSurfacePosition);
+2 −0
Original line number Diff line number Diff line
@@ -647,6 +647,8 @@ public class WindowStateTests extends WindowTestsBase {
        win1.mSurfaceControl = mock(SurfaceControl.class);
        win1.mAttrs.surfaceInsets.set(1, 2, 3, 4);
        win1.getFrame().offsetTo(WINDOW_OFFSET, 0);
        // Simulate layout
        win1.mRelayoutCalled = true;
        win1.updateSurfacePosition(t);
        win1.getTransformationMatrix(values, matrix);