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

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

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

am: d2b522a0

Change-Id: Ic3272abcbd5944818e6d3b93d08dfee2bc44e84d
parents 2492a494 d2b522a0
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);

@@ -674,6 +676,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) {
@@ -709,6 +712,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);
            }
        }

@@ -1002,8 +1006,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) {
@@ -1012,7 +1015,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);
                    }
@@ -1031,6 +1037,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);