diff options
| author | 2021-11-15 12:14:50 -0800 | |
|---|---|---|
| committer | 2021-11-15 22:04:47 +0000 | |
| commit | eca0b750e79f6aeed835b0fb24d34debfe64cd30 (patch) | |
| tree | a95f0ae17c50998b8f21ccfb0629f387f0a5fe8b | |
| parent | cb4a25f6dffcab62b0eee48af38bba0ce2f72d81 (diff) | |
Don't hold wakelocks for passive requests
Prevents power usage for passive requests and reduces wakelock
thrashing.
Bug: 206340085
Test: presubmits
Change-Id: I258ba16ace2a2a3fa248665bc936e6b855471762
| -rw-r--r-- | services/core/java/com/android/server/location/provider/LocationProviderManager.java | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/services/core/java/com/android/server/location/provider/LocationProviderManager.java b/services/core/java/com/android/server/location/provider/LocationProviderManager.java index 72ab8c1e2d1a..f7c4d03bfdf3 100644 --- a/services/core/java/com/android/server/location/provider/LocationProviderManager.java +++ b/services/core/java/com/android/server/location/provider/LocationProviderManager.java @@ -911,18 +911,21 @@ public class LocationProviderManager extends @Override public void onPreExecute() { mUseWakeLock = false; - final int size = locationResult.size(); - for (int i = 0; i < size; ++i) { - if (!locationResult.get(i).isMock()) { - mUseWakeLock = true; - break; + + // don't acquire a wakelock for passive requests or for mock locations + if (getRequest().getIntervalMillis() != LocationRequest.PASSIVE_INTERVAL) { + final int size = locationResult.size(); + for (int i = 0; i < size; ++i) { + if (!locationResult.get(i).isMock()) { + mUseWakeLock = true; + break; + } } } // update last delivered location setLastDeliveredLocation(locationResult.getLastLocation()); - // don't acquire a wakelock for mock locations to prevent abuse if (mUseWakeLock) { mWakeLock.acquire(WAKELOCK_TIMEOUT_MS); } |