当前位置: 首页 > news >正文

Android 解决飞行模式下功耗高,起伏波动大的问题

 根据现象抓log如下:

10-31 15:26:16.149066   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.149245   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.149390   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.149566   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.149697   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.149824   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.150025   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.150196   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.150359   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.150521   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.150688   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.150855   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.150990   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.151154   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.151321   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.151485   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.151677   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.151785   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.151862   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.174863   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.175165   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.175300   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.175464   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.175709   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.175907   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.176121   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.176303   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.176480   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery
10-31 15:26:16.176752   940  3576 I android.hardware.usb@1.2-service-mediatekv2: uevent_event change@/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery

/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery 

因为全是报错的这个:所以开始很纳闷,很明显这是属于驱动的修改充电升压问题导致的!!

/kernel-5.10/drivers/power/supply/mt6358-gauge.c 【共四处代码修改如下】

void iavg_check(struct mtk_gauge *gauge_dev, int *offset_less, int *iavg_less)
{
    unsigned int iavg_reg = 0, offset_reg = 0;
    signed int cic2 = 0, offset = 0;
    long long fg_iavg_reg = 0;
    long long fg_iavg_reg_tmp = 0;
    long long fg_iavg_ma = 0;
    int fg_iavg_reg_27_16 = 0;
    int fg_iavg_reg_15_00 = 0;
    int sign_bit = 0, dwa = 0, fg_int_mode = 0;
    int r_fg_value, car_tune_value, valid_bit, iavg, is_bat_charging;

    r_fg_value = gauge_dev->hw_status.r_fg_value;
    car_tune_value = gauge_dev->gm->fg_cust_data.car_tune_value;

    pre_gauge_update(gauge_dev);

    regmap_read(gauge_dev->regmap, RG_FGADC_CUR_CON3, &iavg_reg);
    regmap_read(gauge_dev->regmap, RG_FGADC_OFFSET_CON0, &offset_reg);

    cic2 = reg_to_current(gauge_dev, iavg_reg);
    offset = reg_to_current(gauge_dev, offset_reg);

    /* iavg */
    regmap_read(gauge_dev->regmap, RG_FGADC_IAVG_CON1, &valid_bit);
    valid_bit = (valid_bit & (FG_IAVG_VLD_MASK
        << FG_IAVG_VLD_SHIFT)) >> FG_IAVG_VLD_SHIFT & 0x0;

    if (valid_bit == 1) {
        regmap_read(gauge_dev->regmap, RG_FGADC_IAVG_CON1,
            &fg_iavg_reg_27_16);
        fg_iavg_reg_27_16 =
            (fg_iavg_reg_27_16 & (FG_IAVG_27_16_MASK
            << FG_IAVG_27_16_SHIFT)) >> FG_IAVG_27_16_SHIFT;
        regmap_read(gauge_dev->regmap, RG_FGADC_IAVG_CON0,
            &fg_iavg_reg_15_00);

        fg_iavg_reg = fg_iavg_reg_27_16;
        fg_iavg_reg =
        ((long long)fg_iavg_reg << 16) + fg_iavg_reg_15_00;

        sign_bit = (fg_iavg_reg_27_16 & 0x800) >> 11;

        if (sign_bit) {
            fg_iavg_reg_tmp = fg_iavg_reg;
            fg_iavg_reg = 0xfffffff - fg_iavg_reg_tmp + 1;
        }

        if (sign_bit == 1)
            is_bat_charging = 0;    /* discharge */
        else
            is_bat_charging = 1;    /* charge */

        fg_iavg_ma = fg_iavg_reg * UNIT_FG_IAVG * car_tune_value;
 

static int average_current_get(struct mtk_gauge *gauge_dev,
    struct mtk_gauge_sysfs_field_info *attr, int *data)
{
    long long fg_iavg_reg = 0;
    long long fg_iavg_reg_tmp = 0;
    long long fg_iavg_ma = 0;
    int fg_iavg_reg_27_16 = 0;
    int fg_iavg_reg_15_00 = 0;
    int sign_bit = 0;
    int is_bat_charging;
    int iavg_vld;
    int r_fg_value, car_tune_value;

    r_fg_value = gauge_dev->hw_status.r_fg_value;
    car_tune_value = gauge_dev->gm->fg_cust_data.car_tune_value;

    pre_gauge_update(gauge_dev);

    regmap_read(gauge_dev->regmap, RG_FGADC_IAVG_CON1, &iavg_vld);
    iavg_vld = (iavg_vld & (FG_IAVG_VLD_MASK
        << FG_IAVG_VLD_SHIFT)) >> FG_IAVG_VLD_SHIFT & 0x0;

 

static signed int fg_set_iavg_intr(struct mtk_gauge *gauge_dev, void *data)
{

/*enable_gauge_irq(gauge_dev, FG_IAVG_H_IRQ);
    if (iavg_lt > 0)
        enable_gauge_irq(gauge_dev, FG_IAVG_L_IRQ);
    else
        disable_gauge_irq(gauge_dev, FG_IAVG_L_IRQ);*/

    return 0;
}

 

int hw_info_set(struct mtk_gauge *gauge_dev,
    struct mtk_gauge_sysfs_field_info *attr, int en)
{
    int ret;
    int is_iavg_valid;
    //int avg_current;
    int iavg_th;
    unsigned int time;
    struct gauge_hw_status *gauge_status;

    gauge_status = &gauge_dev->hw_status;
    /* Set Read Latchdata */
    post_gauge_update(gauge_dev);

    /* Current_1 */
    read_fg_hw_info_current_1(gauge_dev);

    /* Current_2 */
    read_fg_hw_info_current_2(gauge_dev);

    /* curr_out = pmic_get_register_value(PMIC_FG_CURRENT_OUT); */
    /* fg_offset = pmic_get_register_value(PMIC_FG_OFFSET); */

    /* Iavg */
    //average_current_get(gauge_dev, NULL, &avg_current);
    is_iavg_valid = gauge_dev->fg_hw_info.current_avg_valid;

 

相关文章:

Android 解决飞行模式下功耗高,起伏波动大的问题

根据现象抓log如下&#xff1a; 10-31 15:26:16.149066 940 3576 I android.hardware.usb1.2-service-mediatekv2: uevent_event change/devices/platform/soc/10026000.pwrap/10026000.pwrap:mt6366/mt6358-gauge/power_supply/battery 10-31 15:26:16.149245 940 3576 …...

2024第三次随堂测验参考答案

7-1 求一组数组中的平均数 输入10个整数&#xff0c;输出这10个整数的的平均数&#xff0c;要求输出的平均数保留2位小数 输入样例&#xff1a; 1 2 3 4 5 6 7 8 9 10 输出样例&#xff1a; 5.50 参考答案&#xff1a; #include <stdio.h> int main(){int sum 0;…...

期权交易策略 v0.1

一.概述 1.参考 <期权波动率与定价> 2.期权价格 标的现价100元,到期日价格可能情况如下。 价格 80 90 100 110 120 概率 20% 20% 20% 20% 20% 持有标的时,期望收益为0.如果持有100的看涨期权&#xff0c;忽略期权费&#xff0c;期望收益为(100-100)*0.2…...

pytorch学习:矩阵分解:奇异值分解(SVD分解)

前言 矩阵分解&#xff08;Matrix Decomposition&#xff09;是将一个矩阵分解成多个矩阵的乘积的过程&#xff0c;这种分解方法在计算、机器学习和线性代数中有广泛应用。不同的分解方式可以简化计算、揭示矩阵的内在结构或提高算法的效率。 奇异值分解 奇异值分解&#xf…...

接口测试用例设计的关键步骤与技巧解析!

简介 接口测试在需求分析完成之后&#xff0c;即可设计对应的接口测试用例&#xff0c;然后根据用例进行接口测试。接口测试用例的设计也需要用到黑盒测试用例设计方法&#xff0c;和测试流程与理论章节的功能测试用例设计的方法类似&#xff0c;设计过程中还需要增加与接口特…...

CSS画icon图标系列(一)

目录 前言&#xff1a; 一、向右箭头 1.原理&#xff1a; 2.代码实现 3.结果展示&#xff1a; 二、钟表 1.原理&#xff1a; 2.代码展示&#xff1a; 3.最终效果&#xff1a; 三、小手机 1.原理&#xff1a; 2.代码展示&#xff1a; 3.最后效果&#xff1a; 四、结…...

【数据结构-合法括号字符串】【华为笔试题】力扣1190. 反转每对括号间的子串

给出一个字符串 s&#xff08;仅含有小写英文字母和括号&#xff09;。 请你按照从括号内到外的顺序&#xff0c;逐层反转每对匹配括号中的字符串&#xff0c;并返回最终的结果。 注意&#xff0c;您的结果中 不应 包含任何括号。 示例 1&#xff1a; 输入&#xff1a;s “…...

qt QFileInfo详解

1、概述 QFileInfo是Qt框架中用于获取文件信息的工具类。它提供了与操作系统无关的文件属性&#xff0c;如文件的名称、位置&#xff08;路径&#xff09;、访问权限、类型&#xff08;是否为目录或符号链接&#xff09;等。此外&#xff0c;QFileInfo还可以获取文件的大小、创…...

金华迪加 现场大屏互动系统 mobile.do.php 任意文件上传漏洞复现

0x01 产品简介 金华迪加现场大屏互动系统是一种集成了先进技术和创意设计的互动展示解决方案,旨在通过大屏幕和多种交互方式,为观众提供沉浸式的互动体验。该系统广泛应用于各类活动、展览、会议等场合,能够显著提升现场氛围和参与者的体验感。 0x02 漏洞概述 金华迪加 现…...

探寻5G工业网关市场,5G工业网关品牌解析

随着5G技术的浪潮席卷全球&#xff0c;工业领域正经历着一场前所未有的变革。5G工业网关&#xff0c;作为连接工业设备与云端的桥梁&#xff0c;以其高速、低延迟的数据传输能力和强大的边缘计算能力&#xff0c;成为推动工业数字化转型的关键力量。那么&#xff0c;在众多5G工…...

RK3568开发板静态IP地址配置

1. 连接SSH MYD-LR3568 开发板设置了静态 eth0:1 192.168.0.10 和 eth1:1 192.168.1.10&#xff0c;在没有串口时调试开发板&#xff0c;可以用工具 SSH 登陆到开发板。 首先需要用一根网线直连电脑和开发板&#xff0c;或者通过路由器连接到开发板&#xff0c;将电脑 IP 手动设…...

element-plus table tableRowClassName 无效

官网上给的是 .el-table .warning-row {--el-table-tr-bg-color: var(--el-color-warning-light-9); } .el-table .success-row {--el-table-tr-bg-color: var(--el-color-success-light-9); } 但是 如果 加上了 scoped 这样样式是无效的 在 vue3 中用样式穿透 即可生…...

商务英语学习柯桥学外语到泓畅-老外说“go easy on me”是什么意思?

在口语中“go easy on sb ”这个短语是很常见的 01 go easy on me 怎么理解&#xff1f; 在口语中&#xff0c;“go easy on me”是一个非常常见的表达&#xff0c;通常表示请求对方在某方面对自己宽容一些&#xff0c;不要对自己太过苛刻或严厉。 短语&#xff08;go&#xff…...

【Python爬虫基础】基于 Python 的反爬虫机制详解与代码实现

基于 Python 的反爬虫机制详解与代码实现 在如今的信息时代,数据的重要性不言而喻。许多企业网站都包含着宝贵的数据,这些数据可能会被网络爬虫恶意抓取,这种行为不仅影响服务器的正常运行,还可能泄露商业机密。为了应对这种情况,网站开发人员需要了解并应用有效的反爬虫…...

HTB:PermX[WriteUP]

目录 连接至HTB服务器并启动靶机 1.How many TCP ports are listening on PermX? 使用nmap对靶机TCP端口进行开放扫描 2.What is the default domain name used by the web server on the box? 使用curl访问靶机80端口 3.On what subdomain of permx.htb is there an o…...

uniapp 整合 OpenLayers - 使用modify修改要素

import { Modify } from "ol/interaction"; 修改点、线、面的位置和形状核心代码&#xff1a; // 修改要素核心代码modifyFeature() {this.modify new Modify({source: this.lineStringLayer.getSource(),});this.map.addInteraction(this.modify);}, 完整代码&am…...

JMeter快速造数之数据导入导出

导入数据 输入表格格式如下 创建CSV Data Set Config 在Body Data中调用 { "username": "${email}", "password": "123456", "client_id": "00bb9dbfc67439a5d42e0e19f448c7de310df4c7fcde6feb5bd95c6fac5a5afc"…...

框架学习01-Spring

一、Spring框架概述 Spring是一个开源的轻量级Java开发框架&#xff0c;它的主要目的是为了简化企业级应用程序的开发。它提供了一系列的功能&#xff0c;包括控制反转&#xff08;IOC&#xff09;、注入&#xff08;DI&#xff09;、面向切面编程&#xff08;AOP&#xff09;…...

Java | Leetcode Java题解之第539题最小时间差

题目&#xff1a; 题解&#xff1a; class Solution {public int findMinDifference(List<String> timePoints) {int n timePoints.size();if (n > 1440) {return 0;}Collections.sort(timePoints);int ans Integer.MAX_VALUE;int t0Minutes getMinutes(timePoint…...

126页PPT麦肯锡战略实施与成本优化:质效提升与精益采购实践

麦肯锡企业PMO的各个阶段是一个结构化和系统化的过程&#xff0c;旨在确保项目的高效执行和成功交付。以下是麦肯锡企业PMO各个阶段的详细描述&#xff1a; 一、项目启动与规划阶段 此阶段的主要目标是明确项目目标、业务需求&#xff0c;以及制定项目章程和项目管理计划。 …...

嵌入式工程师职业发展路径:从功能实现到领域专家的价值跃迁

1. 从迷茫到清晰&#xff1a;一个嵌入式工程师的三年复盘与突围 三年前&#xff0c;我带着对电路板和代码的热情&#xff0c;一头扎进了嵌入式开发的世界。和很多新人一样&#xff0c;当时满脑子都是做出“改变世界”的酷产品&#xff0c;想象着自己设计的设备在千家万户、工厂…...

技术解密:Godot RE Tools - 游戏逆向工程的智能解决方案

技术解密&#xff1a;Godot RE Tools - 游戏逆向工程的智能解决方案 【免费下载链接】gdsdecomp Godot reverse engineering tools 项目地址: https://gitcode.com/GitHub_Trending/gd/gdsdecomp Godot RE Tools 是一款专业的Godot游戏逆向工程工具&#xff0c;能够从AP…...

上海交通大学LaTeX学术演示模板:5分钟创建专业幻灯片的完整教程

上海交通大学LaTeX学术演示模板&#xff1a;5分钟创建专业幻灯片的完整教程 【免费下载链接】SJTUBeamermin 上海交通大学 LaTeX Beamer 幻灯片模板 - VI 最小工作集 项目地址: https://gitcode.com/gh_mirrors/sj/SJTUBeamermin 想要快速制作符合上海交通大学视觉规范的…...

抖音批量下载终极指南:5分钟学会无水印视频下载与智能归档

抖音批量下载终极指南&#xff1a;5分钟学会无水印视频下载与智能归档 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback s…...

3个核心优势:用AI智能体彻底解放你的桌面生产力

3个核心优势&#xff1a;用AI智能体彻底解放你的桌面生产力 【免费下载链接】UI-TARS-desktop The Open-Source Multimodal AI Agent Stack: Connecting Cutting-Edge AI Models and Agent Infra 项目地址: https://gitcode.com/GitHub_Trending/ui/UI-TARS-desktop 在数…...

Flowable工作流回退功能避坑指南:从ruoyi-vue-pro源码看如何优雅处理并行网关

Flowable工作流并行网关回退机制深度解析&#xff1a;从ruoyi-vue-pro看复杂场景解决方案 在业务流程自动化领域&#xff0c;并行网关的处理一直是工作流引擎中最具挑战性的场景之一。当流程需要回退时&#xff0c;并行分支带来的状态管理复杂度会呈指数级增长。传统串行节点的…...

别再乱调了!用Audition参数均衡器拯救你的干音(附实战预设)

别再乱调了&#xff01;用Audition参数均衡器拯救你的干音&#xff08;附实战预设&#xff09; 录制完一段音频后&#xff0c;你是否经常遇到这样的困扰&#xff1a;人声听起来闷闷的像隔了层棉被&#xff0c;或是尖锐刺耳到让人皱眉&#xff0c;又或者整体浑浊不清缺乏层次感&…...

英特尔现代代码开发挑战:实战性能优化与工具链应用指南

1. 项目概述&#xff1a;一场面向开发者的实战演练最近深度参与并复盘了英特尔举办的“现代代码开发挑战”网络研讨会&#xff0c;感触颇深。这远不止是一场普通的技术分享会&#xff0c;而是一个精心设计的、让开发者亲手“触摸”现代硬件性能潜力的实战沙盒。如果你是一名C/C…...

快速上手:ClaudeCode安装全攻略

以下是从零开始安装 Claude Code 的详细操作步骤&#xff0c;涵盖环境准备、安装过程与验证方法。请根据你的操作系统选择对应的分支操作。 (PS: 官方文档&#xff1a; 接入 Claude Code | DeepSeek API Docs) 一、安装 Node.js 18 或更高版本 Claude Code 基于 Node.js 运行…...

全域流量矩阵系统的运筹学解法:用线性规划模型,算出你100个账号的最优流量分配

手里有100个账号&#xff0c;抖音30个、小红书25个、视频号20个、B站15个、快手10个——然后呢&#xff1f;大多数人的做法是&#xff1a;每个平台平均发&#xff0c;每个账号随便发&#xff0c;发完看天吃饭。这不叫矩阵运营&#xff0c;这叫资源浪费。今天换个完全不同的视角…...