降龙十八掌搞定rt3070 USB WIFI模块在android2.3平台上上网[基于x210开发板]

第一掌:编译KO文件,生成rt3070sta.ko

编译时提示如下错误:

错误:

./include/generated/autoconf.h:708: fatal error: /home/lqm/share/V210/samsung/kernel/include/config/modversions.h: No such file or directory

这是因为内核中没有开启模块版本管理选项,在内核的menuconfig中做如下配置:

make menuconfig

[*] Enable loadable module support  —>

[*]   Module versioning support

重新编译内核后,再编译RT3070源码,该问题解决。

另外提示找不到private等变量的问题,是因为内核中CONFIG_EXT_PRIV没有置高造成的,三星默认BSP包并没有置高该变量,这个配置很繁琐,配了

整整一个下午也没有配出来,换用自己的BSP包,问题解决。

为支持android系统,需修改源码:

由于在linux的根文件系统下存在/etc目录,而android的根目录下,/etc是从/system/etc下链接过来的,因此

需要修改wifi源码,让驱动从/system/etc下寻找配置文件。

寻找/etc/Wireless文件,找到如下文件存在,全修改为/system/etc/Wireless:

root@lqm:/opt/program/tools/RT3070_Linux_STA# grep -r ‘/etc/Wireless’ ./

./include/os/rt_drv.h:#define STA_PROFILE_PATH
“/etc/Wireless/RT2870STA/RT2870STA.dat”

./include/os/rt_drv.h:#define CARD_INFO_PATH
“/etc/Wireless/RT2870STA/RT2870STACard.dat”

./include/os/rt_drv.h:#define EEPROM_BIN_FILE_NAME  “/etc/Wireless/RT2870STA/e2p.bin”

./include/os/rt_linux.h:#define STA_PROFILE_PATH
“/etc/Wireless/RT2870STA/RT2870STA.dat”

./include/os/rt_linux.h:#define CARD_INFO_PATH
“/etc/Wireless/RT2870STA/RT2870STACard.dat”

./include/os/rt_linux.h:#define EEPROM_BIN_FILE_NAME  “/etc/Wireless/RT2870STA/e2p.bin”

./os/linux/Makefile.6:DAT_PATH = /etc/Wireless/RT$(CHIPSET_DAT)STA

./os/linux/Makefile.6:
$(shell [ ! -f /etc/Wireless ] && mkdir /etc/Wireless)

二进制文件 ./os/linux/rt_profile.o 匹配

./os/linux/Makefile:DAT_PATH = /mnt/etc/Wireless/RT$(CHIPSET_DAT)STA

./os/linux/Makefile:
$(shell [ ! -f /etc/Wireless ] && mkdir /etc/Wireless)

二进制文件 ./os/linux/rt3070sta.o 匹配

二进制文件 ./os/linux/rt3070sta.ko 匹配

./os/linux/Makefile.4:DAT_PATH = /etc/Wireless/RT$(CHIPSET_DAT)STA

./os/linux/Makefile.4:
$(shell [ ! -f /etc/Wireless ] && mkdir /etc/Wireless)

二进制文件 ./common/rtmp_init_inf.o 匹配

./RT2870STACard.dat:00CARDID=/etc/Wireless/RT2870STA/RT2870STA1.dat

./RT2870STACard.dat:01CARDID=/etc/Wireless/RT2870STA/RT2870STA2.dat

./RT2870STACard.dat:02CARDID=/etc/Wireless/RT2870STA/RT2870STA3.dat

./RT2870STACard.dat:00MAC00:0E:2E:C3:D0:48=/etc/Wireless/RT2870STA/RT2870STA1.dat

./RT2870STACard.dat:01MAC00:40:F4:FF:AA:40=/etc/Wireless/RT2870STA/RT2870STA2.dat

./RT2870STACard.dat:02MAC00:0C:43:10:11:5C=/etc/Wireless/RT2870STA/RT2870STA3.dat

