本文转载自:http://blog.csdn.net/tankai19880619/article/details/42972551

一、现象

12小时压测wifi连接后,发现网络连接中断;相关log:

我们关心状态变化部分ConnectivityService: ConnectivityChange for WIFI

  1. 01-19-17:42;0501-01 08:00:38.552   954  1117 D ConnectivityService: --NetworkStateTracker.EVENT_STATE_CHANGED handle--
  2. 01-19-17:42;0501-01 08:00:38.552   954  1117 D ConnectivityService: ConnectivityChange for WIFI: CONNECTED/CONNECTED
  3. 01-19-17:42;0501-01 08:00:38.552   954  1117 D ConnectivityService: Setting TCP values: [524288,1048576,2097152,262144,524288,1048576] which comes from [net.tcp.buffersize.wifi]
  4. /////////////////////////////////////////////////////////////////////////////////////////////////////12hago
  5. 01-20-05:14;2201-01 19:33:18.943  1267  1386 V shizx   : @@@clienttype:@@@TCL-CN-MT55CD-F3700A-LG
  6. 01-20-05:14;22ERROR!!! MlmeEnqueueForRecv: un-recongnized mgmt->subtype=15
  7. 01-20-05:14;2301-01 19:33:19.572   954  1808 E Dhinit:
  8. 01-20-05:14;23 waitpid returned pid 1835, status = 00000009
  9. 01-20-05:14;23cpStateMacinit: process 'dhcpcd_wlan0', pid 1835 exited
  10. 01-20-05:14;23hine: DHCP failed on wlan0: Timed out waiting for DHCP Renew to finish
  11. 01-20-05:14;2301-01 19:33:19.574   954  1808 D DHCP    : ifc_init, return = 0
  12. 01-20-05:14;2301-01 19:33:19.574   954  1808 D DHCP    : ifc_set_addr(wlan0, xx) = 0
  13. 01-20-05:14;2301-01 19:33:19.574   954  1808 D DHCP    : ifc_close
  14. 01-20-05:14;2301-01 19:33:19.779   954  1115 D WifiHW  : send cmd is DRIVER POWERMODE 0
  15. 01-20-05:14;2301-01 19:33:19.779   954  1115 D WifiHW  : send cmd is DRIVER BTCOEXMODE 2
  16. 01-20-05:14;2301-01 19:33:19.781   954  1115 E WifiStateMachine: IP configuration failed
  17. 01-20-05:14;2301-01 19:33:19.781   954  1115 D WifiHW  : send cmd is DISCONNECT
  18. 01-20-05:14;2301-01 19:33:19.782  1558  1558 D wpa_supplicant: wpa_driver_wext_deauthenticate
  19. 01-20-05:14;2301-01 19:33:19.789  1558  1558 D wpa_supplicant: wpa_driver_wext_set_key: alg=0 key_idx=0 set_tx=0 seq_len=0 key_len=0
  20. 01-20-05:14;2301-01 19:33:19.790  1558  1558 D wpa_supplicant: wpa_driver_wext_set_key: alg=0 key_idx=1 set_tx=0 seq_len=0 key_len=0
  21. 01-20-05:14;2301-01 19:33:19.790   954  1110 D NetdConnector: RCV <- {600 Iface linkstate wlan0 up}
  22. 01-20-05:14;2301-01 19:33:19.793  1558  1558 D wpa_supplicant: wpa_driver_wext_set_key: alg=0 key_idx=2 set_tx=0 seq_len=0 key_len=0
  23. 01-20-05:14;2301-01 19:33:19.793  1558  1558 D wpa_supplicant: wpa_driver_wext_set_key: alg=0 key_idx=3 set_tx=0 seq_len=0 key_len=0
  24. 01-20-05:14;2301-01 19:33:19.794  1558  1558 D wpa_supplicant: wpa_driver_wext_set_key: alg=0 key_idx=0 set_tx=0 seq_len=0 key_len=0
  25. 01-20-05:14;2301-01 19:33:19.795  1558  1558 D wpa_supplicant: wpa_driver_wext_set_operstate: operstate 1->0 (DORMANT)
  26. 01-20-05:14;2301-01 19:33:19.795  1558  1558 D wpa_supplicant: netlinkinit:
  27. 01-20-05:14;23 waitpid returned pid 1126, status = 00000009
  28. 01-20-05:14;23init: process 'dhcpcd_eth0', pid 1126 exited
  29. 01-20-05:14;23: Operstate: linkmode=-1, operstate=5

