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

摘要

待机功耗中联网目前已知的盲点: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        };    }
相关推荐
希忘auto3 小时前
详解Redis的常用命令
redis·1024程序员节
yaosheng_VALVE19 小时前
探究全金属硬密封蝶阀的奥秘-耀圣控制
运维·eclipse·自动化·pyqt·1024程序员节
dami_king19 小时前
SSH特性|组成|SSH是什么?
运维·ssh·1024程序员节
法迪3 天前
南山区的妈祖庙
功耗
一个通信老学姐6 天前
专业125+总分400+南京理工大学818考研经验南理工电子信息与通信工程,真题,大纲,参考书。
考研·信息与通信·信号处理·1024程序员节
sheng12345678rui6 天前
mfc140.dll文件缺失的修复方法分享,全面分析mfc140.dll的几种解决方法
游戏·电脑·dll文件·dll修复工具·1024程序员节
huipeng9267 天前
第十章 类和对象(二)
java·开发语言·学习·1024程序员节
earthzhang20217 天前
《深入浅出HTTPS》读书笔记(19):密钥
开发语言·网络协议·算法·https·1024程序员节
爱吃生蚝的于勒8 天前
计算机基础 原码反码补码问题
经验分享·笔记·计算机网络·其他·1024程序员节
earthzhang20218 天前
《深入浅出HTTPS》读书笔记(20):口令和PEB算法
开发语言·网络协议·算法·https·1024程序员节