./RT2870STACard.dat:00CARDTYPEbgn=/etc/Wireless/RT2870STA/RT2870STA1.dat

./RT2870STACard.dat:01CARDTYPEbgn=/etc/Wireless/RT2870STA/RT2870STA2.dat

./RT2870STACard.dat:02CARDTYPEabgn=/etc/Wireless/RT2870STA/RT2870STA3.dat

root@lqm:/opt/program/tools/RT3070_Linux_STA# 

再次编译,最终得到我们需要的ko文件。

第二掌:修改init.rc文件

on init

    # give system access to wpa_supplicant.conf for backup and restore

    mkdir /data/misc/wifi 0777 wifi system

    chmod 0771 /data/misc/wifi

    chmod 0660 /data/misc/wifi/wpa_supplicant.conf

    mkdir /system/etc/wifi 0771 wifi wifi

    chmod 0771 /system/etc/wifi

    chmod 0660 /system/etc/wifi/wpa_supplicant.conf

    chown wifi wifi /system/etc/wifi/wpa_supplicant.conf

    

    mkdir /data/misc/dhcp 0777 wifi system

    mkdir /data/misc/wifi/sockets 0777 wifi wifi

    mkdir /data/misc/wifi/wpa_supplicant 0777 wifi system

    mkdir /data/misc/wifi/hostapd 0777 wifi system

    mkdir /system/etc/Wireless 0777 wifi wifi

    mkdir /system/etc/Wireless/RT2870STA 0777 wifi wifi

on boot

# basic network init

    ifup lo

    hostname localhost

    domainname localdomain

    mkdir /data/system 0775 system system

    mkdir /data/system/wpa_supplicant 0771 wifi wifi # lqm added.

# Set DNS. lqm added.

    setprop net.dns1 192.168.1.1

# Prepare for wifi. lqm added.

    setprop wifi.interface ra0

    mkdir /data/misc/wifi/sockets 0777 wifi wifi #lqm changed property

    mkdir /data/misc/dhcp 0771 system system #lqm changed.

service wpa_supplicant /system/bin/wpa_supplicant -Dwext -ira0 -c /system/etc/wifi/wpa_supplicant.conf

     group system wifi inet

     disabled

     oneshot

service dhcpcd /system/bin/dhcpcd ra0

     group system dhcp wifi

     disabled

     oneshot

默认init.rc中全使用的wlan0,而rt2860的网络名称为ra0,因此需全替换为ra0。

第三掌:修改hardware/libhardware_legacy/wifi/wifi_rt3070.c文件,内容详见源码,注意,

默认该目录下有一个wifi.c文件,它已经针对AR6102调试成功,为保持兼容性,特别再建一个wifi_rt3070.c

文件,通过Android.mk脚本选择。

在Android.mk脚本中做如下判断:

ifeq ($(BOARD_HAVE_WIFI_AR6102), true)

  LOCAL_SRC_FILES += wifi/wifi.c

else

  LOCAL_SRC_FILES += wifi/wifi_rt3070.c

endif

这里就需要定义变量BOARD_HAVE_WIFI_AR6102了,通常我们在device/samsung/smdkv210/BoardConfig.mk中定义,

示例如下:

BOARD_HAVE_WIFI_AR6102 := false

BOARD_WPA_SUPPLICANT_DRIVER := WEXT

在wifi_rt3070.c中,主要是修改了模块的名称等,重要修改部分如下:

#ifndef WIFI_DRIVER_MODULE_PATH

#define WIFI_DRIVER_MODULE_PATH         “/system/lib/modules/rt3070sta.ko”

#endif

#ifndef WIFI_DRIVER_MODULE_NAME

#define WIFI_DRIVER_MODULE_NAME         “rt3070sta”

#endif

#ifndef WIFI_DRIVER_MODULE_ARG

