高通平台android怎么过去开机时间

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高通平台android怎么过去开机时间相关的知识,希望对你有一定的参考价值。

参考技术A

(1) android是基于Linux内核的系统,因此Android的启动过程是分为两个阶段的:

第一个阶段就是Linux内核的启动

第二个阶段就是Android框架的启动(包括核心服务和程序)。

(2)Android的log系统是独立于Linux内核的log系统的。

Linux内核通过printk打印的log信息,这些log写入到了/dev/kmsg文件中,在Shell终端可以通过dmesg命令查看这些log信息。 

Android框架则是通过Logger驱动打印log信息,这些log并没有归并到kmesg文件中,而是单独存储的,位于/dev/log目录下,在Shell终端可以通过logcat命令来查看。

下面我们分别从两种log信息中找到如何统计系统启动时间的方法。

1.  通过dmesg信息统计Linux内核启动时间

首先,我们通过dmesg命令抓取Linux内核的log信息(部分系统可能需要先执行 adb root):

$ adb shell dmesg > dmesg.txt

Linux内核启动完成,一般都有如下的标准输出信息:

<6> [ 6.613861] Freeing init memory: 176K

因此,只要我们在dmesg.txt文件中找到“Freeing init memory”这一行即可,从上面的log可以看出,Linux内核启动只用了6.613861s。

那么,如何找到Android系统启动完成的标志呢?

很多Android设备在系统启动完成后,会在内核log中打印如下信息:

<6>[ 29.913726] init: processing action 0x96bb8 (property:sys.boot_completed=1)

因此,找到“boot_completed”这一行也就得到了整个系统的启动时间了,从这一行可以看出,整个系统启动用了29.913726s。

当然,并不是所有的Android设备都会打印出这条log,因此,我们一般用下面介绍的方法来专门统计Android系统的启动时间,

2.  通过logcat统计Android Logger启动时间

文章开头我们已经介绍过,Android的log系统是独立于Linux内核log系统的,通过在终端输入adb shell 进入Android系统,cd到/dev/log目录,你会发现里面有四个文件,分别是:events,main,radio,system.

Android系统把Log分为了四类,不同的类别记录不同的Log信息:

main - 主要的Log信息,大部分应用级别的Log信息都在这里

events - 系统事件相关的Log信息

radio   - 无线/电话相关的Log信息

system - 低级别的系统调试Log信息

默认通过logcat抓取的是main信息,如果想抓取指定类别的log信息的方法,在logcat命令后加-b参数,例如:

1234

$ adb logcat -d -v time -b "main"   >  main.txt$ adb logcat -d -v time -b "events" >  events.txt$ adb logcat -d -v time -b "system" >  system.txt$ adb logcat -d -v time -b "radio"  >  radio.txt

关于Android Log系统的分类,你可以访问如下页面详细了解: 《Android Logging System》

那么,如何统计Android系统的启动时间呢?

我们可以重点关注events类别的log信息,通过如下命令:

$ adb logcat -v time -d -b events | grep "boot"

如图所示,这是我在高通的APQ8064开发板上抓取的log信息:

“boot_progress_start”代表着Android屏幕点亮,开始显示启动动画,即15.492s开始闪烁Android字样。

“boot_progress_enable_screen”代表着整个系统启动结束,即用了29.986s,用这个总时间减去Linux Kernel的启动时间即可得到Android OS部分的时间。

3.  小结

由于本文重点关注如何统计Android系统的启动时间,因此,很多启动log文件的分析就不做详细展开了,下一篇文章将会对系统启动的log做稍微详细的分析。有任何疑问或者建议欢迎留言或者来信lujun.hust@gmail.com交流,或者关注我的新浪微博 @卢_俊 获取最新的文章和资讯。

参考技术B 应该要root后在data分区找吧

Android系统之Mtk开机logo镜像单独制作(不用全编译代码)

一.问题背景

在我们客制系统版本时,经常有时候会有需求就是单独更新一个客制logo,如果每次仅仅就是更改一个开机logo,我们每次都需要有一个完整编译的out,也就意味着可能要全编,这想必是非常低效率的,
了解高通平台的人知道,高通的开机logo由单独的 splash.img 分区 包含,且高通有非常便利的python脚本可以直接将一张png格式的开机logo图片转换成splash.img,以达成不用编译代码,直接替换 splash.img分区即可完成开机logo替换的客制版本,这可所谓真香,
但是MTK平台就没那么香了,他们没有专门的脚本去制作,每次都需要单独去替换开机logo图片,所以特别麻烦,低效率
那么对于MTK平台,是否也有办法,不进行全编,答案肯定是有滴,我们这篇文章的目的就是这个。

二.MTK 通过编译代码去定制客制开机logo版本

在讲解如何单独制作开机logo之前,我们有必要先简单了解一下如何通过编译代码的形式去定制客制logo,因为这有利于我们了解后续单独制作开机logo的分析和原理。

定位到 源码的如下目录:
vendor/mediatek/proprietary/bootable/bootloader/lk/dev/logo
可以看到mtk开机logo都在这个目录,但是这个目录有太多文件夹,如何确定当前的代码是使

以上是关于高通平台android怎么过去开机时间的主要内容,如果未能解决你的问题,请参考以下文章

Android系统之Mtk开机logo镜像单独制作(不用全编译代码)

高通方案的Android设备几种开机模式的进入与退出

android文件系统挂载分析---正常开机挂载

高通平台LCD调试

tiny4412开机动画开机界面的定制 原创

高通平台抓取ramdump文件