Android Oreo8.0 使用wpa_supplicant和wpa_cli(更新AndroidPie9.0)

使用wpa_cli关键是先启动wpa_supplicant,而启动wpa_supplicant关键是要指定好启动参数,文件路径要对。

 

  • 启动WLAN

(1)加载驱动 
android系统需要先load driver。手动调试dirver ko的时候,先调用insmod命令加载指定的wifi驱动。 

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

# 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 (c) 2004-2013, Jouni Malinen  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通了。

 

你可能感兴趣的:(android,wifi,wpa_supplicant)