• S3c6410 平台 Android系统的Wi-Fi调试记录


    硬件平台:S3c6410

    操作系统:Android

    网卡芯片:GH381(SDIO接口 sdio8688)

    1、SDIO驱动

            因为是SDIO接口,所以请先保证mmc驱动(代码在“kerneldriversmmc”)部分能够正常工作,这个一般调试flash的时候会涉及到,问题不大,因为S3c6410平台的HSMMC有3个,要根据硬件原理图确认网卡的SDIO接口接在哪个上面了,我调试的时候是HSMMC1,针对HSMMC1涉及到的修改有

             ① "kernelarcharmconfigssmdk6410_android_deconfig":

                    CONFIG_S3C_DEV_HSMMC1=y

                    CONFIG_S3C6410_SD_CH1=y

            ②"kernelarcharmmach-s3c6410Kcofnig":

                    select S3C_DEV_HSMMC1

            ③“kernelarcharmmach-s3c6410mach-smdk6410.c":

                    #ifdef CONFIG_S3C6410_SD_CH1

                        &s3c_device_hsmmc1,

                     #endif

            注:目前暂时把网卡的上电部分放到了mmc初始化管脚的时候,以后再挪到其他地方

    2、网卡驱动

            网卡驱动一般由芯片厂商提供,如果能拿到源代码首先要保证能够编译通过,GH381的驱动编译出来名为sd8xxx.ko。

            驱动能够编译通过后,就是加载了,两个步骤:

            1)把驱动和firmware放到系统中去.

            一般是在”eclairvendorsec_proprietary"目录下建一个目录,放上驱动和firmware文件。

            然后在Android.mk中将文件拷贝到设备对应目录即可,如:

            PRODUCT_COPY_FILES += $(LOCAL_PATH)/helper_sd.bin:system/etc/firmware/mrvl/helper_sd.bin (firmware文件)

            PRODUCT_COPY_FILES += $(LOCAL_PATH)/sd8688.bin:system/etc/firmware/mrvl/sd8688.bin (firmware文件)

            PRODUCT_COPY_FILES += $(LOCAL_PATH)/sd8xxx.ko:system/lib/modules/sd8xxx.ko (驱动文件)        

            2)系统调用驱动,驱动download firmware

                因为网卡驱动对上层的接口是通过wpa_supplicant中间层实现的,因此也要保证wpa层能能够正确的识别网卡。

            涉及到的代码修改有:

            ①”eclairhardwarelibhardware_legacywifiwifi.c“

                    #define WIFI_DRIVER_MODULE_PATH         "/system/lib/modules/sd8xxx.ko"//驱动文件的全路径

                    #define WIFI_DRIVER_MODULE_NAME         "sd8xxx" //这个名字是模块名字,用于关闭WIFI时调用,一般和ko文件的名字相同

                    #define WIFI_TEST_INTERFACE "mlan0"//"sta"(这个名字是根据网卡名字写的,但是个人感觉应该用sta才对)

            注:这部分修改,保证在启动wifi的时候可以找到对应的驱动

            “eclairvendorsecsmdk6410AndroidBoard.mk”

                    BOARD_WPA_SUPPLICANT_DRIVER := WEXT

            注:这部分修改,保证wpa_supplicnat能够正常编译到系统中(见“externalwpa_supplicantAndroid.mk”开始部分的编译条件)

            ③“eclairvendorsecsmdk6410init.rc”

                    # give system access to wpa_supplicant.conf for backup and restore
                    mkdir /system/etc/wifi 0770 wifi wifi
                    chmod 0770 /system/etc/wifi
                    chmod 0660 /system/etc/wifi/wpa_supplicant.conf
                    chown wifi wifi /system/etc/wifi/wpa_supplicant.conf
        
                    #wpa_supplicant control socket for android wifi.c (android private socket)
                    mkdir /data/misc/wifi 0777 wifi wifi
                    mkdir /data/misc/wifi/sockets 0777 wifi wifi
                    mkdir /data/system/wpa_supplicant 0777 wifi wifi
                    chmod 0777 /data/misc/wifi
                    chmod 0777 /data/misc/wifi/wpa_supplicant.conf
                    chown wifi wifi /data/misc/wifi
                    chown wifi wifi /data/misc/wifi/wpa_supplicant.conf
        
                    mkdir /data/misc/dhcp 0777 dhcp dhcp
                    chmod 0777 /data/misc/dhcp
                    chmod 0777 /system/etc/dhcpcd
                    chmod 0777 /system/etc/dhcpcd/dhcpcd-run-hooks # dhcpcd-run-hooks的权限一定要设置,不然DHCP服务无法正常工作
                    chown dhcp dhcp /data/misc/dhcp
                    chown dhcp dhcp /system/etc/dhcpcd
                    chown dhcp dhcp /system/etc/dhcpcd/dhcpcd-run-hooks                

                 on boot#注意这里,创建目录,设置权限的部分一定要放在on boot 之前,而启动服务设置接口的在放在之后。不然会出现没有/data/misc/dhcp目录的问题,之后dhcp服务更无法工作。

                   service wpa_supplicant /system/bin/wpa_supplicant -dd -Dwext -imlan0-c /system/etc/wifi/wpa_supplicant.conf
                    #socket wpa_mlan0dgram 660 wifi wifi
                   #group system wifi inet
                    disabled
                    oneshot

                    service dhcpcd /system/bin/dhcpcd -f /system/etc/dhcpcd/dhcpcd.conf -dmlan0
                    #group system dhcp wifi
                    disabled
                    oneshot

                    setprop wifi.interface "mlan0"
                    setprop wlan.driver.status "ok"
                    setprop wlan.interface "mlan0"

                    注:红色的部分mlan0是网卡驱动设置的网卡名字,这部分代码可以在驱动代码的wlan_add_card()函数中找到:

                     if (dev_alloc_name(dev, "mlan%d") < 0) {

                         PRINTM(ERROR, "Could not allocate device name! ");

                         goto err_kmalloc;

                     }

            "eclairexternalwpa_supplicantwpa_supplicant.conf"

                    update_config=1

                    //ctrl_interface=mlan0 这部分应该是Android的特殊定义,不过用起来貌似会有错误,就使用下面通用的unix设置了

                    ctrl_interface=DIR=/data/misc/wifi/wpa_supplicant GROUP=wifi

                    ap_scan=1 #这里最好设置为1,不然可能会出现搜索不到AP的现象。

     

            目前的状态:WIFI可以成功打开,搜索到周围的AP,连接部分还存在问题,继续调试。2011.2.11 16:30

    -------------------------------------------------------------------------------------------------------

    碰到问题及解决方式:

    1、连接AP时,运行到下面的代码时,出现错误
         Wlan_wmm.c wmm_process_app_iface_tx{
         ...
         atomic_inc(&Adapter->wmm.packetsQueued);//此处有错误
         ...
         }
         错误如下:
         Alignment trap: not handling instruction e1930f9f at [<bf027b90>]
         Unhandled fault: alignment exception (0x001) at 0xc98ac0b2 //校准错误
            
         解决办法:
         在wmm的结构体中增加变量,使整个结构体,在packetsQueued的前面是4个字节的整数倍
         typedef struct
          {
                u8 required;
                u8 enabled;
                u16 tmp;//此处为额外增加,保证packetsQueued前面有4个字节
                atomic_t packetsQueued;
                ...
           }__ATTRIB_PACK__ WMM_DESC;

           目前这种解决方式只是针对错误提示,也有可能根本原因在于编译参数等设置的存在问题,后续再分析。

    目前状态:可以成功连接AP,但是之后获取AP地址的时候失败,应该是DHCP服务器的设置还存在问题。

    -------------------------------------------------------------------------------------------------------------------------

    获取IP地址失败,可能的原因如下:

    1、DHCP服务没有启动,或者启动后工作不正常,请参考前面“eclairvendorsecsmdk6410init.rc”中增加的内容。

    2、DHCP代码中的网卡接口错误,请查看文件“eclairframeworksasewifijafaandroid etwifiWifiStateTracker.java”中的函数:

    public WifiStateTracker()

    {

    ...

            mSettingsObserver = new SettingsObserver(new Handler());

            mInterfaceName = SystemProperties.get("wifi.interface", "mlan0" ); //"tiwlan0");此处默认的网卡名称为tiwlan0,需修改为我们使用的
            sDnsPropNames = new String[] {
                "dhcp." + mInterfaceName + ".dns1",
                "dhcp." + mInterfaceName + ".dns2"
            };

    ...

    }

    目前,WIFI已经可以正常的连接不加密类型的AP热点,并成功获取IP地址,打开网页,正常开关。

  • 相关阅读:
    我的死党前同事 料
    相信缘份吗?我所见所闻的测试工程师
    多线程基础【面试题形式】
    kafka学习(五)Spring Boot 整合 Kafka
    kafka学习(四)kafka安装与命令行调用
    J2EE的13个规范总结
    Spring Boot学习(四)常用注解
    kafka学习(三)kafka生产者,消费者详解
    dubbo学习(十一)dubbo知识点总结
    MyBatis学习(三)日志输出环境配置
  • 原文地址:https://www.cnblogs.com/muhuacat/p/5498577.html
Copyright © 2020-2023  润新知