diff options
| author | 2018-02-14 23:24:57 +0000 | |
|---|---|---|
| committer | 2018-02-14 23:24:57 +0000 | |
| commit | 16c012dad325ae488cd6131e09392b2fd6c1a386 (patch) | |
| tree | 0acc245701b06e1041b4ae629d88d9357e98dba6 | |
| parent | 461ce2aac1c5ae0666653cb19624307171c6ce80 (diff) | |
| parent | 3883563d9277af0654fd7fca977e2e2437bb9509 (diff) | |
Merge "Listen for IFingerprintServiceLockoutResetCallback death"
| -rw-r--r-- | services/core/java/com/android/server/fingerprint/FingerprintService.java | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/services/core/java/com/android/server/fingerprint/FingerprintService.java b/services/core/java/com/android/server/fingerprint/FingerprintService.java index b5f94b1ce384..3da35517faf0 100644 --- a/services/core/java/com/android/server/fingerprint/FingerprintService.java +++ b/services/core/java/com/android/server/fingerprint/FingerprintService.java @@ -915,7 +915,7 @@ public class FingerprintService extends SystemService implements IHwBinder.Death notifyLockoutResetMonitors(); } - private class FingerprintServiceLockoutResetMonitor { + private class FingerprintServiceLockoutResetMonitor implements IBinder.DeathRecipient { private static final long WAKELOCK_TIMEOUT_MS = 2000; private final IFingerprintServiceLockoutResetCallback mCallback; @@ -926,6 +926,11 @@ public class FingerprintService extends SystemService implements IHwBinder.Death mCallback = callback; mWakeLock = mPowerManager.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "lockout reset callback"); + try { + mCallback.asBinder().linkToDeath(FingerprintServiceLockoutResetMonitor.this, 0); + } catch (RemoteException e) { + Slog.w(TAG, "caught remote exception in linkToDeath", e); + } } public void sendLockoutReset() { @@ -959,6 +964,12 @@ public class FingerprintService extends SystemService implements IHwBinder.Death removeLockoutResetCallback(FingerprintServiceLockoutResetMonitor.this); } }; + + @Override + public void binderDied() { + Slog.e(TAG, "Lockout reset callback binder died"); + mHandler.post(mRemoveCallbackRunnable); + } } private IBiometricsFingerprintClientCallback mDaemonCallback = |