本文介绍wifi framework层的扫描处理流程,所介绍的流程的代码1
2
(android\frameworks\opt\net\wifi\service\java\com\android\server\wifi\WifiStateMachine.java)
InitialState->SupplicantStartingState-> DriverStartedState->DisconnectedState
InitialState->SupplicantStartingState->DriverStartedState->DisconnectedState-> ObtainingIpState-> ConnectedState不管之前连接过ap,还是没连接过ap,在进入1
2
processMessage处理,调用下面函数:mFrequencyBand.set(band); // Flush old data - like scan results mWifiNative.bssFlush(); // Fetch the latest scan results when frequency band is set startScanNative(WifiNative.SCAN_WITHOUT_CONNECTION_SETUP, null);1
2
3
4
5
mWifiNative.scan的返回值由supplicant中的wpas_ctrl_scan1
2
mWifiNative.scan的返回值为true。在之前没有连接ap的情况下,进入DisconnectedState时,在亮屏1
2
CMD_NO_NETWORKS_PERIODIC_SCAN消息,mSupplicantScanIntervalMs(15s)。 sendMessageDelayed(obtainMessage(CMD_NO_NETWORKS_PERIODIC_SCAN, ++mPeriodicScanToken, 0), mSupplicantScanIntervalMs);1
2
3
消息。startScan(UNKNOWN_SCAN_SOURCE, -1, null, null); sendMessageDelayed(obtainMessage(CMD_NO_NETWORKS_PERIODIC_SCAN, ++mPeriodicScanToken, 0), mSupplicantScanIntervalMs);1
2
3
息接收函数处理;mContext.registerReceiver( new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { sScanAlarmIntentCount++; // Used for debug only startScan(SCAN_ALARM_SOURCE, mDelayedScanCounter.incrementAndGet(), null, null); if (VDBG) loge("WiFiStateMachine SCAN ALARM -> " + mDelayedScanCounter.get()); } }, new IntentFilter(ACTION_START_SCAN));1
2
3
4
5
6
7
8
9
10
会真正进行扫描动作,前面的Delayed Scan会被丢掉。若打开wifi之前连接过ap,则不会发起1
2
暗屏、亮屏的Delayed Scan计数机制,与没连接ap的情况是一样的。Wifi作为station时,大部分情况下都是处理连接1
2
其它中间连接状态,ap切换状态等等的情况,请自行分析。