二、分析

关键部分:

  1. DhcpStateMachine: DHCP failed on wlan0: Timed out waiting for DHCP Renew to finish
  2. init: waitpid returned pid 1835, status = 00000009
  3. init: process 'dhcpcd_wlan0', pid 1835 exited

1.frameworks/base/core/java/android/net/DhcpStateMachine.java

  1. private boolean runDhcp(DhcpAction dhcpAction) {
  2. if (dhcpAction == DhcpAction.START) {
  3. if (DBG) Log.d(TAG, "DHCP request on " + mInterfaceName);
  4. success = NetworkUtils.runDhcp(mInterfaceName, dhcpInfoInternal);
  5. mDhcpInfo = dhcpInfoInternal;
  6. } else if (dhcpAction == DhcpAction.RENEW) {
  7. if (DBG) Log.d(TAG, "DHCP renewal on " + mInterfaceName);
  8. success = NetworkUtils.runDhcpRenew(mInterfaceName, dhcpInfoInternal); //f分析该函数
  9. dhcpInfoInternal.updateFromDhcpRequest(mDhcpInfo);
  10. }
  11. if (success) {
  12. ......
  13. } else {
  14. //这里就是打印:DhcpStateMachine: DHCP failed on wlan0: Timed out waiting for DHCP Renew to finish
  15. Log.e(TAG, "DHCP failed on " + mInterfaceName + ": " +
  16. NetworkUtils.getDhcpError());
  17. NetworkUtils.stopDhcp(mInterfaceName);
  18. mController.obtainMessage(CMD_POST_DHCP_ACTION, DHCP_FAILURE, 0)
  19. .sendToTarget();
  20. }
  21. return success;
  22. }

2.frameworks/base/core/java/android/net/NetworkUtils.java

  1. public native static boolean runDhcpRenew(String interfaceName, DhcpInfoInternal ipInfo);

3.frameworks/base/core/jni/android_net_NetUtils.cpp

  1. static jboolean android_net_utils_runDhcpRenew(JNIEnv* env, jobject clazz, jstring ifname, jobject info)
  2. {
  3. return android_net_utils_runDhcpCommon(env, clazz, ifname, info, true);
  4. }
  5. static jboolean android_net_utils_runDhcpCommon(JNIEnv* env, jobject clazz, jstring ifname,
  6. jobject info, bool renew)
  7. {
  8. if (renew) {
  9. result = ::dhcp_do_request_renew(nameStr, ipaddr, gateway, &prefixLength,
  10. dns1, dns2, server, &lease, vendorInfo);
  11. }
  12. }

4.system/core/libnetutils/dhcp_utils.c

  1. int dhcp_do_request_renew(const char *interface,
  2. char *ipaddr,
  3. char *gateway,
  4. uint32_t *prefixLength,
  5. char *dns[],
  6. char *server,
  7. uint32_t *lease,
  8. char *vendorInfo,
  9. char *domain,
  10. char *mtu)
  11. {
  12. if (wait_for_property(result_prop_name, NULL, 30) < 0) {
  13. snprintf(errmsg, sizeof(errmsg), "%s", "Timed out waiting for DHCP Renew to finish"); //这是最关键的错误部分
  14. return -1;
  15. }
  16. }
  17. static int wait_for_property(const char *name, const char *desired_value, int maxwait)
  18. {
  19. char value[PROPERTY_VALUE_MAX] = {'\0'};
  20. int maxnaps = (maxwait * 1000) / NAP_TIME;
  21. if (maxnaps < 1) {
  22. maxnaps = 1;
  23. }
  24. //add by tank
  25. //  add for MStar Android Patch Begin
  26. maxnaps = maxnaps + 1;
  27. usleep(50*1000);
  28. //  add for MStar Android Patch End
  29. //end tank
  30. while (maxnaps-- > 0) {
  31. usleep(NAP_TIME * 1000);
  32. if (property_get(name, value, NULL)) {
  33. if (desired_value == NULL ||
  34. strcmp(value, desired_value) == 0) {
  35. return 0;
  36. }
  37. }
  38. //add by tank@
  39. //  add for MStar Android Patch Begin
  40. usleep(NAP_TIME * 1000);
  41. //  add for MStar Android Patch End
  42. //end tank
  43. }
  44. return -1; /* failure */
  45. }

