S3c6410 平台 Android系统的Wi-Fi调试记录
硬件平台:S3c6410 操作系统:Android 网卡芯片:GH381(SDIO接口 sdio8688) 1、SDIO驱动 因为是SDIO接口,所以请先保证mmc驱动(代码在“kernel\drivers\mmc”)部分能够正常工作,这个一般调试flash的时候会涉及到,问题不大,因为S3c6410平台的HSMMC有3个,要根据硬件原理图确认网卡的SDIO接口接在哪个上面了,我调试的时候是HSMMC1,针对HSMMC1涉及到的修改有 ① "kernel\arch\arm\configs\smdk6410_android_deconfig": CONFIG_S3C_DEV_HSMMC1=y CONFIG_S3C6410_SD_CH1=y ②"kernel\arch\arm\mach-s3c6410\Kcofnig": select S3C_DEV_HSMMC1 ③“kernel\arch\arm\mach-s3c6410\mach-smdk6410.c": #ifdef CONFIG_S3C6410_SD_CH1 &s3c_device_hsmmc1, #endif 注:目前暂时把网卡的上电部分放到了mmc初始化管脚的时候,以后再挪到其他地方 2、网卡驱动 网卡驱动一般由芯片厂商提供,如果能拿到源代码首先要保证能够编译通过,GH381的驱动编译出来名为sd8xxx.ko。 驱动能够编译通过后,就是加载了,两个步骤: 1)把驱动和firmware放到系统中去. 一般是在”eclair\vendor\sec_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层能能够正确的识别网卡。 涉及到的代码修改有: ①”eclair\hardware\libhardware_legacy\wifi\wifi.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的时候可以找到对应的驱动 ②“eclair\vendor\sec\smdk6410\AndroidBoard.mk” BOARD_WPA_SUPPLICANT_DRIVER := WEXT 注:这部分修改,保证wpa_supplicnat能够正常编译到系统中(见“external\wpa_supplicant\Android.mk”开始部分的编译条件) ③“eclair\vendor\sec\smdk6410\init.rc” # give system access to wpa_supplicant.conf for backup and restore 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 service dhcpcd /system/bin/dhcpcd -f /system/etc/dhcpcd/dhcpcd.conf -dmlan0 setprop wifi.interface "mlan0" 注:红色的部分mlan0是网卡驱动设置的网卡名字,这部分代码可以在驱动代码的wlan_add_card()函数中找到: if (dev_alloc_name(dev, "mlan%d") < 0) { PRINTM(ERROR, "Could not allocate device name!\n"); goto err_kmalloc; } ③"eclair\external\wpa_supplicant\wpa_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时,运行到下面的代码时,出现错误 目前这种解决方式只是针对错误提示,也有可能根本原因在于编译参数等设置的存在问题,后续再分析。 目前状态:可以成功连接AP,但是之后获取AP地址的时候失败,应该是DHCP服务器的设置还存在问题。 ------------------------------------------------------------------------------------------------------------------------- 获取IP地址失败,可能的原因如下: 1、DHCP服务没有启动,或者启动后工作不正常,请参考前面“eclair\vendor\sec\smdk6410\init.rc”中增加的内容。 2、DHCP代码中的网卡接口错误,请查看文件“eclair\frameworks\base\wifi\jafa\android\net\wifi\WifiStateTracker.java”中的函数: public WifiStateTracker() { ... mSettingsObserver = new SettingsObserver(new Handler()); mInterfaceName = SystemProperties.get("wifi.interface", "mlan0" ); //"tiwlan0");此处默认的网卡名称为tiwlan0,需修改为我们使用的 ... } 目前,WIFI已经可以正常的连接不加密类型的AP热点,并成功获取IP地址,打开网页,正常开关。 |