#define WIFI_DRIVER_MODULE_ARG          “”

#endif

#ifndef WIFI_FIRMWARE_LOADER

#define WIFI_FIRMWARE_LOADER
“”

#endif

#define WIFI_TEST_INTERFACE
“sta”

#define WIFI_DRIVER_LOADER_DELAY
5000000

static const char IFACE_DIR[]           = “/data/system/wpa_supplicant”;

static const char DRIVER_MODULE_NAME[]  = WIFI_DRIVER_MODULE_NAME;

static const char DRIVER_MODULE_TAG[]   = WIFI_DRIVER_MODULE_NAME ” “;

static const char DRIVER_MODULE_PATH[]  = WIFI_DRIVER_MODULE_PATH;

static const char DRIVER_MODULE_ARG[]   = WIFI_DRIVER_MODULE_ARG;

static const char FIRMWARE_LOADER[]     = WIFI_FIRMWARE_LOADER;

static const char DRIVER_PROP_NAME[]    = “wlan.driver.status”;

static const char SUPPLICANT_NAME[]     = “wpa_supplicant”;

static const char SUPP_PROP_NAME[]      = “init.svc.wpa_supplicant”;

static const char SUPP_CONFIG_TEMPLATE[]= “/system/etc/wifi/wpa_supplicant.conf”;

static const char SUPP_CONFIG_FILE[]    = “/data/misc/wifi/wpa_supplicant.conf”;

static const char MODULE_FILE[]         = “/proc/modules”;

wifi.c用于启动时自动加载ko模块,因触摸屏效果不理想,这里暂时使用手动加载的方法,后续更新自动加载功能。

第四掌:BoardConfig.mk配置

device/samsung/smdkv210/BoardConfig.mk中,屏掉如下语句:

WPA_SUPPLICANT_VERSION := VER_0_6_X

在external目录,可以看到有wpa_supplicant和wpa_supplicant_6两个目录,他们分别对应0.5和0.6两个版本。

打开前面目录的Android.mk文件,可以看到有如下定义:

ifndef WPA_SUPPLICANT_VERSION

WPA_SUPPLICANT_VERSION := VER_0_5_X

endif

打开后面目录的Android.mk文件,可以看到有如下定义:

ifeq ($(WPA_SUPPLICANT_VERSION),VER_0_6_X)

    include $(call all-subdir-makefiles)

endif

可见,这两个目录都是根据变量WPA_SUPPLICANT_VERSION的值来决定是否编译,最终都是生成WPA_SUPPLICANT可

执行文件。这里测试0.5版本的WPA_SUPPLICANT,可以成功上网,0.6版本的有兴趣的可以测试一下,之前在MX53平台

上使用0.6的版本无法正常上网,一直报错。

第五掌:device.mk配置

由于AR6102和RT3070的init.rc文件不同,至少目前没有使用自动联网方式下是有很大差异的,为了保证二者兼容性,

另做一个init.rc文件,命名为init_sdmmc_RT3070.rc,这时,init_sdmmc.rc就是针对AR6102的,

init_sdmmc_RT3070.rc就是针对RT3070的,具体通过device.mk来选择,示例脚本如下:

ifeq ($(BOARD_SDMMC_BSP),true)

ifeq ($(BOARD_HAVE_WIFI_AR6102),true)

source_init_rc_file := $(LOCAL_PATH)/init_sdmmc_RT3070.rc

else

source_init_rc_file := $(LOCAL_PATH)/init_sdmmc.rc

endif

else

source_init_rc_file := $(LOCAL_PATH)/init.rc

endif

可以看到,这里通过两个变量判断,如果没有定义BOARD_SDMMC_BSP,则使用init.rc,即如果映像文件全烧在nand中,

则使用init.rc,目前我们暂时将映像文件全放在SD卡上,先不考虑init.rc文件。

第六掌:device-vendor.mk文件配置

