手动连接wifi失败分析

    最近一直在处理公司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同事处理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值