summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Plass <mplass@google.com>2017-03-24 11:04:15 -0700
committerNingyuan Wang <nywang@google.com>2017-03-29 16:56:42 -0700
commitbb9016d1e5f7c2b27502e7d7db13b55460bca88b (patch)
tree4132fd4abae2e0caa2fe067f1933bced0427440f
parent6490231d83f30b48ac48e62e707ed68e1f3ef730 (diff)
downloadandroid_frameworks_opt_net_wifi-bb9016d1e5f7c2b27502e7d7db13b55460bca88b.tar.gz
android_frameworks_opt_net_wifi-bb9016d1e5f7c2b27502e7d7db13b55460bca88b.tar.bz2
android_frameworks_opt_net_wifi-bb9016d1e5f7c2b27502e7d7db13b55460bca88b.zip
Cherry-picl: Remove bssid hotlist from framework
Bug: 30147676 Test: Relevant unit tests pass, wifi functions Change-Id: Iac6a4c3d4a9e842e73b6122218fe0842126e43e7
-rw-r--r--service/java/com/android/server/wifi/WifiNative.java35
-rw-r--r--service/java/com/android/server/wifi/WifiVendorHal.java6
-rw-r--r--service/java/com/android/server/wifi/scanner/HalWifiScannerImpl.java22
-rw-r--r--service/java/com/android/server/wifi/scanner/WifiScannerImpl.java22
-rw-r--r--service/java/com/android/server/wifi/scanner/WifiScanningServiceImpl.java607
-rw-r--r--service/java/com/android/server/wifi/scanner/WificondScannerImpl.java185
-rw-r--r--tests/wifitests/src/com/android/server/wifi/scanner/WifiScanningServiceTest.java2
7 files changed, 1 insertions, 878 deletions
diff --git a/service/java/com/android/server/wifi/WifiNative.java b/service/java/com/android/server/wifi/WifiNative.java
index 5e448ad07..4feb4ba71 100644
--- a/service/java/com/android/server/wifi/WifiNative.java
+++ b/service/java/com/android/server/wifi/WifiNative.java
@@ -822,12 +822,6 @@ public class WifiNative {
public int max_ap_cache_per_scan;
public int max_rssi_sample_size;
public int max_scan_reporting_threshold;
- public int max_hotlist_bssids;
- public int max_significant_wifi_change_aps;
- public int max_bssid_history_entries;
- public int max_number_epno_networks;
- public int max_number_epno_networks_by_ssid;
- public int max_number_of_white_listed_ssid;
}
/**
@@ -1018,35 +1012,6 @@ public class WifiNative {
return mWifiVendorHal.getBgScanResults();
}
- public static interface HotlistEventHandler {
- void onHotlistApFound (ScanResult[] result);
- void onHotlistApLost (ScanResult[] result);
- }
-
- public boolean setHotlist(WifiScanner.HotlistSettings settings,
- HotlistEventHandler eventHandler) {
- Log.e(mTAG, "setHotlist not supported");
- return false;
- }
-
- public void resetHotlist() {
- Log.e(mTAG, "resetHotlist not supported");
- }
-
- public static interface SignificantWifiChangeEventHandler {
- void onChangesFound(ScanResult[] result);
- }
-
- public boolean trackSignificantWifiChange(
- WifiScanner.WifiChangeSettings settings, SignificantWifiChangeEventHandler handler) {
- Log.e(mTAG, "trackSignificantWifiChange not supported");
- return false;
- }
-
- public void untrackSignificantWifiChange() {
- Log.e(mTAG, "untrackSignificantWifiChange not supported");
- }
-
public WifiLinkLayerStats getWifiLinkLayerStats(String iface) {
return mWifiVendorHal.getWifiLinkLayerStats();
}
diff --git a/service/java/com/android/server/wifi/WifiVendorHal.java b/service/java/com/android/server/wifi/WifiVendorHal.java
index 8646b613b..d623f9e3b 100644
--- a/service/java/com/android/server/wifi/WifiVendorHal.java
+++ b/service/java/com/android/server/wifi/WifiVendorHal.java
@@ -416,12 +416,6 @@ public class WifiVendorHal {
out.max_scan_buckets = cap.maxBuckets;
out.max_rssi_sample_size = 0;
out.max_scan_reporting_threshold = cap.maxReportingThreshold;
- out.max_hotlist_bssids = 0;
- out.max_significant_wifi_change_aps = 0;
- out.max_bssid_history_entries = 0;
- out.max_number_epno_networks = 0;
- out.max_number_epno_networks_by_ssid = 0;
- out.max_number_of_white_listed_ssid = 0;
ans.value = true;
}
);
diff --git a/service/java/com/android/server/wifi/scanner/HalWifiScannerImpl.java b/service/java/com/android/server/wifi/scanner/HalWifiScannerImpl.java
index 3fb491ae5..211e62a0d 100644
--- a/service/java/com/android/server/wifi/scanner/HalWifiScannerImpl.java
+++ b/service/java/com/android/server/wifi/scanner/HalWifiScannerImpl.java
@@ -151,26 +151,4 @@ public class HalWifiScannerImpl extends WifiScannerImpl implements Handler.Callb
return mWificondScannerDelegate.shouldScheduleBackgroundScanForHwPno();
}
}
-
- @Override
- public boolean setHotlist(WifiScanner.HotlistSettings settings,
- WifiNative.HotlistEventHandler eventHandler) {
- return mWifiNative.setHotlist(settings, eventHandler);
- }
-
- @Override
- public void resetHotlist() {
- mWifiNative.resetHotlist();
- }
-
- @Override
- public boolean trackSignificantWifiChange(WifiScanner.WifiChangeSettings settings,
- WifiNative.SignificantWifiChangeEventHandler handler) {
- return mWifiNative.trackSignificantWifiChange(settings, handler);
- }
-
- @Override
- public void untrackSignificantWifiChange() {
- mWifiNative.untrackSignificantWifiChange();
- }
}
diff --git a/service/java/com/android/server/wifi/scanner/WifiScannerImpl.java b/service/java/com/android/server/wifi/scanner/WifiScannerImpl.java
index 5e1de30ef..e0fb535dd 100644
--- a/service/java/com/android/server/wifi/scanner/WifiScannerImpl.java
+++ b/service/java/com/android/server/wifi/scanner/WifiScannerImpl.java
@@ -158,26 +158,4 @@ public abstract class WifiScannerImpl {
* @return true if background scan needs to be started, false otherwise.
*/
public abstract boolean shouldScheduleBackgroundScanForHwPno();
-
- /**
- * Set a new hotlist
- */
- public abstract boolean setHotlist(WifiScanner.HotlistSettings settings,
- WifiNative.HotlistEventHandler eventHandler);
-
- /**
- * Reset any active hotlist
- */
- public abstract void resetHotlist();
-
- /**
- * Start tracking significant wifi changes
- */
- public abstract boolean trackSignificantWifiChange(WifiScanner.WifiChangeSettings settings,
- WifiNative.SignificantWifiChangeEventHandler handler);
-
- /**
- * Stop tracking significant wifi changes
- */
- public abstract void untrackSignificantWifiChange();
}
diff --git a/service/java/com/android/server/wifi/scanner/WifiScanningServiceImpl.java b/service/java/com/android/server/wifi/scanner/WifiScanningServiceImpl.java
index b766db3a6..ef881dad6 100644
--- a/service/java/com/android/server/wifi/scanner/WifiScanningServiceImpl.java
+++ b/service/java/com/android/server/wifi/scanner/WifiScanningServiceImpl.java
@@ -18,7 +18,6 @@ package com.android.server.wifi.scanner;
import android.Manifest;
import android.app.AlarmManager;
-import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
@@ -28,7 +27,6 @@ import android.net.wifi.IWifiScanner;
import android.net.wifi.ScanResult;
import android.net.wifi.WifiManager;
import android.net.wifi.WifiScanner;
-import android.net.wifi.WifiScanner.BssidInfo;
import android.net.wifi.WifiScanner.ChannelSpec;
import android.net.wifi.WifiScanner.PnoSettings;
import android.net.wifi.WifiScanner.ScanData;
@@ -69,11 +67,8 @@ import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
-import java.util.HashMap;
-import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
-import java.util.Set;
public class WifiScanningServiceImpl extends IWifiScanner.Stub {
@@ -215,8 +210,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
switch (msg.what) {
case WifiScanner.CMD_START_BACKGROUND_SCAN:
case WifiScanner.CMD_STOP_BACKGROUND_SCAN:
- case WifiScanner.CMD_SET_HOTLIST:
- case WifiScanner.CMD_RESET_HOTLIST:
mBackgroundScanStateMachine.sendMessage(Message.obtain(msg));
break;
case WifiScanner.CMD_START_PNO_SCAN:
@@ -227,11 +220,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
case WifiScanner.CMD_STOP_SINGLE_SCAN:
mSingleScanStateMachine.sendMessage(Message.obtain(msg));
break;
- case WifiScanner.CMD_CONFIGURE_WIFI_CHANGE:
- case WifiScanner.CMD_START_TRACKING_CHANGE:
- case WifiScanner.CMD_STOP_TRACKING_CHANGE:
- mWifiChangeStateMachine.sendMessage(Message.obtain(msg));
- break;
case WifiScanner.CMD_REGISTER_SCAN_LISTENER:
logScanRequest("registerScanListener", ci, msg.arg2, null, null, null);
mSingleScanListeners.addRequest(ci, msg.arg2, null, null);
@@ -277,7 +265,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
private WifiBackgroundScanStateMachine mBackgroundScanStateMachine;
private WifiSingleScanStateMachine mSingleScanStateMachine;
- private WifiChangeStateMachine mWifiChangeStateMachine;
private WifiPnoScanStateMachine mPnoScanStateMachine;
private ClientHandler mClientHandler;
private final IBatteryStats mBatteryStats;
@@ -305,7 +292,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
public void startService() {
mClientHandler = new ClientHandler(TAG, mLooper);
mBackgroundScanStateMachine = new WifiBackgroundScanStateMachine(mLooper);
- mWifiChangeStateMachine = new WifiChangeStateMachine(mLooper);
mSingleScanStateMachine = new WifiSingleScanStateMachine(mLooper);
mPnoScanStateMachine = new WifiPnoScanStateMachine(mLooper);
@@ -329,7 +315,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
}, new IntentFilter(WifiManager.WIFI_SCAN_AVAILABLE));
mBackgroundScanStateMachine.start();
- mWifiChangeStateMachine.start();
mSingleScanStateMachine.start();
mPnoScanStateMachine.start();
}
@@ -905,15 +890,13 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
}
class WifiBackgroundScanStateMachine extends StateMachine
- implements WifiNative.ScanEventHandler, WifiNative.HotlistEventHandler {
+ implements WifiNative.ScanEventHandler {
private final DefaultState mDefaultState = new DefaultState();
private final StartedState mStartedState = new StartedState();
private final PausedState mPausedState = new PausedState();
private final RequestList<ScanSettings> mActiveBackgroundScans = new RequestList<>();
- private final RequestList<WifiScanner.HotlistSettings> mActiveHotlistSettings =
- new RequestList<>();
WifiBackgroundScanStateMachine(Looper looper) {
super("WifiBackgroundScanStateMachine", looper);
@@ -939,11 +922,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
updateSchedule();
}
- public void removeHotlistSettings(ClientInfo ci) {
- mActiveHotlistSettings.removeAllForClient(ci);
- resetHotlist();
- }
-
@Override
public void onScanStatus(int event) {
if (DBG) localLog("onScanStatus event received, event=" + event);
@@ -980,24 +958,11 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
sendMessage(CMD_SCAN_RESTARTED);
}
- @Override
- public void onHotlistApFound(ScanResult[] results) {
- if (DBG) localLog("onHotlistApFound event received");
- sendMessage(CMD_HOTLIST_AP_FOUND, 0, 0, results);
- }
-
- @Override
- public void onHotlistApLost(ScanResult[] results) {
- if (DBG) localLog("onHotlistApLost event received");
- sendMessage(CMD_HOTLIST_AP_LOST, 0, 0, results);
- }
-
class DefaultState extends State {
@Override
public void enter() {
if (DBG) localLog("DefaultState");
mActiveBackgroundScans.clear();
- mActiveHotlistSettings.clear();
}
@Override
@@ -1041,8 +1006,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
case WifiScanner.CMD_STOP_BACKGROUND_SCAN:
case WifiScanner.CMD_START_SINGLE_SCAN:
case WifiScanner.CMD_STOP_SINGLE_SCAN:
- case WifiScanner.CMD_SET_HOTLIST:
- case WifiScanner.CMD_RESET_HOTLIST:
case WifiScanner.CMD_GET_SCAN_RESULTS:
replyFailed(msg, WifiScanner.REASON_UNSPECIFIED, "not available");
break;
@@ -1074,8 +1037,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
public void exit() {
sendBackgroundScanFailedToAllAndClear(
WifiScanner.REASON_UNSPECIFIED, "Scan was interrupted");
- sendHotlistFailedToAllAndClear(
- WifiScanner.REASON_UNSPECIFIED, "Scan was interrupted");
mScannerImpl.cleanup();
}
@@ -1114,28 +1075,12 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
reportScanResults(mScannerImpl.getLatestBatchedScanResults(true));
replySucceeded(msg);
break;
- case WifiScanner.CMD_SET_HOTLIST:
- if (addHotlist(ci, msg.arg2, (WifiScanner.HotlistSettings) msg.obj)) {
- replySucceeded(msg);
- } else {
- replyFailed(msg, WifiScanner.REASON_INVALID_REQUEST, "bad request");
- }
- break;
- case WifiScanner.CMD_RESET_HOTLIST:
- removeHotlist(ci, msg.arg2);
- break;
case CMD_SCAN_RESULTS_AVAILABLE:
reportScanResults(mScannerImpl.getLatestBatchedScanResults(true));
break;
case CMD_FULL_SCAN_RESULTS:
reportFullScanResult((ScanResult) msg.obj, /* bucketsScanned */ msg.arg2);
break;
- case CMD_HOTLIST_AP_FOUND:
- reportHotlistResults(WifiScanner.CMD_AP_FOUND, (ScanResult[]) msg.obj);
- break;
- case CMD_HOTLIST_AP_LOST:
- reportHotlistResults(WifiScanner.CMD_AP_LOST, (ScanResult[]) msg.obj);
- break;
case CMD_SCAN_PAUSED:
reportScanResults((ScanData[]) msg.obj);
transitionTo(mPausedState);
@@ -1359,106 +1304,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
}
mActiveBackgroundScans.clear();
}
-
- private boolean addHotlist(ClientInfo ci, int handler,
- WifiScanner.HotlistSettings settings) {
- if (ci == null) {
- Log.d(TAG, "Failing hotlist request ClientInfo not found " + handler);
- return false;
- }
- mActiveHotlistSettings.addRequest(ci, handler, null, settings);
- resetHotlist();
- return true;
- }
-
- private void removeHotlist(ClientInfo ci, int handler) {
- if (ci != null) {
- mActiveHotlistSettings.removeRequest(ci, handler);
- resetHotlist();
- }
- }
-
- private void resetHotlist() {
- if (mScannerImpl == null) {
- loge("Failed to update hotlist because WifiScanningService is not initialized");
- return;
- }
-
- Collection<WifiScanner.HotlistSettings> settings =
- mActiveHotlistSettings.getAllSettings();
- int num_hotlist_ap = 0;
-
- for (WifiScanner.HotlistSettings s : settings) {
- num_hotlist_ap += s.bssidInfos.length;
- }
-
- if (num_hotlist_ap == 0) {
- mScannerImpl.resetHotlist();
- } else {
- BssidInfo[] bssidInfos = new BssidInfo[num_hotlist_ap];
- int apLostThreshold = Integer.MAX_VALUE;
- int index = 0;
- for (WifiScanner.HotlistSettings s : settings) {
- for (int i = 0; i < s.bssidInfos.length; i++, index++) {
- bssidInfos[index] = s.bssidInfos[i];
- }
- if (s.apLostThreshold < apLostThreshold) {
- apLostThreshold = s.apLostThreshold;
- }
- }
-
- WifiScanner.HotlistSettings mergedSettings = new WifiScanner.HotlistSettings();
- mergedSettings.bssidInfos = bssidInfos;
- mergedSettings.apLostThreshold = apLostThreshold;
- mScannerImpl.setHotlist(mergedSettings, this);
- }
- }
-
- private void reportHotlistResults(int what, ScanResult[] results) {
- if (DBG) localLog("reportHotlistResults " + what + " results " + results.length);
- for (RequestInfo<WifiScanner.HotlistSettings> entry : mActiveHotlistSettings) {
- ClientInfo ci = entry.clientInfo;
- int handler = entry.handlerId;
- WifiScanner.HotlistSettings settings = entry.settings;
- int num_results = 0;
- for (ScanResult result : results) {
- for (BssidInfo BssidInfo : settings.bssidInfos) {
- if (result.BSSID.equalsIgnoreCase(BssidInfo.bssid)) {
- num_results++;
- break;
- }
- }
- }
- if (num_results == 0) {
- // nothing to report
- return;
- }
- ScanResult[] results2 = new ScanResult[num_results];
- int index = 0;
- for (ScanResult result : results) {
- for (BssidInfo BssidInfo : settings.bssidInfos) {
- if (result.BSSID.equalsIgnoreCase(BssidInfo.bssid)) {
- results2[index] = result;
- index++;
- }
- }
- }
- WifiScanner.ParcelableScanResults parcelableScanResults =
- new WifiScanner.ParcelableScanResults(results2);
-
- ci.reportEvent(what, 0, handler, parcelableScanResults);
- }
- }
-
- private void sendHotlistFailedToAllAndClear(int reason, String description) {
- for (RequestInfo<WifiScanner.HotlistSettings> entry : mActiveHotlistSettings) {
- ClientInfo ci = entry.clientInfo;
- int handler = entry.handlerId;
- ci.reportEvent(WifiScanner.CMD_OP_FAILED, 0, handler,
- new WifiScanner.OperationResult(reason, description));
- }
- mActiveHotlistSettings.clear();
- }
}
/**
@@ -1978,7 +1823,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
mSingleScanListeners.removeAllForClient(this);
mSingleScanStateMachine.removeSingleScanRequests(this);
mBackgroundScanStateMachine.removeBackgroundScanSettings(this);
- mBackgroundScanStateMachine.removeHotlistSettings(this);
unregister();
localLog("Successfully stopped all requests for client " + this);
}
@@ -2078,10 +1922,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
@Override
public void cleanup() {
mDisconnected = true;
- // Internal clients should not have any wifi change requests. So, keeping this cleanup
- // only for external client because this will otherwise cause an infinite recursion
- // when the internal client in WifiChangeStateMachine is cleaned up.
- mWifiChangeStateMachine.removeWifiChangeHandler(this);
mPnoScanStateMachine.removePnoSettings(this);
super.cleanup();
}
@@ -2190,451 +2030,6 @@ public class WifiScanningServiceImpl extends IWifiScanner.Stub {
}
}
- /**
- * Wifi Change state machine is used to handle any wifi change tracking requests.
- * TODO: This state machine doesn't handle driver loading/unloading yet.
- */
- class WifiChangeStateMachine extends StateMachine
- implements WifiNative.SignificantWifiChangeEventHandler {
-
- private static final int MAX_APS_TO_TRACK = 3;
- private static final int MOVING_SCAN_PERIOD_MS = 10000;
- private static final int STATIONARY_SCAN_PERIOD_MS = 5000;
- private static final int MOVING_STATE_TIMEOUT_MS = 30000;
-
- State mDefaultState = new DefaultState();
- State mStationaryState = new StationaryState();
- State mMovingState = new MovingState();
-
- private static final String ACTION_TIMEOUT =
- "com.android.server.WifiScanningServiceImpl.action.TIMEOUT";
- private PendingIntent mTimeoutIntent;
- private ScanResult[] mCurrentBssids;
- private InternalClientInfo mInternalClientInfo;
-
- private final Set<Pair<ClientInfo, Integer>> mActiveWifiChangeHandlers = new HashSet<>();
-
- WifiChangeStateMachine(Looper looper) {
- super("SignificantChangeStateMachine", looper);
-
- // CHECKSTYLE:OFF IndentationCheck
- addState(mDefaultState);
- addState(mStationaryState, mDefaultState);
- addState(mMovingState, mDefaultState);
- // CHECKSTYLE:ON IndentationCheck
-
- setInitialState(mDefaultState);
- }
-
- public void removeWifiChangeHandler(ClientInfo ci) {
- Iterator<Pair<ClientInfo, Integer>> iter = mActiveWifiChangeHandlers.iterator();
- while (iter.hasNext()) {
- Pair<ClientInfo, Integer> entry = iter.next();
- if (entry.first == ci) {
- iter.remove();
- }
- }
- untrackSignificantWifiChangeOnEmpty();
- }
-
- class DefaultState extends State {
- @Override
- public void enter() {
- if (DBG) localLog("Entering IdleState");
- }
-
- @Override
- public boolean processMessage(Message msg) {
- if (DBG) localLog("DefaultState state got " + msg);
- ClientInfo ci = mClients.get(msg.replyTo);
- switch (msg.what) {
- case WifiScanner.CMD_START_TRACKING_CHANGE:
- if (addWifiChangeHandler(ci, msg.arg2)) {
- replySucceeded(msg);
- transitionTo(mMovingState);
- } else {
- replyFailed(msg, WifiScanner.REASON_INVALID_REQUEST, "bad request");
- }
- break;
- case WifiScanner.CMD_STOP_TRACKING_CHANGE:
- // nothing to do
- break;
- case WifiScanner.CMD_CONFIGURE_WIFI_CHANGE:
- /* save configuration till we transition to moving state */
- deferMessage(msg);
- break;
- case WifiScanner.CMD_SCAN_RESULT:
- // nothing to do
- break;
- default:
- return NOT_HANDLED;
- }
- return HANDLED;
- }
- }
-
- class StationaryState extends State {
- @Override
- public void enter() {
- if (DBG) localLog("Entering StationaryState");
- reportWifiStabilized(mCurrentBssids);
- }
-
- @Override
- public boolean processMessage(Message msg) {
- if (DBG) localLog("Stationary state got " + msg);
- ClientInfo ci = mClients.get(msg.replyTo);
- switch (msg.what) {
- case WifiScanner.CMD_START_TRACKING_CHANGE:
- if (addWifiChangeHandler(ci, msg.arg2)) {
- replySucceeded(msg);
- } else {
- replyFailed(msg, WifiScanner.REASON_INVALID_REQUEST, "bad request");
- }
- break;
- case WifiScanner.CMD_STOP_TRACKING_CHANGE:
- removeWifiChangeHandler(ci, msg.arg2);
- break;
- case WifiScanner.CMD_CONFIGURE_WIFI_CHANGE:
- /* save configuration till we transition to moving state */
- deferMessage(msg);
- break;
- case CMD_WIFI_CHANGE_DETECTED:
- if (DBG) localLog("Got wifi change detected");
- reportWifiChanged((ScanResult[]) msg.obj);
- transitionTo(mMovingState);
- break;
- case WifiScanner.CMD_SCAN_RESULT:
- // nothing to do
- break;
- default:
- return NOT_HANDLED;
- }
- return HANDLED;
- }
- }
-
- class MovingState extends State {
- boolean mWifiChangeDetected = false;
- boolean mScanResultsPending = false;
-
- @Override
- public void enter() {
- if (DBG) localLog("Entering MovingState");
- if (mTimeoutIntent == null) {
- Intent intent = new Intent(ACTION_TIMEOUT, null);
- mTimeoutIntent = PendingIntent.getBroadcast(mContext, 0, intent, 0);
-
- mContext.registerReceiver(
- new BroadcastReceiver() {
- @Override
- public void onReceive(Context context, Intent intent) {
- sendMessage(CMD_WIFI_CHANGE_TIMEOUT);
- }
- }, new IntentFilter(ACTION_TIMEOUT));
- }
- issueFullScan();
- }
-
- @Override
- public boolean processMessage(Message msg) {
- if (DBG) localLog("MovingState state got " + msg);
- ClientInfo ci = mClients.get(msg.replyTo);
- switch (msg.what) {
- case WifiScanner.CMD_START_TRACKING_CHANGE:
- if (addWifiChangeHandler(ci, msg.arg2)) {
- replySucceeded(msg);
- } else {
- replyFailed(msg, WifiScanner.REASON_INVALID_REQUEST, "bad request");
- }
- break;
- case WifiScanner.CMD_STOP_TRACKING_CHANGE:
- removeWifiChangeHandler(ci, msg.arg2);
- break;
- case WifiScanner.CMD_CONFIGURE_WIFI_CHANGE:
- if (DBG) localLog("Got configuration from app");
- WifiScanner.WifiChangeSettings settings =
- (WifiScanner.WifiChangeSettings) msg.obj;
- reconfigureScan(settings);
- mWifiChangeDetected = false;
- long unchangedDelay = settings.unchangedSampleSize * settings.periodInMs;
- mAlarmManager.cancel(mTimeoutIntent);
- mAlarmManager.setExact(AlarmManager.ELAPSED_REALTIME_WAKEUP,
- mClock.getElapsedSinceBootMillis() + unchangedDelay,
- mTimeoutIntent);
- break;
- case WifiScanner.CMD_SCAN_RESULT:
- if (DBG) localLog("Got scan results");
- if (mScanResultsPending) {
- if (DBG) localLog("reconfiguring scan");
- reconfigureScan((ScanData[])msg.obj,
- STATIONARY_SCAN_PERIOD_MS);
- mWifiChangeDetected = false;
- mAlarmManager.setExact(AlarmManager.ELAPSED_REALTIME_WAKEUP,
- mClock.getElapsedSinceBootMillis() + MOVING_STATE_TIMEOUT_MS,
- mTimeoutIntent);
- mScanResultsPending = false;
- }
- break;
- case CMD_WIFI_CHANGE_DETECTED:
- if (DBG) localLog("Change detected");
- mAlarmManager.cancel(mTimeoutIntent);
- reportWifiChanged((ScanResult[])msg.obj);
- mWifiChangeDetected = true;
- issueFullScan();
- break;
- case CMD_WIFI_CHANGE_TIMEOUT:
- if (DBG) localLog("Got timeout event");
- if (mWifiChangeDetected == false) {
- transitionTo(mStationaryState);
- }
- break;
- default:
- return NOT_HANDLED;
- }
- return HANDLED;
- }
-
- @Override
- public void exit() {
- mAlarmManager.cancel(mTimeoutIntent);
- }
-
- void issueFullScan() {
- if (DBG) localLog("Issuing full scan");
- ScanSettings settings = new ScanSettings();
- settings.band = WifiScanner.WIFI_BAND_BOTH;
- settings.periodInMs = MOVING_SCAN_PERIOD_MS;
- settings.reportEvents = WifiScanner.REPORT_EVENT_AFTER_EACH_SCAN;
- addScanRequest(settings);
- mScanResultsPending = true;
- }
-
- }
-
- private void reconfigureScan(ScanData[] results, int period) {
- // find brightest APs and set them as sentinels
- if (results.length < MAX_APS_TO_TRACK) {
- localLog("too few APs (" + results.length + ") available to track wifi change");
- return;
- }
-
- removeScanRequest();
-
- // remove duplicate BSSIDs
- HashMap<String, ScanResult> bssidToScanResult = new HashMap<String, ScanResult>();
- for (ScanResult result : results[0].getResults()) {
- ScanResult saved = bssidToScanResult.get(result.BSSID);
- if (saved == null) {
- bssidToScanResult.put(result.BSSID, result);
- } else if (saved.level > result.level) {
- bssidToScanResult.put(result.BSSID, result);
- }
- }
-
- // find brightest BSSIDs
- ScanResult brightest[] = new ScanResult[MAX_APS_TO_TRACK];
- Collection<ScanResult> results2 = bssidToScanResult.values();
- for (ScanResult result : results2) {
- for (int j = 0; j < brightest.length; j++) {
- if (brightest[j] == null
- || (brightest[j].level < result.level)) {
- for (int k = brightest.length; k > (j + 1); k--) {
- brightest[k - 1] = brightest[k - 2];
- }
- brightest[j] = result;
- break;
- }
- }
- }
-
- // Get channels to scan for
- ArrayList<Integer> channels = new ArrayList<Integer>();
- for (int i = 0; i < brightest.length; i++) {
- boolean found = false;
- for (int j = i + 1; j < brightest.length; j++) {
- if (brightest[j].frequency == brightest[i].frequency) {
- found = true;
- }
- }
- if (!found) {
- channels.add(brightest[i].frequency);
- }
- }
-
- if (DBG) localLog("Found " + channels.size() + " channels");
-
- // set scanning schedule
- ScanSettings settings = new ScanSettings();
- settings.band = WifiScanner.WIFI_BAND_UNSPECIFIED;
- settings.channels = new ChannelSpec[channels.size()];
- for (int i = 0; i < channels.size(); i++) {
- settings.channels[i] = new ChannelSpec(channels.get(i));
- }
-
- settings.periodInMs = period;
- addScanRequest(settings);
-
- WifiScanner.WifiChangeSettings settings2 = new WifiScanner.WifiChangeSettings();
- settings2.rssiSampleSize = 3;
- settings2.lostApSampleSize = 3;
- settings2.unchangedSampleSize = 3;
- settings2.minApsBreachingThreshold = 2;
- settings2.bssidInfos = new BssidInfo[brightest.length];
-
- for (int i = 0; i < brightest.length; i++) {
- BssidInfo BssidInfo = new BssidInfo();
- BssidInfo.bssid = brightest[i].BSSID;
- int threshold = (100 + brightest[i].level) / 32 + 2;
- BssidInfo.low = brightest[i].level - threshold;
- BssidInfo.high = brightest[i].level + threshold;
- settings2.bssidInfos[i] = BssidInfo;
-
- if (DBG) localLog("Setting bssid=" + BssidInfo.bssid + ", " +
- "low=" + BssidInfo.low + ", high=" + BssidInfo.high);
- }
-
- trackSignificantWifiChange(settings2);
- mCurrentBssids = brightest;
- }
-
- private void reconfigureScan(WifiScanner.WifiChangeSettings settings) {
-
- if (settings.bssidInfos.length < MAX_APS_TO_TRACK) {
- localLog("too few APs (" + settings.bssidInfos.length
- + ") available to track wifi change");
- return;
- }
-
- if (DBG) localLog("Setting configuration specified by app");
-
- mCurrentBssids = new ScanResult[settings.bssidInfos.length];
- HashSet<Integer> channels = new HashSet<Integer>();
-
- for (int i = 0; i < settings.bssidInfos.length; i++) {
- ScanResult result = new ScanResult();
- result.BSSID = settings.bssidInfos[i].bssid;
- mCurrentBssids[i] = result;
- channels.add(settings.bssidInfos[i].frequencyHint);
- }
-
- // cancel previous scan
- removeScanRequest();
-
- // set new scanning schedule
- ScanSettings settings2 = new ScanSettings();
- settings2.band = WifiScanner.WIFI_BAND_UNSPECIFIED;
- settings2.channels = new ChannelSpec[channels.size()];
- int i = 0;
- for (Integer channel : channels) {
- settings2.channels[i++] = new ChannelSpec(channel);
- }
-
- settings2.periodInMs = settings.periodInMs;
- addScanRequest(settings2);
-
- // start tracking new APs
- trackSignificantWifiChange(settings);
- }
-
-
- @Override
- public void onChangesFound(ScanResult results[]) {
- sendMessage(CMD_WIFI_CHANGE_DETECTED, 0, 0, results);
- }
-
- private void addScanRequest(ScanSettings settings) {
- if (DBG) localLog("Starting scans");
- if (mInternalClientInfo != null) {
- mInternalClientInfo.sendRequestToClientHandler(
- WifiScanner.CMD_START_BACKGROUND_SCAN, settings, null);
- }
- }
-
- private void removeScanRequest() {
- if (DBG) localLog("Stopping scans");
- if (mInternalClientInfo != null) {
- mInternalClientInfo.sendRequestToClientHandler(
- WifiScanner.CMD_STOP_BACKGROUND_SCAN);
- }
- }
-
- private void trackSignificantWifiChange(WifiScanner.WifiChangeSettings settings) {
- if (mScannerImpl != null) {
- mScannerImpl.untrackSignificantWifiChange();
- mScannerImpl.trackSignificantWifiChange(settings, this);
- }
- }
-
- private void untrackSignificantWifiChange() {
- if (mScannerImpl != null) {
- mScannerImpl.untrackSignificantWifiChange();
- }
- }
-
- private boolean addWifiChangeHandler(ClientInfo ci, int handler) {
- if (ci == null) {
- Log.d(TAG, "Failing wifi change request ClientInfo not found " + handler);
- return false;
- }
- mActiveWifiChangeHandlers.add(Pair.create(ci, handler));
- // Add an internal client to make background scan requests.
- if (mInternalClientInfo == null) {
- mInternalClientInfo =
- new InternalClientInfo(ci.getUid(), new Messenger(this.getHandler()));
- mInternalClientInfo.register();
- }
- return true;
- }
-
- private void removeWifiChangeHandler(ClientInfo ci, int handler) {
- if (ci != null) {
- mActiveWifiChangeHandlers.remove(Pair.create(ci, handler));
- untrackSignificantWifiChangeOnEmpty();
- }
- }
-
- private void untrackSignificantWifiChangeOnEmpty() {
- if (mActiveWifiChangeHandlers.isEmpty()) {
- if (DBG) localLog("Got Disable Wifi Change");
- mCurrentBssids = null;
- untrackSignificantWifiChange();
- // Remove the internal client when there are no more external clients.
- if (mInternalClientInfo != null) {
- mInternalClientInfo.cleanup();
- mInternalClientInfo = null;
- }
- transitionTo(mDefaultState);
- }
- }
-
- private void reportWifiChanged(ScanResult[] results) {
- WifiScanner.ParcelableScanResults parcelableScanResults =
- new WifiScanner.ParcelableScanResults(results);
- Iterator<Pair<ClientInfo, Integer>> it = mActiveWifiChangeHandlers.iterator();
- while (it.hasNext()) {
- Pair<ClientInfo, Integer> entry = it.next();
- ClientInfo ci = entry.first;
- int handler = entry.second;
- ci.reportEvent(WifiScanner.CMD_WIFI_CHANGE_DETECTED, 0, handler,
- parcelableScanResults);
- }
- }
-
- private void reportWifiStabilized(ScanResult[] results) {
- WifiScanner.ParcelableScanResults parcelableScanResults =
- new WifiScanner.ParcelableScanResults(results);
- Iterator<Pair<ClientInfo, Integer>> it = mActiveWifiChangeHandlers.iterator();
- while (it.hasNext()) {
- Pair<ClientInfo, Integer> entry = it.next();
- ClientInfo ci = entry.first;
- int handler = entry.second;
- ci.reportEvent(WifiScanner.CMD_WIFI_CHANGES_STABILIZED, 0, handler,
- parcelableScanResults);
- }
- }
- }
-
private static String toString(int uid, ScanSettings settings) {
StringBuilder sb = new StringBuilder();
sb.append("ScanSettings[uid=").append(uid);
diff --git a/service/java/com/android/server/wifi/scanner/WificondScannerImpl.java b/service/java/com/android/server/wifi/scanner/WificondScannerImpl.java
index eaff16d73..1d6d5524a 100644
--- a/service/java/com/android/server/wifi/scanner/WificondScannerImpl.java
+++ b/service/java/com/android/server/wifi/scanner/WificondScannerImpl.java
@@ -87,10 +87,6 @@ public class WificondScannerImpl extends WifiScannerImpl implements Handler.Call
// Settings for the currently running scan, null if no scan active
private LastScanSettings mLastScanSettings = null;
- // Active hotlist settings
- private WifiNative.HotlistEventHandler mHotlistHandler = null;
- private ChangeBuffer mHotlistChangeBuffer = new ChangeBuffer();
-
// Pno related info.
private WifiNative.PnoSettings mPnoSettings = null;
private WifiNative.PnoEventHandler mPnoEventHandler;
@@ -163,8 +159,6 @@ public class WificondScannerImpl extends WifiScannerImpl implements Handler.Call
mPendingSingleScanEventHandler = null;
stopHwPnoScan();
stopBatchedScan();
- resetHotlist();
- untrackSignificantWifiChange();
mLastScanSettings = null; // finally clear any active scan
}
}
@@ -176,8 +170,6 @@ public class WificondScannerImpl extends WifiScannerImpl implements Handler.Call
capabilities.max_ap_cache_per_scan = MAX_APS_PER_SCAN;
capabilities.max_rssi_sample_size = 8;
capabilities.max_scan_reporting_threshold = SCAN_BUFFER_CAPACITY;
- capabilities.max_hotlist_bssids = 0;
- capabilities.max_significant_wifi_change_aps = 0;
return true;
}
@@ -651,18 +643,6 @@ public class WificondScannerImpl extends WifiScannerImpl implements Handler.Call
.onScanStatus(WifiNative.WIFI_SCAN_RESULTS_AVAILABLE);
}
}
-
- if (mHotlistHandler != null) {
- int event = mHotlistChangeBuffer.processScan(backgroundScanResults);
- if ((event & ChangeBuffer.EVENT_FOUND) != 0) {
- mHotlistHandler.onHotlistApFound(
- mHotlistChangeBuffer.getLastResults(ChangeBuffer.EVENT_FOUND));
- }
- if ((event & ChangeBuffer.EVENT_LOST) != 0) {
- mHotlistHandler.onHotlistApLost(
- mHotlistChangeBuffer.getLastResults(ChangeBuffer.EVENT_LOST));
- }
- }
}
if (mLastScanSettings.singleScanActive
@@ -772,39 +752,6 @@ public class WificondScannerImpl extends WifiScannerImpl implements Handler.Call
return false;
}
- @Override
- public boolean setHotlist(WifiScanner.HotlistSettings settings,
- WifiNative.HotlistEventHandler eventHandler) {
- if (settings == null || eventHandler == null) {
- return false;
- }
- synchronized (mSettingsLock) {
- mHotlistHandler = eventHandler;
- mHotlistChangeBuffer.setSettings(settings.bssidInfos, settings.apLostThreshold, 1);
- return true;
- }
- }
-
- @Override
- public void resetHotlist() {
- synchronized (mSettingsLock) {
- mHotlistChangeBuffer.clearSettings();
- mHotlistHandler = null;
- }
- }
-
- /*
- * Significant Wifi Change API is not implemented
- */
- @Override
- public boolean trackSignificantWifiChange(WifiScanner.WifiChangeSettings settings,
- WifiNative.SignificantWifiChangeEventHandler handler) {
- return false;
- }
- @Override
- public void untrackSignificantWifiChange() {}
-
-
private static class LastScanSettings {
public long startTime;
@@ -896,138 +843,6 @@ public class WificondScannerImpl extends WifiScannerImpl implements Handler.Call
}
}
- private static class ChangeBuffer {
- public static int EVENT_NONE = 0;
- public static int EVENT_LOST = 1;
- public static int EVENT_FOUND = 2;
-
- public static int STATE_FOUND = 0;
-
- private WifiScanner.BssidInfo[] mBssidInfos = null;
- private int mApLostThreshold;
- private int mMinEvents;
- private int[] mLostCount = null;
- private ScanResult[] mMostRecentResult = null;
- private int[] mPendingEvent = null;
- private boolean mFiredEvents = false;
-
- private static ScanResult findResult(List<ScanResult> results, String bssid) {
- for (int i = 0; i < results.size(); ++i) {
- if (bssid.equalsIgnoreCase(results.get(i).BSSID)) {
- return results.get(i);
- }
- }
- return null;
- }
-
- public void setSettings(WifiScanner.BssidInfo[] bssidInfos, int apLostThreshold,
- int minEvents) {
- mBssidInfos = bssidInfos;
- if (apLostThreshold <= 0) {
- mApLostThreshold = 1;
- } else {
- mApLostThreshold = apLostThreshold;
- }
- mMinEvents = minEvents;
- if (bssidInfos != null) {
- mLostCount = new int[bssidInfos.length];
- Arrays.fill(mLostCount, mApLostThreshold); // default to lost
- mMostRecentResult = new ScanResult[bssidInfos.length];
- mPendingEvent = new int[bssidInfos.length];
- mFiredEvents = false;
- } else {
- mLostCount = null;
- mMostRecentResult = null;
- mPendingEvent = null;
- }
- }
-
- public void clearSettings() {
- setSettings(null, 0, 0);
- }
-
- /**
- * Get the most recent scan results for APs that triggered the given event on the last call
- * to {@link #processScan}.
- */
- public ScanResult[] getLastResults(int event) {
- ArrayList<ScanResult> results = new ArrayList<>();
- for (int i = 0; i < mLostCount.length; ++i) {
- if (mPendingEvent[i] == event) {
- results.add(mMostRecentResult[i]);
- }
- }
- return results.toArray(new ScanResult[results.size()]);
- }
-
- /**
- * Process the supplied scan results and determine if any events should be generated based
- * on the configured settings
- * @return The events that occurred
- */
- public int processScan(List<ScanResult> scanResults) {
- if (mBssidInfos == null) {
- return EVENT_NONE;
- }
-
- // clear events from last time
- if (mFiredEvents) {
- mFiredEvents = false;
- for (int i = 0; i < mLostCount.length; ++i) {
- mPendingEvent[i] = EVENT_NONE;
- }
- }
-
- int eventCount = 0;
- int eventType = EVENT_NONE;
- for (int i = 0; i < mLostCount.length; ++i) {
- ScanResult result = findResult(scanResults, mBssidInfos[i].bssid);
- int rssi = Integer.MIN_VALUE;
- if (result != null) {
- mMostRecentResult[i] = result;
- rssi = result.level;
- }
-
- if (rssi < mBssidInfos[i].low) {
- if (mLostCount[i] < mApLostThreshold) {
- mLostCount[i]++;
-
- if (mLostCount[i] >= mApLostThreshold) {
- if (mPendingEvent[i] == EVENT_FOUND) {
- mPendingEvent[i] = EVENT_NONE;
- } else {
- mPendingEvent[i] = EVENT_LOST;
- }
- }
- }
- } else {
- if (mLostCount[i] >= mApLostThreshold) {
- if (mPendingEvent[i] == EVENT_LOST) {
- mPendingEvent[i] = EVENT_NONE;
- } else {
- mPendingEvent[i] = EVENT_FOUND;
- }
- }
- mLostCount[i] = STATE_FOUND;
- }
- if (DBG) {
- Log.d(TAG, "ChangeBuffer BSSID: " + mBssidInfos[i].bssid + "=" + mLostCount[i]
- + ", " + mPendingEvent[i] + ", rssi=" + rssi);
- }
- if (mPendingEvent[i] != EVENT_NONE) {
- ++eventCount;
- eventType |= mPendingEvent[i];
- }
- }
- if (DBG) Log.d(TAG, "ChangeBuffer events count=" + eventCount + ": " + eventType);
- if (eventCount >= mMinEvents) {
- mFiredEvents = true;
- return eventType;
- }
- return EVENT_NONE;
- }
- }
-
/**
* HW PNO Debouncer is used to debounce PNO requests. This guards against toggling the PNO
* state too often which is not handled very well by some drivers.
diff --git a/tests/wifitests/src/com/android/server/wifi/scanner/WifiScanningServiceTest.java b/tests/wifitests/src/com/android/server/wifi/scanner/WifiScanningServiceTest.java
index e7962f508..3cd08439e 100644
--- a/tests/wifitests/src/com/android/server/wifi/scanner/WifiScanningServiceTest.java
+++ b/tests/wifitests/src/com/android/server/wifi/scanner/WifiScanningServiceTest.java
@@ -355,8 +355,6 @@ public class WifiScanningServiceTest {
capabilities.max_ap_cache_per_scan = MAX_AP_PER_SCAN;
capabilities.max_rssi_sample_size = 8;
capabilities.max_scan_reporting_threshold = 10;
- capabilities.max_hotlist_bssids = 0;
- capabilities.max_significant_wifi_change_aps = 0;
return true;
}
});