在vendor/samsung/smdkv210目录下,打开device-vendor.mk文件,可以发现很多关于WIFI的文件都是在这里指定

并拷备的,由于之前拷备的全是AR6102的文件,这里需添加RT3070文件,同样我们可以使用变量BOARD_HAVE_WIFI_AR6102

来判断。示例如下:

ifeq ($(BOARD_HAVE_WIFI_AR6102), true)

PRODUCT_COPY_FILES +=   \

        vendor/samsung/smdkv210/wifi/bin/busybox:system/busybox/busybox \

vendor/samsung/smdkv210/wifi/bin/ls:system/busybox/ls \

        vendor/samsung/smdkv210/wifi/bin/cp:system/busybox/cp \

        vendor/samsung/smdkv210/wifi/bin/sh:system/busybox/sh \

        vendor/samsung/smdkv210/wifi/bin/wmiconfig:system/bin/wmiconfig \

        vendor/samsung/smdkv210/wifi/bin/wlan_tool:system/bin/wlan_tool \

vendor/samsung/smdkv210/wifi/bin/deviceid:system/bin/deviceid \

        vendor/samsung/smdkv210/wifi/etc/udhcpd.conf:system/etc/udhcpd.conf \

        vendor/samsung/smdkv210/wifi/etc/dhcpcd.conf:system/etc/dhcpcd.conf \

        vendor/samsung/smdkv210/wifi/etc/wifi/wpa_supplicant.conf:system/etc/wifi/wpa_supplicant.conf \

        vendor/samsung/smdkv210/wifi/etc/wifi/hostapd.conf:system/etc/wifi/hostapd.conf \

        vendor/samsung/smdkv210/wifi/fw/softmac:system/wifi/softmac \

        vendor/samsung/smdkv210/wifi/fw/data.patch.hw2_0.bin:system/wifi/data.patch.hw2_0.bin \

        vendor/samsung/smdkv210/wifi/fw/calData_ar6102_15dBm.bin:system/wifi/calData_ar6102_15dBm.bin \

        vendor/samsung/smdkv210/wifi/fw/athwlan.bin.z77:system/wifi/athwlan.bin.z77 \

        vendor/samsung/smdkv210/wifi/fw/ar6000.ko:system/wifi/ar6000.ko

else

PRODUCT_COPY_FILES +=   \

        vendor/samsung/smdkv210/wifi/bin/busybox:system/busybox/busybox \

vendor/samsung/smdkv210/wifi/bin/ls:system/busybox/ls \

        vendor/samsung/smdkv210/wifi/bin/cp:system/busybox/cp \

        vendor/samsung/smdkv210/wifi/bin/sh:system/busybox/sh \

        vendor/samsung/smdkv210/wifi/bin/wmiconfig:system/bin/wmiconfig \

vendor/samsung/smdkv210/wifi/bin/deviceid:system/bin/deviceid \

        vendor/samsung/smdkv210/wifi/etc/udhcpd.conf:system/etc/udhcpd.conf \

        vendor/samsung/smdkv210/wifi/etc/dhcpcd.conf:system/etc/dhcpcd_rt3070.conf \

        vendor/samsung/smdkv210/wifi/etc/wifi/wpa_supplicant_RT3070.conf:system/etc/wifi/wpa_supplicant.conf \

        vendor/samsung/smdkv210/wifi/etc/wifi/RT2870STA.dat:system/etc/Wireless/RT2870STA/RT2870STA.dat \

        vendor/samsung/smdkv210/wifi/etc/wifi/hostapd.conf:system/etc/wifi/hostapd_rt3070.conf \

        vendor/samsung/smdkv210/wifi/fw/softmac:system/wifi/softmac \

        vendor/samsung/smdkv210/wifi/fw/rt3070sta.ko:system/wifi/rt3070sta.ko

endif

第七掌:由于前面屏掉了WPA_SUPPLICANT_VERSION,需要单独编译wpa_supplicant。注意,编译之前先要删掉

