wifi @android:wpa_wlan0,Android调试wifi使用wpa_supplicant和wpa_cli总结

司徒杜吟
2023-12-01

启动WLAN

(1)加载驱动

android系统需要先load driver。手动调试dirver ko的时候,先调用insmod命令加载指定的wifi驱动,注意有些wifi ko的加载后面需要添加参数。

再调用iwconfig可以看到驱动是否加载成功,如下,可以看到wlan0已经有了,则驱动加载成功。

(1)ifconfig -a

p2p0 Link encap:Ethernet HWaddr b2:72:bf:d9:55:9f Driver hif_pci

BROADCAST MULTICAST MTU:1500 Metric:1

RX packets:0 errors:0 dropped:0 overruns:0 frame:0

TX packets:0 errors:0 dropped:0 overruns:0 carrier:0

collisions:0 txqueuelen:3000

RX bytes:0 TX bytes:0

wlan0 Link encap:Ethernet HWaddr b0:72:bf:53:55:9f Driver hif_pci

UP BROADCAST MULTICAST MTU:1500 Metric:1

RX packets:0 errors:0 dropped:0 overruns:0 frame:0

TX packets:0 errors:0 dropped:0 overruns:0 carrier:0

collisions:0 txqueuelen:3000

RX bytes:0 TX bytes:0

lo Link encap:Local Loopback

inet addr:127.0.0.1 Mask:255.0.0.0

inet6 addr: ::1/128 Scope: Host

UP LOOPBACK RUNNING MTU:65536 Metric:1

RX packets:0 errors:0 dropped:0 overruns:0 frame:0

TX packets:0 errors:0 dropped:0 overruns:0 carrier:0

collisions:0 txqueuelen:1

RX bytes:0 TX bytes:0

sit0 Link encap:IPv6-in-IPv4

NOARP MTU:1480 Metric:1

RX packets:0 errors:0 dropped:0 overruns:0 frame:0

TX packets:0 errors:0 dropped:0 overruns:0 carrier:0

collisions:0 txqueuelen:1

RX bytes:0 TX bytes:0

eth0 Link encap:Ethernet HWaddr 00:04:9f:05:58:c7 Driver fec

UP BROADCAST MULTICAST MTU:1500 Metric:1

RX packets:0 errors:0 dropped:0 overruns:0 frame:0

TX packets:0 errors:0 dropped:0 overruns:0 carrier:0

collisions:0 txqueuelen:1000

RX bytes:0 TX bytes:0

(2)打开wlan0

ifconfig wlan0 up

启动wpa_supplicant

命令如下:可以参考下自己init.xxx.rc是如何配置的,参数可能会不一样。

/vendor/bin/hw/wpa_supplicant -d -B –iwlan0 –Dnl80211 -c/data/misc/wifi/wpa_supplicant.conf

-C/data/misc/wifi/sockets

-i:指定网口;

-D:指定驱动类型;

-c:指定了wpa_supplicant的配置文件。

-C : ctrl_interface parameter

配置文件/data/misc/wifi/wpa_supplicant.conf,-d参数是打开wpa_supplicant的打印。

这里AndroidPie9.0 改变了wpa_supplicant.conf 和 ctrl_interface 的路径:

我这边是改为了/vendor/etc/wifi/wpa_supplicant.conf 和 /data/vendor/wifi/wpa/sockets

所以能正确启动wpa_supplicant的关键就是这边要指定正确的参数路径。

然后确保wpa_supplicant已经运行起来了,可以ps -A | grep wpa看下。

console:/ # ps -A | grep wpa

wifi 4100 1 18316 4904 poll_schedule_timeout 0 S wpa_supplicant

启动wpa_cli

wpa_cli -i网口 -p socket所在路径

例如像我刚才那么调用的话,则用下面命令启动:

wpa_cli -iwlan0 -p /data/misc/wifi/sockets/

进入如下界面则已经可以正常调试了。

wpa_cli v2.0-devel-4.4.2_rtw_r12456.20141113_beta

Copyright © 2004-2013, Jouni Malinen j@w1.fi and contributors

This software may be distributed under the terms of the BSD license.

See README for more details.

Interactive mode

如果一直显示如果出现“Could not connect to wpa_supplicant - re-trying”,那表示 wpa_cli 不能和wpa_supplicant 建立 socket 连接,这时要检查 wpa_supplicant 进程是否还在,还有socket所在路径wlan0是否存在(在我的例子是/data/misc/wifi/sockets/wlan0)。

使用wpa_cli 进行debug

扫描ap

输入scan命令

scan

OK

<3>CTRL-EVENT-STATE-CHANGE id=-1 state=3 BSSID=00:00:00:00:00:00 SSID=

