summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Soonil Nagarkar <sooniln@google.com> 2021-11-15 12:14:50 -0800
committer Soonil Nagarkar <sooniln@google.com> 2021-11-15 22:04:47 +0000
commiteca0b750e79f6aeed835b0fb24d34debfe64cd30 (patch)
treea95f0ae17c50998b8f21ccfb0629f387f0a5fe8b
parentcb4a25f6dffcab62b0eee48af38bba0ce2f72d81 (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.java15
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);
}