wpa_supplicant生成的一些文件,否则会提示出错,路径如下:

out/target/product/smdkv210/obj/EXECUTABLES/wpa_cli_intermediates以及

out/target/product/smdkv210/obj/EXECUTABLES/wpa_supplicant_intermediates

将这两个目录删掉,再编译:

source build/envsetup.sh

mm external/wpa_supplicant/ PRODUCT-full_smdkv210-eng

这时将会在out/…./system/bin下生成新的wpa_supplicant文件。

第八掌:新建wpa_supplicant配置文件

默认在vendor/samsung/smdkv210/wifi/etc/wifi目录下,存在wpa_supplicant.conf文件,保留用于AR6102,新

建wpa_supplicant_RT3070.conf文件,内容如下:

# WPA-PSK/TKIP

ctrl_interface=/data/system/wpa_supplicant

network={

ssid=”yyb”

scan_ssid=1

key_mgmt=WPA-EAP WPA-PSK IEEE8021X NONE

pairwise=TKIP CCMP

group=CCMP TKIP WEP104 WEP40

psk=”androidok”

}

注意,ctrl_interface的路径不要放在/system目录下,否则会提示unlink[ctrl_iface]: Not a directory的错误。

ssid为路由的名称,androidok为路由的密码,用户请根据自己的路由密码设置。

将wpa_supplicant_RT3070.conf文件拷贝到/ventor/samsung/smdkv210/wifi/etc/wifi目录; 

第九掌:新建hostapd配置文件

在vendor/samsung/smdkv210/wifi/etc/wifi目录下,存在hostapd.conf文件,保留用于AR6102,新建hostapd_rt3070.conf

文件,内容如下:

interface=ra0

ctrl_interface=ra0

ssid=test

channel=1

max_num_sta=8

beacon_int=100

dtim_period=1

二者区别在于接口名称,rt3070名称为ra0。

第十掌:将第一步生成的RT2870STA.dat文件拷贝到vendor/samsung/smdkv210/wifi目录;

第十一掌:新建dhcpcd配置文件

在vendor/samsung/smdkv210/wifi/etc目录下,存在dhcpcd.conf文件,保留用于AR6102,新建dhcpcd_rt3070.conf文件,

内容如下:

# dhcpcd configuration for Android Wi-Fi interface

# See dhcpcd.conf(5) for details.

interface ra0

# dhcpcd-run-hooks uses these options.

option subnet_mask, routers, domain_name_servers, domain_search, host_name, domain_name

第十二掌:将第一步生成的rt3070sta.ko文件拷贝到vendor/samsung/smdkv210/wifi/fw目录;

第十三掌:重新编译android源码,注意由于更新了init.rc,必须更新xboot;

第十四掌:更新内核,xboot,android系统映像,重启开发板,进入文件系统后,将USB WIFI模块插到USB HOST端口,加载驱动

手动加载驱动如下:

/mnt/sdcard # insmod rt3070sta.ko 

[  428.933862] rtusb init rt2870 —>

[  428.935247] 

[  428.935251] 

[  428.935254] === pAd = e117d000, size = 514896 ===

[  428.935260] 

[  428.938024] <– RTMPAllocTxRxRingMemory, Status=0

[  428.938394] <– RTMPAllocAdapterBlock, Status=0

[  428.951083] usbcore: registered new interface driver rt2870

/mnt/sdcard # 

注意,如果开发板没有检测到USB WIFI模块,则加载驱动时打印如下信息:

/mnt/sdcard # insmod rt3070sta.ko 

[  304.232305] rtusb init rt2870 —>

[  304.235108] usbcore: registered new interface driver rt2870

这时仅仅加载了驱动,没未探测到WIFI模块。

正常加载后,可以通过下面的命令查询驱动是否正常加载:

cat /proc/net/dev

正常打印如下:

