From 8bd4db2620d090c414954d135b2486ce515f1dc4 Mon Sep 17 00:00:00 2001 From: Soonil Nagarkar Date: Thu, 11 Jun 2020 11:58:23 -0700 Subject: Fix deadlock for system location clients Bug: 158637743 Test: manual Change-Id: I0fd2f2ac8cc4c81014e67d1115a2343b95b7cecf --- location/java/android/location/LocationManager.java | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) (limited to 'location') diff --git a/location/java/android/location/LocationManager.java b/location/java/android/location/LocationManager.java index a112bdd0ce03..7d15bbd46697 100644 --- a/location/java/android/location/LocationManager.java +++ b/location/java/android/location/LocationManager.java @@ -2583,9 +2583,15 @@ public class LocationManager { } public void cancel() { + remove(); + } + + private Consumer remove() { + Consumer consumer; ICancellationSignal cancellationSignal; synchronized (this) { mExecutor = null; + consumer = mConsumer; mConsumer = null; if (mAlarmManager != null) { @@ -2605,6 +2611,8 @@ public class LocationManager { // ignore } } + + return consumer; } public void fail() { @@ -2663,16 +2671,10 @@ public class LocationManager { } private void acceptResult(Location location) { - Consumer consumer; - synchronized (this) { - if (mConsumer == null) { - return; - } - consumer = mConsumer; - cancel(); + Consumer consumer = remove(); + if (consumer != null) { + consumer.accept(location); } - - consumer.accept(location); } } -- cgit v1.2.3