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

Commit 6104af0e authored by Chris Li's avatar Chris Li
Browse files

Fix race condition on size compat UI

Before, the leash might have been released while the update surface
position runnable was in queue. Now, we make sure the leash is valid
before update position.

Fix: 196942784
Test: manual
Change-Id: I2d052bf46b12a2441dbc0aa1aabf5dfe9be2fa45
parent 6bad1e88
Loading
Loading
Loading
Loading
+6 −1
Original line number Original line Diff line number Diff line
@@ -28,6 +28,7 @@ import android.content.res.Configuration;
import android.graphics.PixelFormat;
import android.graphics.PixelFormat;
import android.graphics.Rect;
import android.graphics.Rect;
import android.os.Binder;
import android.os.Binder;
import android.util.Log;
import android.view.SurfaceControl;
import android.view.SurfaceControl;
import android.view.View;
import android.view.View;
import android.view.WindowManager;
import android.view.WindowManager;
@@ -45,7 +46,7 @@ import com.android.wm.shell.common.SyncTransactionQueue;
class SizeCompatUILayout {
class SizeCompatUILayout {
    private static final String TAG = "SizeCompatUILayout";
    private static final String TAG = "SizeCompatUILayout";


    private final SyncTransactionQueue mSyncQueue;
    final SyncTransactionQueue mSyncQueue;
    private final SizeCompatUIController.SizeCompatUICallback mCallback;
    private final SizeCompatUIController.SizeCompatUICallback mCallback;
    private Context mContext;
    private Context mContext;
    private Configuration mTaskConfig;
    private Configuration mTaskConfig;
@@ -306,6 +307,10 @@ class SizeCompatUILayout {


    private void updateSurfacePosition(SurfaceControl leash, int positionX, int positionY) {
    private void updateSurfacePosition(SurfaceControl leash, int positionX, int positionY) {
        mSyncQueue.runInSync(t -> {
        mSyncQueue.runInSync(t -> {
            if (!leash.isValid()) {
                Log.w(TAG, "The leash has been released.");
                return;
            }
            t.setPosition(leash, positionX, positionY);
            t.setPosition(leash, positionX, positionY);
            // The size compat UI should be the topmost child of the Task in case there can be more
            // The size compat UI should be the topmost child of the Task in case there can be more
            // than one children.
            // than one children.
+2 −1
Original line number Original line Diff line number Diff line
@@ -110,7 +110,8 @@ class SizeCompatUIWindowManager extends WindowlessWindowManager {
        }
        }


        if (mLeash != null) {
        if (mLeash != null) {
            new SurfaceControl.Transaction().remove(mLeash).apply();
            final SurfaceControl leash = mLeash;
            mLayout.mSyncQueue.runInSync(t -> t.remove(leash));
            mLeash = null;
            mLeash = null;
        }
        }
    }
    }