/mnt/sdcard # cat /proc/net/dev

Inter-|   Receive                                                |  Transmit

 face |bytes    packets errs drop fifo frame compressed multicast|bytes    pacd

    lo:       0       0    0    0    0     0          0         0        0    0

  ifb0:       0       0    0    0    0     0          0         0        0    0

  ifb1:       0       0    0    0    0     0          0         0        0    0

  usb0:       0       0    0    0    0     0          0         0        0    0

  sit0:       0       0    0    0    0     0          0         0        0    0

ip6tnl0:       0       0    0    0    0     0          0         0        0   0

   ra0:       0       0    0    0    0     0          0         0        0    0

/mnt/sdcard #

可以看到多了一路ra0了,它就是我们需要的rt2860驱动。

第十五掌:配置IP地址,并使能网口

/mnt/sdcard # ifconfig ra0 192.168.1.5 up

[  668.686681] (Efuse for 3062/3562/3572) Size=0x2d [2d0-2fc] 

[  669.006160] –>RTUSBVenderReset

[  669.006280] <–RTUSBVenderReset

[  669.319229] RtmpOSFileOpen(): Error 2 opening /system/etc/Wireless/RT2870STA/RT2870STA.dat

[  669.319339] Open file “/system/etc/Wireless/RT2870STA/RT2870STA.dat” failed!

[  669.319430] 1. Phy Mode = 0

[  669.319466] ERROR!!! RTMPReadParametersHook failed, Status[=0x00000001]

[  669.383946] !!! rt28xx Initialized fail !!!

error: SIOCSIFFLAGS (Operation not permitted)

/mnt/sdcard # 

这是/system/etc下没有找到相关文件造成的,先手动创建,再配置IP地址,注意,手动创建时,会提示只读,需手动mount:

mount -o remount,rw -t ext4 /dev/block/mmcblk0p2 /system

再配置IP地址,正确打印如下:

/system/etc # ifconfig ra0 192.168.1.5 up

[  256.708808] (Efuse for 3062/3562/3572) Size=0x2d [2d0-2fc] 

[  257.018670] –>RTUSBVenderReset

[  257.018914] <–RTUSBVenderReset

[  257.339967] Key1Str is Invalid key length(0) or Type(0)

[  257.340119] Key2Str is Invalid key length(0) or Type(0)

[  257.340255] Key3Str is Invalid key length(0) or Type(0)

[  257.340393] Key4Str is Invalid key length(0) or Type(0)

[  257.342169] 1. Phy Mode = 5

[  257.342211] 2. Phy Mode = 5

[  257.344107] NVM is Efuse and its size =2d[2d0-2fc] 

[  257.411799] phy mode> Error! The chip does not support 5G band 5!

[  257.412329] RTMPSetPhyMode: channel is out of range, use first channel=1 

[  257.416162] (Efuse for 3062/3562/3572) Size=0x2d [2d0-2fc] 

[  257.435416] 3. Phy Mode = 9

[  257.516803] MCS Set = ff 00 00 00 01

[  257.528524] <==== rt28xx_init, Status=0

[  257.530162] 0x1300 = 00064300

/system/etc # ifconfig

使用如下指令查询是否配置成功:

/system/etc # ifconfig ra0

ra0: ip 192.168.1.5 mask 255.255.255.0 flags [up broadcast running multicast]

注意,不能使用ifconfig指令查询,仅使用ifconfig将找不到任何的网络名称。

第十六掌:使用wireless_tools寻找WIFI信号

注意,由于之前AR6102已经调试成功,因此这里没有必要再移植wireless_tools了,用现成的即可。

使用下面的指令寻找附近的AP:

iwlist ra0 scan

打印如下信息:

/ # iwlist ra0 scan

[  104.990667] ===>rt_ioctl_giwscan. 4(4) BSS returned, data->length = 642

