最近一直在处理公司wifi连接问题,遇到一个问题就是手动连接wifi概率性连接失败,日志打印如下:
根据日志,定位到WifiStateMachine这个类里面的updateLinkProperties方法里面报错。原因是 wasProvisioned:false,isProvisioned:false这两个boolean类型的值为false。现在来看源码:
/framework/opt/net/wifi/service/java/com/android/server/wifi/WifiStateMachine.java
再看看isPovisioned方法的实现:
可以看出是LinkProperties这个类里面的参数出了问题,回头看下LinkProperties的获取位置,在updateLinkProperties方法里面LinkProperties newLp = makeLinkProperties();去查看makeLinkProperties()这个方法:
看到这里,我们现在就需要去分析getLinkProperties设置LinkProperties的位置;
/framework/base/core/java/com/android/server/net/NetlinkTracker.java
现在有开始看mLinkProperties添加数据的位置:
搜索下 addressUpdated方法,查看数据在哪个位置设置进来的:
这时候进入NetworkManagementService.java里面722查看:
在当前类里面搜索 notifyAddressUpdated方法看看具体实现:
我们开始在系统下面搜索InterfaceAddressChange查看是哪里调用的,在framework下面没找到,最后在system下面找到了:
这里就是我们获取数据的源头,在此加打印分析具体原因,此问题交给netd同事处理。