三、解决

合入上处4中add by tank后问题解决。

其他问题,mac地址冲突导致重启后无法获取IP。

    1. D/NetdConnector(  958): RCV <- {213 5c:36:b8:4d:ab:7a 0.0.0.0 0 [up broadcast multicast]}
    2. D/NetdConnector(  958): RSP <- {213 5c:36:b8:4d:ab:7a 0.0.0.0 0 [up broadcast multicast]}
    3. D/NetworkManagementService(  958): rsp <213 5c:36:b8:4d:ab:7a 0.0.0.0 0 [up broadcast multicast]>
    4. D/NetworkManagementService(  958): flags <[up broadcast multicast]>
    5. D/NetworkManagementService(  958): Registering observer
    6. I/EthernetStateTracker(  958): reset device eth0
    7. D/NetUtils(  958): android_net_utils_resetConnections in env=0x7d6950 clazz=0xad200001 iface=eth0 mask=0x3
    8. D/DHCP    (  958): ifc_init, return = 0
    9. D/DHCP    (  958): ifc_close
    10. D/DHCP    (  958): ifc_init, return = 0
    11. D/DHCP    (  958): ifc_up(eth0) = 0
    12. D/DHCP    (  958): ifc_close
    13. D/DHCP    (  958): ifc_init, return = 0
    14. D/DHCP    (  958): ifc_close
    15. D/DHCP    (  958): ifc_init, return = 0
    16. D/DHCP    (  958): ifc_close
    17. D/dhcp    ( 1124): enter dhcpcd service
    18. D/dhcp    ( 1124): enter dhcpcd service add options
    19. D/dhcp    ( 1124): enter dhcpcd service leave option
    20. D/dhcp    ( 1124): enter dhcpcd service chdir
    21. D/dhcp    ( 1124): enter dhcpcd service dump
    22. D/dhcp    ( 1124): enter dhcpcd service master
    23. E/dhcp    ( 1124): version 5.2.10 starting
    24. D/DHCP    ( 1124): ifc_init, return = 0
    25. D/DHCP    ( 1124): ifc_close
    26. F/dhcp    ( 1124): eth0: using hwaddr 5c:36:b8:4d:ab:7a
    27. F/dhcp    ( 1124): eth0: executing `/system/etc/dhcpcd/dhcpcd-run-hooks', reason PREINIT
    28. I/dhcp    ( 1124): host does not support a monotonic clock - timing can skew
    29. F/dhcp    ( 1124): eth0: reading lease `/data/misc/dhcp/dhcpcd-eth0.lease'
    30. E/dhcp    ( 1124): eth0: broadcasting for a lease
    31. F/dhcp    ( 1124): eth0: sending DISCOVER (xid 0xd92bbde3), next in 3.54 seconds

