Android 关机/重启原因分析

1、重启log过滤

过滤tag为bootstat的log,中间会有比如:boot reason: shutdown,userrequested的信息,标时上一次设备重启的原因。
详细介绍见https://source.android.google.cn/devices/bootloader/boot-reason

adb shell logcat |findstr "bootstat"
07-05 17:07:08.625   980   980 I bootstat: Service started: /system/bin/bootstat --set_system_boot_reason
07-05 17:07:08.655   980   980 I bootstat: Canonical boot reason: shutdown,userrequested
07-05 17:07:08.655   980   980 I bootstat: Canonical boot reason: shutdown,userrequested
2、mtklog

打开mtklog,复现问题重启后导出。log文件中会有boot__normal文件夹。

3、mtk gat工具

导出/data/vendor/aee_exp和/data/aee_exp下面的log文件。----- dbg文件
使用gat工具解析dbg文件。
gat工具可以在mtk官网下载:https://online.mediatek.com/

4、废话

mtk官网有一些不错的工具和文章。内存和重启问题的分析,多偏向于底层。

5、关机流程

关机流程可以参考以下其它人的文章https://blog.csdn.net/qq_29413633/article/details/120848128

monkey测试关机/重启问题分析(一)
monkey测试关机/重启问题分析(二)
frameworks/base/services/core/java/com/android/server/power/ShutdownThread.java的run方法会打印一些log和保存文件。
可以pull出来这2个文件夹看看
adb pull /data/system/shutdown-checkpoints
adb pull /data/system/shutdown-metrics

    // File to use for saving shutdown metrics
    private static final String METRICS_FILE_BASENAME = "/data/system/shutdown-metrics";
    // File to use for saving shutdown check points
    private static final String CHECK_POINTS_FILE_BASENAME =
            "/data/system/shutdown-checkpoints/checkpoints";

adb shell getprop 打印出系统属性查看boot.reason

[persist.sys.boot.reason.history]: [shutdown,userrequested,1685867693
reboot,factory_reset,1685777074
reboot,23]
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android系统的关机功能是通过多个层面的交互来实现的。首先,从按键触发中断开始,操作系统会将按键事件传递给Android框架层。然后,框架层会将这个事件再次传递回内核层,以执行关机任务。除了按键触发外,还可以通过其他方式触发,比如使用命令行工具reboot或者直接调用PowerManager的reboot()方法。 在具体的代码实现中,可以通过函数fastboot_register("reboot-bootloader", cmd_reboot_bootloader)将到引导加载程序(bootloader)的功能注册到系统中。这样,当执行该命令时,系统就会进入引导加载程序。 关于Android系统的关机功能的具体实现,可以参考Android源代码中的PowerManager.java文件,其中包含了与关机相关的代码。在该文件中,有一个名为PM.reboot的方法,用于实现系统的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Android关机流程](https://blog.csdn.net/mafei852213034/article/details/109818131)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [android 系统关机流程分析](https://blog.csdn.net/vzvzvxz/article/details/7768361)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值