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

Commit d2b522a0 authored by nchalko's avatar nchalko Committed by android-build-merger
Browse files

Merge "Fix reference leak on TvInputManagerService" am: 3fe37342

am: 4d5e8e1d

Change-Id: I5bdac4568dd83d3de578603ddd37fc4dc4535c32
parents 58a1512d 4d5e8e1d
Loading
Loading
Loading
Loading
+16 −9
Original line number Diff line number Diff line
@@ -128,6 +128,8 @@ public final class TvInputManagerService extends SystemService {

    private final WatchLogHandler mWatchLogHandler;

    private IBinder.DeathRecipient mDeathRecipient;

    public TvInputManagerService(Context context) {
        super(context);

@@ -672,6 +674,7 @@ public final class TvInputManagerService extends SystemService {
                if (sessionToken == userState.mainSessionToken) {
                    setMainLocked(sessionToken, false, callingUid, userId);
                }
                sessionState.session.asBinder().unlinkToDeath(sessionState, 0);
                sessionState.session.release();
            }
        } catch (RemoteException | SessionNotFoundException e) {
@@ -707,6 +710,7 @@ public final class TvInputManagerService extends SystemService {
            clientState.sessionTokens.remove(sessionToken);
            if (clientState.isEmpty()) {
                userState.clientStateMap.remove(sessionState.client.asBinder());
                sessionState.client.asBinder().unlinkToDeath(clientState, 0);
            }
        }

@@ -1000,8 +1004,7 @@ public final class TvInputManagerService extends SystemService {
                synchronized (mLock) {
                    final UserState userState = getOrCreateUserStateLocked(resolvedUserId);
                    userState.callbackSet.add(callback);
                    try {
                        callback.asBinder().linkToDeath(new IBinder.DeathRecipient() {
                    mDeathRecipient = new IBinder.DeathRecipient() {
                        @Override
                        public void binderDied() {
                            synchronized (mLock) {
@@ -1010,7 +1013,10 @@ public final class TvInputManagerService extends SystemService {
                                }
                            }
                        }
                        }, 0);
                    };

                    try {
                        callback.asBinder().linkToDeath(mDeathRecipient, 0);
                    } catch (RemoteException e) {
                        Slog.e(TAG, "client process has already died", e);
                    }
@@ -1029,6 +1035,7 @@ public final class TvInputManagerService extends SystemService {
                synchronized (mLock) {
                    UserState userState = getOrCreateUserStateLocked(resolvedUserId);
                    userState.callbackSet.remove(callback);
                    callback.asBinder().unlinkToDeath(mDeathRecipient, 0);
                }
            } finally {
                Binder.restoreCallingIdentity(identity);