Android系统DHCP问题【转】的更多相关文章

  1. 深入浅出 - Android系统移植与平台开发(五)- 编译Android源码(转)

    2.3编译Android源码 Android源码体积非常庞大,由Dalvik虚拟机.Linux内核.编译系统.框架代码.Android定制C库.测试套件.系统应用程序等部分组成,在编译Android源 ...

  2. Android系统在超级终端下必会的命令大全(adb shell命令大全)

    . 显示系统中全部Android平台: android list targets . 显示系统中全部AVD(模拟器): android list avd . 创建AVD(模拟器): android c ...

  3. [总结]Android系统体系结构

    Android 从图中可以看出Android主要的组成部分,其中底层是Linux的内核,包括的主要就是文件.内存.系统资源等的管理,Google在这部分的工作主要就是电源管理和一部分驱动,并且整合上层 ...

  4. 【Android 系统开发】 编译 Android文件系统 u-boot 内核 并烧写到 OK-6410A 开发板上

    博客地址 : http://blog.csdn.net/shulianghan/article/details/40299813  本篇文章中用到的工具源码下载 : -- ok-6410A 附带的 A ...

  5. (转)android系统架构及源码目录结构

    转自:http://blog.csdn.net/finewind/article/details/46324507 1. Android系统架构: android系统架构采用了分层架构的思想,如下图所 ...

  6. Android 系统属性-SystemProperties详解***

    创建与修改android属性用Systemproperties.set(name, value),获取android属性用Systemproperties.get(name),需要注意的是androi ...

  7. 最新Android系统版本与API等级对应关系表

    最新Android系统版本与API等级对应关系表 从Android官网拷过来的,方便查阅... 官网地址:https://developer.android.com/guide/topics/mani ...

  8. Android系统全貌 (转)

    转自Gityuan的Android开篇,对自我学习作进一步整理. Android系统以Linux内核作为基底,上层采用Native层和Java层.系统分为内核空间和用户空间,并通过系统调用(Sysca ...

  9. android系统release签名

    转自:http://blog.csdn.net/yangkai6121/article/details/38682321 为什么需要给Android系统签个名才能进行CTS认证呢?原来我们通过make ...

随机推荐

  1. Javascript 限制文本字节数

    文本限制字数的问题,在实际开发中经常用到;主要问题出现在对中文的限制,下面代码就解决关于限制字节数的校验问题 以下是引用片段: /* value: 值: byteLength:数据库字节长度 titl ...

  2. 洛谷——P1144 最短路计数

    P1144 最短路计数 题目描述 给出一个N个顶点M条边的无向无权图,顶点编号为1-N.问从顶点1开始,到其他每个点的最短路有几条. 输入输出格式 输入格式: 输入第一行包含2个正整数N,M,为图的顶 ...

  3. Maven的构建配置文件(Build Profiles)

    在命令行使用构建配置文件时,是-P,比如:mvn -Pinput 注意:这里的构建配置文件并不是一个真正的文件,而是通过指定参数来做特定的事. 以下内容引用自https://ayayui.gitboo ...

  4. MySQL常用SQL整理

    MySQL常用SQL整理 一.DDL #创建数据库 CREATE DATABASE IF NOT EXISTS product DEFAULT CHARSET utf8 COLLATE utf8_ge ...

  5. [Algorithm] Write a Depth First Search Algorithm for Graphs in JavaScript

    Depth first search is a graph search algorithm that starts at one node and uses recursion to travel ...

  6. NYOJ 38 布线问题_(解法1 Kruskal算法)

    时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描写叙述 南阳理工学院要进行用电线路改造.如今校长要求设计师设计出一种布线方式,该布线方式须要满足下面条件: 1.把全部的楼都供 ...

  7. FFmpeg for ios架构:中级

    FFmpeg这部分想了非常久,也没找到比較好的解说方式.本来想像其他博客一样.对着代码一行行的分析.但后来感觉不太现实,FFmpeg应用在IOS上怎么说代码最少也有个5.6k行(包含音视频.业务逻辑) ...

  8. jquery easyui 全部图标

    所有的图标在 jquery-easyui-1.2.6\themes\icons 目录下, 在icon.css定义的如何引用 jquery-easyui-1.2.6/themes/icon.css .i ...

  9. mysqldump导入导出详解

    mysqldump可以指定路径的,如果没指定路径,而只写了文件名的话,那么就在当前进入mysql命令行所在的目录,也就是mysql安装目录下 mysqldump  --default-characte ...

  10. JavaScript的string方法(demo)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...