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

摘要

待机功耗中联网目前已知的盲点: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        };    }
相关推荐
DC妙妙屋29 分钟前
10.24.2024刷华为OD C题型(四) -- 对象list按照多个属性排序
1024程序员节
bitenum1 小时前
qsort函数的学习与使用
c语言·开发语言·学习·算法·visualstudio·1024程序员节
EmotionFlying2 小时前
(11)(2.1.6) Hobbywing DroneCAN ESC(一)
copter·ardupilot·1024程序员节·电调和电机
伏飞而行2 小时前
六、元素应用CSS的习题
1024程序员节
idealzouhu2 小时前
Spring Boot 实现文件上传下载功能
java·spring boot·1024程序员节
sudo_Ene3 小时前
Isaac Sim Docker 部署并使用过程记录
笔记·学习·docker·1024程序员节·isaacsim
天使的同类3 小时前
uniapp使用easyinput文本框显示输入的字数和限制的字数
1024程序员节
Elastic 中国社区官方博客4 小时前
GraphQL 与 Elasticsearch 相遇:使用 Hasura DDN 构建可扩展、支持 AI 的应用程序
大数据·后端·elasticsearch·搜索引擎·全文检索·graphql·1024程序员节
·云扬·4 小时前
WeakHashMap详解
java·开发语言·学习·1024程序员节
Dennis_nafla5 小时前
《MYSQL实战45讲》表数据删一半,为什么表文件大小不变?
mysql·1024程序员节