ra0       Scan completed :

          Cell 01 – Address: F4:EC:38:5A:C5:1C

                    Protocol:802.11b/g/n

                    ESSID:”Lolaage”

                    Mode:Managed

                    Frequency:2.412 GHz (Channel 1)

                    Quality=31/100  Signal level=-77 dBm  Noise level=-85 dBm

                    Encryption key:on

                    Bit Rates:54 Mb/s

                    (Unknown Wireless Token 0x8C05)

                    (Unknown Wireless Token 0x8C05)

                    (Unknown Wireless Token 0x8C05)

          Cell 02 – Address: B0:48:7A:51:BA:72

                    Protocol:802.11b/g/n

                    ESSID:”yyb”

                    Mode:Managed

                    Frequency:2.437 GHz (Channel 6)

                    Quality=100/100  Signal level=-19 dBm  Noise level=-92 dBm

                    Encryption key:on

                    Bit Rates:22.5 Mb/s

                    (Unknown Wireless Token 0x8C05)

                    (Unknown Wireless Token 0x8C05)

                    (Unknown Wireless Token 0x8C05)

          Cell 03 – Address: 22:0F:C6:69:22:6A

                    Protocol:802.11b/g

                    ESSID:”888″

                    Mode:Managed

                    Frequency:2.437 GHz (Channel 6)

                    Quality=100/100  Signal level=-47 dBm  Noise level=-92 dBm

                    Encryption key:on

                    Bit Rates:54 Mb/s

                    (Unknown Wireless Token 0x8C05)

          Cell 04 – Address: 94:8F:C2:69:22:69

                    Protocol:802.11b/g

                    ESSID:”XGD-A”

                    Mode:Managed

                    Frequency:2.437 GHz (Channel 6)

                    Quality=31/100  Signal level=-77 dBm  Noise level=-81 dBm

                    Encryption key:on

                    Bit Rates:54 Mb/s

                    (Unknown Wireless Token 0x8C05)

/ # 

可见,第二个就是我们需要找的AP。

第十七掌:使用强大的wpa_supplicant连接网络:

/ # wpa_supplicant -Dwext -ira0 -c /system/etc/wifi/wpa_supplicant.conf &

/ # ===>rt_ioctl_giwscan. 4(4) BSS returned, data->length = 635

ioctl[SIOCSIWGENIE]==>rt_ioctl_siwfreq::SIOCSIWFREQ(Channel=1)

: Operation not supported on transport endpoint

/ # 

我们可以通过PING路由来测试是否工作正常:

/ # ping 192.168.1.1

PING 192.168.1.1 (192.168.1.1): 56 data bytes

RTMP_TimerListAdd: add timer obj d4ad873c!

Rcv Wcid(1) AddBAReq

Start Seq = 00000000

RTMP_TimerListAdd: add timer obj d4ada74c!

64 bytes from 192.168.1.1: seq=0 ttl=64 time=89.936 ms

64 bytes from 192.168.1.1: seq=1 ttl=64 time=2.154 ms

64 bytes from 192.168.1.1: seq=2 ttl=64 time=6.433 ms

64 bytes from 192.168.1.1: seq=3 ttl=64 time=0.899 ms

^C

— 192.168.1.1 ping statistics —

4 packets transmitted, 4 packets received, 0% packet loss

round-trip min/avg/max = 0.899/24.855/89.936 ms

/ # 

曾经遇到过如下错误信息:

/system/etc/wifi # wpa_supplicant -Dwext -ira0 -c /system/etc/wifi/wpa_supplican

t.conf &

/system/etc/wifi # [  327.506005] (Efuse for 3062/3562/3572) Size=0x2d [2d0-2fc] 

[  327.803791] RTMP_TimerListAdd: add timer obj e11c3280!

[  327.803867] RTMP_TimerListAdd: add timer obj e11c32b0!

[  327.803932] RTMP_TimerListAdd: add timer obj e11c32e0!