<3>CTRL-EVENT-SCAN-RESULTS

<3>CTRL-EVENT-STATE-CHANGE id=-1 state=0 BSSID=00:00:00:00:00:00 SSID=

wpa_supplicant有“CTRL-EVENT-SCAN-RESULTS ”的回复,则可以输入scan_results可以看到扫描结果,如下。

scan_results

bssid / frequency / signal level / flags / ssid

14:75:90:7b:9c:b2 5745 -52 [WPA-PSK-CCMP][WPA2-PSK-CCMP][ESS] TP-LINK_5G_9CB2

a0:63:91:45:9a:ed 5785 -63 [WPA2-PSK-CCMP][WPS][ESS] LinuxBSPtest_5G

a4:6c:2a:54:03:d7 5765 -57 [WPA2-EAP-CCMP][ESS] NXP

a4:6c:2a:54:03:db 5765 -58 [WPA-PSK-TKIP][WPA2-PSK-CCMP][ESS] External-Internet

a4:6c:2a:54:03:df 5765 -58 [WPA2-EAP-CCMP][ESS] Freescale

a4:6c:2a:54:03:d8 5765 -58 [WPA2-PSK-CCMP][ESS] Hydra

d4:ee:07:50:a8:52 2447 -50 [WPA-PSK-CCMP][WPA2-PSK-CCMP][ESS] Android_test

连接

从扫描结果选择连接一个ap。

add_network

1

set_network 1 ssid “HUAWEI G9 Youth”

OK

set_network 1 key_mgmt WPA-PSK

OK

set_network 1 psk “xx123456”

OK

set_network 1 pairwise CCMP

OK

set_network 1 group CCMP

OK

set_network 1 proto WPA2

OK

enable_network 1

OK

<3>CTRL-EVENT-STATE-CHANGE id=-1 state=3 BSSID=00:00:00:00:00:00 SSID=

<3>CTRL-EVENT-SCAN-RESULTS

<3>WPS-AP-AVAILABLE

<3>Trying to associate with d4:61:2e:a2:b9:e5 (SSID=‘HUAWEI G9 Youth’ freq=2437 MHz)

<3>CTRL-EVENT-STATE-CHANGE id=-1 state=5 BSSID=00:00:00:00:00:00 SSID=

<3>CTRL-EVENT-STATE-CHANGE id=1 state=6 BSSID=00:00:00:00:00:00 SSID=HUAWEI G9 Youth

<3>Associated with d4:61:2e:a2:b9:e5

<3>CTRL-EVENT-STATE-CHANGE id=1 state=7 BSSID=d4:61:2e:a2:b9:e5 SSID=HUAWEI G9 Youth

<3>CTRL-EVENT-STATE-CHANGE id=1 state=8 BSSID=d4:61:2e:a2:b9:e5 SSID=HUAWEI G9 Youth

<3>WPA: Key negotiation completed with d4:61:2e:a2:b9:e5 [PTK=CCMP GTK=CCMP]

<3>CTRL-EVENT-CONNECTED - Connection to d4:61:2e:a2:b9:e5 completed (auth) [id=1 id_str=]

<3>CTRL-EVENT-STATE-CHANGE id=1 state=9 BSSID=d4:61:2e:a2:b9:e5 SSID=HUAWEI G9 Youth

步骤如下:

(1)“add_network”,这里返回网络ID 为 1。

(2) 配置网络的 SSID,执行 set_network 1 ssid AP 的 SSID。

(3)配置网络的加密方式和密码。

(4)启动网络,执行“enable_network 0”。

(5)收到“CTRL-EVENT-CONNECTED”表示连接成功。

分配IP

此时已经连接上ap,dhcp分配一个IP即可。

输入 q 退出 wpa_cli,执行命令:dhcpcd wlan0

此时已经可以ping通了。

调试技巧总结:

可以在wpa_supplicant里面增加一些log来跟踪指令的下发流程。

通过在命令行终端输入getprop init.svc.wpa_servername 来检查wpa_supplicant进程是否在运行。

wpa_supplicant起来后,可以通过查看wpa_cli ping或者wpa_cli status来检测wpa_suppliant通道是否正常。

检查/system/etc/wifi/wpa_supplicant.conf和/data/misc/wifi/wpa_supplicant.conf中ctrl_interface是否正确。

检查/dev/socket/wpa_wlan0、/data/misc/wifi/sockets/wlan0、/data/misc/wifi/sockets/p2p、wpa_ctrl_*等节点是否成功创建。

通过lsmod检查驱动模块是否成功加载。

通过查看/sys/class/rfkill/目录下是否生成rfkill*节点判断驱动加载过程是否OK。

 类似资料: