反编译华为-研究功耗联网监控日志

摘要

待机功耗中联网目前已知的盲点:App自己都不知道的push类型的被动联网、app下载场景所需时长、组播联网、路由器打醒AP。

|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 竞品 | 策略 |
| 华为 | 灭屏使用handler定时检测(若灭屏30分钟内则周期1分钟,否则为2分钟),检测应用流量的大小变化(UidTxBytes+UidRxBytes),当检测到应用流量速率大于8kb/s && 非下载场景则计为1次后台联网, 若灭屏检测到联网次数大于30次,则上报联网异常大数据 备注:也是无法知道联网事件的时间和次数分布 |
| xxx公司 | 1.基于AppProcessWakeup进行统计待机唤醒Ap的应用次数, 超过9次上报联网大数据和统计到日志文件中 2.在电池电量变化或待机场景,统计uid对应的数据和wifi流量的上传和下载大小到本地日志文件中 3.WiFi模块:设备休眠时kernel添加监控唤醒AP的联网日志 |

备注:如果是wifi联网可以使用WiFi模块提供的工具分析发生时的时间和次数情况,可以解决上述盲点,但是数据联网就没有单独工具了哈。

源码流程图

// 加载 powergenie_native3.so    static {        NativeAdapter.mNativeAvailabe = true;        try {            System.loadLibrary("powergenie_native3");        }        catch(UnsatisfiedLinkError v0) {            System.err.println("WARNING: Could not load libpowergenie_native3.so");            NativeAdapter.mNativeAvailabe = false;        }    }            /**    *   获取进程上传和下载的流量数据    *  v1.mUidBytes.put(v5_1, Long.valueOf(v14_1));        if(this.isDownloadStateDbg()) {        v1.mUidTxBytes.put(v5_1, Long.valueOf(v68));        v1.mUidRxBytes.put(v5_1, Long.valueOf(v66));        v1.mUidTxPackets.put(v5_1, Long.valueOf(v64));        v1.mUidRxPackets.put(v5_1, Long.valueOf(v62));    }    */    public static long[] updateTrafficStats() {        if(NativeAdapter.mNativeAvailabe) {            return NativeAdapter.nativeUpdateTrafficStats();        }​        return null;    }            /* 流量大于8 kb/s,记一次联网次数 */    public void updateDlUlNetTrafficCount(long j, long j2, int i) {        if (j > 0 && j2 > 0 && i > 0) {            long j3 = (j2 * 1000) / j;            if (j3 >= 8192) {                this.mTotalDlUlTrafficCount += i;                Log.i("AppPowerRecord", this.mAppName + " dl or upload speed: " + j3 + "bytes/s, traffic count:" + i + ", duration:" + (j / 1000));            }        }    }       // type 9 流量次数:3次, 30次,60次   static {        mAppPowerTable = new int[]{40, 20, 4};        mCurrentLevelTable = new int[]{100, 50, 5};        mPowerTypeCurrent = new PowerTypeCurrent();        mPowerLevelTable = new int[][]{                new int[]{POWER_TYPE_ALARM, 3, 12, 40}, // type 1                new int[]{POWER_TYPE_GPS, 10, 300, 600}, // type 2                new int[]{POWER_TYPE_SENSOR, 10, 300, 600}, // type 3                new int[]{POWER_TYPE_WAKELOCK, 10, 300, 600}, // type 4                new int[]{POWER_TYPE_AUTOSTART, 3, 20, 40}, // type 6                new int[]{POWER_TYPE_WIFI_SCAN, 10, 180, 360}, // type 7                new int[]{POWER_TYPE_BT_SCAN, 10, 300, 600}, // type 8                new int[]{POWER_TYPE_NET_TRAFFIC, 3, 30, 60}, // type 9                 new int[]{POWER_TYPE_CPU_HIGH_LOAD, 0, 300, 600}, // type 10                new int[]{POWER_TYPE_BLOCK_SCREEN_TIMEOUT, 0, 180, 600}, // type 11, 超时0秒,超时180秒,,超时600秒                new int[]{POWER_TYPE_NET_LOCATION, 180, 1800, 3600}// type 12        };    }
相关推荐
惜.己9 小时前
Jmeter中的断言(二)
测试工具·jmeter·1024程序员节
西电研梦18 小时前
考研倒计时30天丨和西电一起向前!再向前!
人工智能·考研·1024程序员节·西电·西安电子科技大学
惜.己19 小时前
Jmeter中的断言(四)
测试工具·jmeter·1024程序员节
·云扬·1 天前
Java IO 与 BIO、NIO、AIO 详解
java·开发语言·笔记·学习·nio·1024程序员节
网安_秋刀鱼1 天前
PHP代码审计 --MVC模型开发框架&rce示例
开发语言·web安全·网络安全·php·mvc·1024程序员节
HUODUNYUN2 天前
小程序免备案:快速部署与优化的全攻略
服务器·网络·web安全·小程序·1024程序员节
法迪2 天前
DataWind 查看单个维度的2个版本间数据差异值的方法
功耗
惜.己2 天前
Jmeter的后置处理器(二)
测试工具·github·1024程序员节
惜.己2 天前
Jmeter中的断言(一)
测试工具·jmeter·1024程序员节
cainiao0806052 天前
《物理学进展》
1024程序员节·核心期刊·知网期刊·职称评审