美文网首页
Android SoftAP 实现框架

Android SoftAP 实现框架

作者: 仲秋雨路 | 来源:发表于2017-06-14 19:55 被阅读1362次

    文章概要

    1. SoftAP 简介
    2. 功能模块与框架图
    3. 设备启动与管理
    4. 网络共享功能的实现
    5. SoftAP 运行时序图

    SoftAP 简介

    无线AP(AP,Access Point,无线访问节点、会话点或存取桥接器)是一个包含很广的名称,它不仅包含单纯性无线接入点(无线AP),也同样是无线路由器(含无线网关、无线网桥)等类设备的统称。
    单纯性无线接入点就是一个无线的交换机,提供无线信号发射接收的功能,不具备路由功能(包括DNS、DHCP、Firewall等)

    从Android 2.2 开始支持SoftAp 功能(也称为Wifi Tethering ),是指将手机作为无线AP, 其他便携式设备可以通过802.11 协议与其互联, 并通过Tethering 技术实现网络Internet 共享等功能。
    所以,Android 实现的SoftAp 是包含了路由功能的无线接入点,提供类似无线路由器的功能。

    功能模块与框架图

    Android 提供的无线AP功能,可以划分为与设备和路由功能两部分。
    其中设备相关部分包括,启动,关闭,鉴权功能等;
    路由相关的功能,包括DHCP,DNS 配置,网络数据路由转发等,是在路由表中通过地址转换技术(NAT)实现。

    框架图

    SoftAP 在Android 实现框架

    代码实现

    APP:
    app\Settings\src\com\android\settings\ TetherSettings.java 设置SoftAp 界面
    app\Settings\src\com\android\settings\wifi\ WifiApEnabler.java
    Framework Layer :
    frameworks\base\services\java\com\android\server\connectivity\Tethering.java
    frameworks\base\services\java\com\android\server\ConnectivityService.java
    frameworks\base\services\java\com\android\server \NetworkManagementService.java 网络管理服务
    Local User Space demon:
    Netd 守护进程: 管理网络设备接口,流量控制,softap, Tethering等
    system\netd
    hostapd 进程:由netd 进程启动的子进程,用来管理softap;
    external\wpa_supplicant_8\hostapd
    dnsmasq 进程:用来配置dns forward, dhcp 等功能
    external\dnsmasq
    iptables 进程:路由表管理,实现NAT 等功能;
    external\iptables

    设备启动与管理

    SoftAP 在硬件上实现依赖于Wifi 芯片,当前的wifi 芯片厂商大都不支持wifi 和 SoftAp 共存;
    开启Soft ap功能在Settings程序的WifiApEnabler. onPreferenceChange里, 设置soft ap在WifiApDialog.onClick里。它们依赖WifiManager的如下接口:

    void setWifiApEnabled(in WifiConfiguration wifiConfig, boolean enable);
    int getWifiApEnabledState();
    WifiConfiguration getWifiApConfiguration();
    void setWifiApConfiguration(in WifiConfiguration wifiConfig);

    WifiManager调用WifiService实现的功能, WifiService最终调用NetworkManagementService.startAccessPoint函数, 如下:
    public void stopAccessPoint(String wlanIface) throws IllegalStateException {
    mContext.enforceCallingOrSelfPermission(
    android.Manifest.permission.CHANGE_NETWORK_STATE, "NetworkManagementService");
    mContext.enforceCallingOrSelfPermission(
    android.Manifest.permission.CHANGE_WIFI_STATE, "NetworkManagementService");
    try {
    mConnector.doCommand("softap stopap");
    mConnector.doCommand("softap stop " + wlanIface);
    wifiFirmwareReload(wlanIface, "STA");
    } catch (NativeDaemonConnectorException e) {
    throw new IllegalStateException("Error communicating to native daemon to stop soft AP",
    e);
    }
    }

    NetworkManagementService顾名思义是Android系统的网络管理服务, 负责比较特殊的网络的设置(比如网络共享(Tether)和网络地址转换(Nat)和ip 转发(ip forwording))和向上层通知网络相关的事件。mConnector是一个NativeDaemonConnector, 这里用来和系统的netd守护进程通信。NetworkManagementService的好多功能都是通过Netd实现的。 Netd的代码在“android sources”/system/netd里。Netd中softap控制的功能在“android sources”/system/netd/SoftapController.{h,cpp}里, 是通过wireless extention定义的SIOCGIWPRIV来调用网卡驱动的ap功能。 如果具体网卡驱动提供的soft ap接口不同, SoftapController的代码就需要改。比如T810T的驱动厂家提供了hostapd来控制ap, 就需要改SoftapController来适配hostapd提供的接口(参见: SoftapController.cpp 中宏开关HAVE_HOSTAPD)。

    Netd 进程中监听netd socket 并接收从NetworkManagementService 发送的指令,解析之后,执行start hostapd 的动作,启动softap 驱动模式并且配置参数。
    int SoftapController::startSoftap() {
    ….
    ifdef HAVE_HOSTAPD
    ensure_entropy_file_exists();
    if (execl("/system/bin/hostapd", "/system/bin/hostapd",
    "-e", WIFI_ENTROPY_FILE,
    HOSTAPD_CONF_FILE, (char *) NULL)) {
    LOGE("execl failed (%s)", strerror(errno));
    }
    endif
    ….
    }

    启动之后,Wlan0 的设备启动,并且被当作network device , 并向系统发送设备启动成功的消息,便于后续路由配置等工作继续。

    网络共享功能的实现

    com.android.server.connectivity.Tethering类向NetworkManagementService(NetworkManagementService通过netd来监听, netd用netlink socket监听内核热插拔事件)类注册了一个Observer来监听Interface的add, remove, change的信息。 当使能soft ap时, 会以soft ap模式加载驱动, 此时驱动会发出热插拔事件。 Tethering类里面跑了两种状态机, 一个TetherMasterSM, 和n个TetherInterfaceSM(每个tetherable interface对应一个)。 添加Interface时就会启动一个TetherInterfaceSM状态机, 并进入Initial状态, 发出ConnectivityManager.ACTION_TETHER_STATE_CHANGED广播。 WifiService收到广播后调用ConnectivityService.tethering(inf)函数, 给TetherInterfaceSM发送CMD_TETHER_REQUESTED命令, 进入tethered状态。

    当UpstreamIface(比如现在共享3g网络)发生变化时, TetherMasterSM会通知所有TetherInterfaceSM改变nat。
    TetherMasterSM初始阶段UpstreamIface的选择是根据从NetworkManagementServicem获得所有Ingerface,能匹配上com.android.internal.R.array.config_tether_upstream_regexs(在base.core.res.res.values.configs中定义, 原始为空需要根据实际情况来改)的第一个状态为up的interface即被选为UpstreamIface。

    运行时UpstreamIface也可能变化, Tethering类监听ConnectivityManager.CONNECTIVITY_ACTION事件(当网络连接变化时由ConnectivityService发出), 当收到时给TetherMasterSM发TetherMasterSM.CMD_UPSTREAM_CHANGED消息。 TetherMasterSM收到后重新选择UpstreamIface,并向所有TetherInterfaceSM发送TetherInterfaceSM.CMD_TETHER_CONNECTION_CHANGED事件来用新的UpstreamIface重启Nat。

    Tethering原理如下:
    NetworkManagementService.setIpForwardingEnabled(true)
    NetworkManagementService.startTethering(mDhcpRange)// 启动dnsmasq(负责dhcp和dns forwarding)
    NetworkManagementService. setDnsForwarders(mDnsServers)//通过给dnsmasq发命令来设置dns服务器
    NetworkManagementService.enableNat(String internalInterface, String externalInterface)//启动nat(网络地址转换)

    SoftAP 运行时序图

    SoftAP 动态时序图

    相关文章

      网友评论

          本文标题:Android SoftAP 实现框架

          本文链接:https://www.haomeiwen.com/subject/oqleqxtx.html