`
huangqinqin
  • 浏览: 367074 次
  • 性别: Icon_minigender_2
  • 来自: 福州
社区版块
存档分类
最新评论

wifi全程移植

 
阅读更多

编译代码时,本目录下用mm,上级目录用mmm,如果加上参数-B则表示强制该目录下的所有文件。
如果编译时显示的编译信息有乱码情况,则需要在该终端export LANG=en 。

移植framework,hardware,wpa_supplicant,dhcpcd及system/core/init
一 修改framework
./frameworks/base/wifi/java/android/net/wifi/WifiStateTracker.java
将mInterfaceName = SystemProperties.get("wifi.interface", "tiwlan0");改成 mInterfaceName = SystemProperties.get("wifi.interface", "eth0");
编译生成
framework.jar
更新jar包:
adb push system/framework/framework.jar /system/framework

二 修改hardware
./hardware/libhardware_legacy/wifi/wifi.c
1 引用库文件:#include <unistd.h>
2 更改wifi接口,将#define WIFI_DEF_IFNAME   "wlan0"改成 #define WIFI_DEF_IFNAME  "eth0"(视项目具体情况而定)
3 更改驱动名及路径:将#define WIFI_DRIVER_MODULE_PATH  "/system/lib/modules/wlan.ko"改成 #define WIFI_DRIVER_MODULE_PATH "/data/dhd.ko"
4 更改驱动模块名:将#define WIFI_DRIVER_MODULE_NAME  "wlan" 改成 #define WIFI_DRIVER_MODULE_NAME  "dhd"
5 更改wifi接口路径:将static const char IFACE_DIR[] = "/data/system/wpa_supplicant"; 改成 static const char IFACE_DIR[] = "/data/wpa_supplicant";
6 增加wifi上电,下电代码:
static const char CONFIG_UP_NAME[] = "wifi_up";
static const char CONFIG_DOWN_NAME[] = "wifi_down";
static const char WIFI_POWER_PATH[] = "/sys/devices/platform/bcm4319-pm/power_state";
static const char * off_state = "off";
static const char * on_state = "on";
static int set_wifi_power(int on)       // on is 0: wifi down power, otherwise wifi up power.
{
    int fd = -1;
    int ret = -1;
    char buf[6];
    int len;

    fd = open(WIFI_POWER_PATH, O_WRONLY);
    //fd = open("/sys/devices/platform/bcm4319-pm/power_state", O_RDWR);
    LOGE("set_wifi_power fd=%d\n", fd);
    if (fd < 0) {
        LOGE("open wifi file %s failed.", WIFI_POWER_PATH);
        goto out;
    }
    if (on) {
        len = sprintf(buf, "on");
    } else {
        len = sprintf(buf, "off");
    }

    len = write(fd, buf, len);
    if (len < 0) {
        LOGE("write wifi file %s failed.", WIFI_POWER_PATH);
        goto out;
    }
    LOGE("set wifi power %s", WIFI_POWER_PATH);
    LOGE("whether wifi is on : %s", buf);
    close(fd);
    return 0;

out:
    if (fd >= 0) {
        close(fd);
    }

    return ret;
}

在insmod方法中的free(module);后面增加如下代码:
if (0 == ret) {
            property_set("ctl.start", CONFIG_UP_NAME);
}
在rmmod方法中的while循环后面增加如下代码:
if (0 == ret) {
        property_set("ctl.start", CONFIG_DOWN_NAME);
}

在wifi_load_driver中调用set_wifi_power(1);
在wifi_unload_driver中调用set_wifi_power(0);

编译生成
libhardware_legacy.so
更新so文件
adb push system/lib/libhardware_legacy.so /system/lib

三 修改wpa_supplicant
./external/wpa_supplicant/wpa_supplicant.conf
将 ctrl_interface=wlan0 改成 ctrl_interface=/data/wpa_supplicant
编译生成
wpa_supplicant.conf
更新文件
adb push system/etc/wifi/wpa_supplicant.conf /system/etc/wifi

如果希望log中能打印出所有级别的log信息,则可以更改wpa_supplicant目录下的common.h文件。
将wpa_printf定义中的if ((level) >= MSG_INFO) 改成 if ((level) >= MSG_ERROR) 如下:
#define wpa_printf(level, ...) \
        do {                                            \
            if ((level) >= MSG_ERROR) {                  \
                android_printf((level), __VA_ARGS__);   \
            }                                           \
        } while (0)

编译生成
wpa_supplicant
更新bin文件
adb push system/bin/wpa_supplicant /system/bin

四 修改dhcpcd
1 ./external/dhcpcd/Android.mk
将以下代码打开
include $(CLEAR_VARS)
LOCAL_MODULE := dhcpcd.conf
LOCAL_MODULE_TAGS := user
LOCAL_MODULE_CLASS := ETC
LOCAL_MODULE_PATH := $(etc_dir)
LOCAL_SRC_FILES := android.conf
include $(BUILD_PREBUILT)

2 ./external/dhcpcd/android.conf
将interface wlan0注释掉

3 ./external/dhcpcd/dhcp.c
将 return (const uint8_t *)dhcp_opt_buffer; 改成 return (const uint8_t *)&dhcp_opt_buffer;
4 ./external/dhcpcd/dhcpcd-hooks/20-dns.conf
在set_dns_props方法最后加上如下脚本代码:
for i in 1 2 3 4; do
      setprop net.dns${i} ""
done

count=1
for dnsaddr in ${new_domain_name_servers}; do
     setprop net.dns${count} ${dnsaddr}
     count=$(($count + 1))
done
在unset_dns_props方法中加上如下脚本代码:
for i in 1 2 3 4; do
       setprop dhcp.${interface}.dns${i} ""
done

for i in 1 2 3 4; do
       setprop net.dns${i} ""
done
编译生成
dhcpcd,dhcpcd.conf, 20-dns.conf
更新文件
adb push system/bin/dhcpcd /system/bin
adb push system/etc/dhcpcd.conf /system/etc/dhcpcd
adb push system/etc/dhcpcd/dhcpcd-hooks/20-dns.conf /system/etc/dhcpcd/dhcpcd-hooks

五 修改system/core
./system/core/init/property_service.c
如下结构体内容:
struct {
    const char *prefix;
    unsigned int uid;
    unsigned int gid;
} property_perms[] = {
    { "net.rmnet0.",      AID_RADIO,    0 },
    { "net.gprs.",        AID_RADIO,    0 },
    { "net.ppp",          AID_RADIO,    0 },
    { "ril.",             AID_RADIO,    0 },
    { "gsm.",             AID_RADIO,    0 },
    { "persist.radio",    AID_RADIO,    0 },
    { "net.dns",          AID_RADIO,    0 },
    { "net.",             AID_SYSTEM,   0 },
    { "dev.",             AID_SYSTEM,   0 },
    { "runtime.",         AID_SYSTEM,   0 },
    { "hw.",              AID_SYSTEM,   0 },
    { "sys.",             AID_SYSTEM,   0 },
    { "service.",         AID_SYSTEM,   0 },
    { "wlan.",            AID_SYSTEM,   0 },
    { "dhcp.",            AID_SYSTEM,   0 },
    { "dhcp.",            AID_DHCP,     0 },
    { "net.",             AID_DHCP,     0 }, // add to avoid "permission denied" error
    { "net.dns",          AID_DHCP,     0 }, // add to avoid "permission denied" error
    { "vpn.",             AID_SYSTEM,   0 },
    { "vpn.",             AID_VPN,      0 },
    { "debug.",           AID_SHELL,    0 },
    { "log.",             AID_SHELL,    0 },
    { "service.adb.root", AID_SHELL,    0 },
    { "persist.sys.",     AID_SYSTEM,   0 },
    { "persist.service.", AID_SYSTEM,   0 },
    { "persist.security.", AID_SYSTEM,  0 },
    { "xec.",             AID_SYSTEM,    0 },
    { "user.",        AID_SYSTEM,  0 },
    { "media.",           AID_MEDIA,    0 },
    { NULL, 0, 0 }
};

/*
* White list of UID that are allowed to start/stop services.
* Currently there are no user apps that require.
*/
struct {
    const char *service;
    unsigned int uid;
    unsigned int gid;
} control_perms[] = {
    { "dumpstate",AID_SHELL, AID_LOG },
    { "pppd_gprs", AID_RADIO, AID_RADIO },
    { "pppd_gprs2", AID_RADIO, AID_RADIO },
    { NULL, 0, 0 }
};
编译生成
system/lib/libpixelflinger.so
system/bin/test-opengl-codegen
root/init
最后将以上文件更新到设备上

六 更新驱动
adb push dhd.ko /data
adb push fw_bcm4329.bin /data
adb push nvram.txt /data

注意:如果移植后出现设备不能启动,并且log中一直循环打印“NetId1.0......”时,则可以考虑编译环境是否正确,版本是否一致。
比如,你的设备上烧写的是最新的image,kernel等,而你在本地的老版本中更改文件后,编译出的是老版本的bin文件,jar包,
当push到设备中后出现版本不一致,最新版本中很多库文件或者设备的配置环境已经发生改变,造成设备不能正常启动。
分享到:
评论

相关推荐

    MTK+openwrt+wifidog移植

    移植wifidog到MTK Openwrt的第一步是添加wifidog的下载源。由于默认的OpenWrt源码中并未包含wifidog,你需要在`feeds.conf.default`文件中加入wifidog的GitHub仓库链接。这可以通过运行`vim feeds.conf.default`命令...

    T507 AndroidQ WIFI模块移植说明.pdf

    Android Q WIFI 模块移植指南 随着 Android 系统的不断发展和更新,WIFI 模块的移植成为 Android 设备开发中一个非常重要的步骤。T507 Android Q WIFI 模块移植说明文档提供了将 WIFI 模块移植到 Android Q 系统上...

    RealTek wifi 驱动移植说明_V1.0.pdf

    RealTek wifi驱动移植说明文档主要针对Android平台,提供了针对RealTek wifi驱动在Rockchip(RK)平台上的移植方法。文档详细介绍了如何将RealTek的USB和SDIO wifi驱动移植到RK平台上,并针对不同内核版本(如kernel...

    aic8800蓝牙WiFi详细移植文档

    aic8800蓝牙WiFi详细移植文档

    Android HAL USB WIFI 驱动移植详解

    Android HAL USB WIFI 驱动移植详解,都是一些比较常用的USB WIFI包括rtl8192cu ,rtl8192du ,rtl8192ce ,rtl8192de,rtl8723as ,rtl8723au ,rtl8189es ,android WIFI 架构和控制流程详解,理解Android架构从Linux底层...

    全志a33--系统移植--ap6210WiFi模块移植--验证服务器通信.pdf

    根据文件内容,以上是关于全志A33开发板、Linux系统、WiFi模块移植、Ubuntu环境配置、交叉编译、Linux内核、编译器安装和配置、网络限制以及wpa_supplicant的知识点。这些知识点对于进行类似系统移植和开发工作的...

    全志A31平台WIFI移植

    全志A31平台的WIFI移植是指将WIFI模块集成到基于全志A31处理器的Android设备中,以实现无线网络通信的功能。在移植过程中需要处理内核配置、引脚配置、平台配置以及与具体WIFI模组相关的配置和代码修改。 文档主要...

    android13 wifi 移植文档

    在Android 13操作系统中移植Wi-Fi功能是一项复杂而关键的任务,涉及到多个组件和步骤。本文档将详细阐述如何进行这一过程,并提供有关NXP无线芯片组的特定信息。NXP是一家知名的半导体制造商,其产品广泛应用于Wi-Fi...

    基于ubuntu-2.6.35内核的SDIO-WiFi驱动移植

    基于ubuntu-2.6.35内核的SDIO-WiFi驱动移植

    RTL8723BU wifi 移植包

    《RTL8723BU WiFi 移植包详解》 在现代移动设备和物联网(IoT)领域,无线网络连接是不可或缺的一部分。Reltek的RTL8723BU芯片是一款单2.4GHz频段的WiFi模块,同时支持蓝牙功能,广泛应用于各种嵌入式系统和智能硬件...

    Linux WIFI驱动移植教程

    "Linux WIFI驱动移植教程" Linux WIFI驱动移植教程是一篇详细的教程,旨在指导读者如何将 WIFI驱动移植到 Linux 系统上。该教程涵盖了从配置红框内设置到创建 WIFI 连接脚本的整个过程。 知识点1:配置红框内设置...

    WIFI驱动移植

    WIFI驱动移植是一项涉及到硬件驱动层与操作系统层面的复杂工作,它要求开发者对WIFI技术、嵌入式系统编程、以及具体目标平台的硬件和软件架构有深入的理解。下面详细解释标题和描述中所涉及的知识点。 首先,WIFI...

    mini2440 wifi驱动移植 linux-3.1.5

    移植WiFi驱动至mini2440平台的Linux-3.1.5内核是一项挑战性的任务,涉及到内核配置、驱动匹配、文件系统构建等多个环节。通过详细的步骤指导与实践经验分享,本文为后续的开发者提供了宝贵的参考,有助于加速类似...

    rtl8723du WiFi驱动,移植SDK

    标题中的“rtl8723du WiFi驱动,移植SDK”涉及到的是无线网络适配器的驱动程序开发,特别是针对Realtek RTL8723DU这一芯片的。Realtek RTL8723DU是一款常见的2.4GHz单频Wi-Fi芯片,广泛应用于各种嵌入式设备和笔记本...

    基于Linux2.6.21的WIFI移植

    总的来说,移植WIFI驱动到Linux 2.6.21内核是一项技术性强且需要耐心的任务。在实践中,可能会遇到各种问题,如驱动与内核版本不兼容、硬件兼容性问题或编译错误。解决这些问题需要扎实的Linux内核知识和调试技巧。...

    基于arm的wifi移植

    在本文中,我们将深入探讨如何在基于ARM架构的S5PC100处理器上移植WiFi驱动,特别是针对RT73无线网卡的驱动移植。这个过程是嵌入式Linux系统开发中的一个关键环节,使得设备能够连接并使用WiFi网络。以下是一步步的...

    RTL8723BU-WiFi-linux-v4.4.2驱动,wifi移植linux的arm开发板使用

    **原厂wifi驱动---》拷贝到ubuntu---》修改Makefile,使生成ko文件---》编译,生成ko文件---》拷贝到开发板insmod *详解如下: ①下载原厂驱动RTL8723BU_WiFi_linux_v4.4.2_18635_BTCOEX20151228-664a.20161006.zip...

    WiFi驱动移植系列文章汇总

    WiFi驱动移植是一个复杂而关键的过程,特别是在嵌入式系统中,比如使用新唐NUC980系列MCU的设备。以下是对标题和描述中提到的知识点的详细说明: 1. **驱动移植**: - **环境准备**:移植驱动前,需要了解目标硬件...

Global site tag (gtag.js) - Google Analytics