[  327.803999] RTMP_TimerListAdd: add timer obj e11c3250!

[  327.804068] RTMP_TimerListAdd: add timer obj e11c31c0!

[  327.807221] RTMP_TimerListAdd: add timer obj e11c31f0!

[  327.812275] RTMP_TimerListAdd: add timer obj e118ddf4!

[  327.817403] RTMP_TimerListAdd: add timer obj e117d0cc!

[  327.823662] RTMP_TimerListAdd: add timer obj e117d104!

[  327.827673] RTMP_TimerListAdd: add timer obj e118de98!

[  327.832743] RTMP_TimerListAdd: add timer obj e118dd94!

[  327.839855] RTMP_TimerListAdd: add timer obj e118de64!

[  327.846376] –>RTUSBVenderReset

[  327.846637] <–RTUSBVenderReset

[  328.190142] Key1Str is Invalid key length(0) or Type(0)

[  328.190288] Key2Str is Invalid key length(0) or Type(0)

[  328.190419] Key3Str is Invalid key length(0) or Type(0)

[  328.190555] Key4Str is Invalid key length(0) or Type(0)

[  328.192035] 1. Phy Mode = 5

[  328.192076] 2. Phy Mode = 5

[  328.194241] NVM is Efuse and its size =2d[2d0-2fc] 

[  328.251497] phy mode> Error! The chip does not support 5G band 5!

[  328.252119] RTMPSetPhyMode: channel is out of range, use first channel=1 

[  328.260874] (Efuse for 3062/3562/3572) Size=0x2d [2d0-2fc] 

[  328.280741] 3. Phy Mode = 9

[  328.351997] MCS Set = ff 00 00 00 01

[  328.367418] <==== rt28xx_init, Status=0

[  328.370119] 0x1300 = 00064300

unlink[ctrl_iface]: Not a directory

找了很久原因没有找到,后来修改wpa_supplicant.conf文件中wpa_supplicant的工作路径为/data/misc/wpa_supplicant即可。

有可能是权限问题,手动将以前的只读路径重新remount也不能解决问题,不知是何原因。

如果遇到如下问题:

[  329.394596] RtmpOSFileOpen(): Error 30 opening /system/etc/Wireless/RT2870STA/RT2870STA.dat

修改RT2870STA.dat权限为777即可。

第十八掌:进入android系统后,手动添加网关:

busybox ip route add default via 192.168.1.1

设置完后我们PING一下新浪主页,测试是否能正常上网了:

/ # ping 58.63.236.42

PING 58.63.236.42 (58.63.236.42): 56 data bytes

64 bytes from 58.63.236.42: seq=0 ttl=51 time=122.108 ms

64 bytes from 58.63.236.42: seq=1 ttl=51 time=15.205 ms

64 bytes from 58.63.236.42: seq=2 ttl=51 time=7.797 ms

64 bytes from 58.63.236.42: seq=3 ttl=51 time=11.878 ms

^C

— 58.63.236.42 ping statistics —

4 packets transmitted, 4 packets received, 0% packet loss

round-trip min/avg/max = 7.797/39.247/122.108 ms

/ # 

到此,整个USB WIFI的流程已经走通。在android图形界面下打开浏览器,会提示网络没连接的错误,这是因为我们全部使用手动方式上网,

暂先不理会它,随便输入网址,发现已经能够正常上网了。

如果您自己移植没有成功,仔细研究看看哪一掌没有练熟^_^

如果在ping时发现无法使用ctrl+c中止程序的问题,请参考如下文章:

<<解决busybox ctrl+c不能中止程序的问题>>

附:由于这里无法上传附件,相关代码及ko文件进如下链接下载:

http://xboot.org/forum.php?mod=viewthread&tid=370&page=1&extra=#pid411

    原文作者:Nightsong_cc
    原文地址: https://blog.csdn.net/gzw1623231307/article/details/56472557
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