在android p下调试wifi时发现,在settings扫描界面可以正常的显示各个AP的信号值,但是一旦连接上其中某个AP后,settings界面上该AP的信号值会变成空。
追查之下发现,上层在获取AP信号值时,在driver侧发现并不支持get_station接口,导致最终没有正确的获取到已连接AP的信号值。
整个信号的获取流程如下:
signalPoll wifiNative.java
signalPoll wificondControl.java
signalPoll client_interface_binder.cpp
SignalPoll client_interface_impl.cpp
GetStationInfo netlink_utils.cpp 同时会检测返回的结果
netlink_manager_->SendMessageAndGetSingleResponse
最终走到内核的nl80211_get_station函数中,此时如果driver侧不支持get_station接口,就会返回错误。而在添加了station接口并将信号值返回后,又出现了如下错误:
01-01 00:00:38.857 3457 3457 E wificond: Failed to get NL80211_STA_INFO_TX_PACKETS
追踪代码得知,在GetStationInfo中会存在若干过滤规则,如果driver侧的get_station接口没有提供过滤规则中的信息,则整个signalPoll函数就会执行失败,所以在driver层的get_station接口中不能仅仅返回signal信息,同时还需要返回若干统计信息。