安卓开机启动阶段

ops/2024/10/15 18:50:35/

目录

  • 概述
  • 一、boot_progress_start
  • 二、boot_progress_preload_start
  • 三、boot_progress_preload_end
  • 四、boot_progress_system_run
  • 五、boot_progress_pms_start
  • 六、boot_progress_pms_system_scan_start
  • 七、boot_progress_pms_data_scan_start
  • 八、boot_progress_pms_scan_end
  • 九、boot_progress_pms_ready
  • 十、boot_progress_ams_ready
  • 十一、boot_progress_enable_screen
  • 十二、sf_stop_bootanim
  • 十三、wm_boot_animation_done
  • 整体框架


概述

开机阶段描述

阶段描述
boot_progress_start系统进入用户空间,标志着kernel启动完成
boot_progress_preload_startZygote启动
boot_progress_preload_endZygote结束
boot_progress_system_runSystemServer ready,开始启动Android系统服务,如PMS,APMS等
boot_progress_pms_startPMS开始扫描安装的应用
boot_progress_pms_system_scan_startPMS先行扫描/system目录下的安装包
boot_progress_pms_data_scan_startPMS扫描/data目录下的安装包
boot_progress_pms_scan_endPMS扫描结束
boot_progress_pms_readyPMS就绪
boot_progress_ams_readyAMS就绪
boot_progress_enable_screenAMS启动完成后开始激活屏幕,从此以后屏幕才能响应用户的触摸,它在WindowManagerService发出退出开机动画的时间节点之前,而真正退出开机动画还会花费少许时间,具体依赖animation zip 包中的desc.txt。wm_boot_animation_done才是用户感知到的动画结束时间节点
sf_stop_bootanimSF设置service.bootanim.exit属性值为1,标志系统要结束开机动画了,可以用来跟踪开机动画结尾部分消耗的时间
wm_boot_animation_done开机动画结束,这一步用户能直观感受到开机结束

一、boot_progress_start

frameworks/base/core/jni/AndroidRuntime.cpp

void AndroidRuntime::start(const char* className, const Vector<String8>& options, bool zygote)
{.../** 'startSystemServer == true' means runtime is obsolete and not run from* init.rc anymore, so we print out the boot start event here.*/for (size_t i = 0; i < options.size(); ++i) {if (options[i] == startSystemServer) {primary_zygote = true;/* track our progress through the boot sequence */const int LOG_BOOT_PROGRESS_START = 3000;LOG_EVENT_LONG(LOG_BOOT_PROGRESS_START,  ns2ms(systemTime(SYSTEM_TIME_MONOTONIC)));}}...
}

二、boot_progress_preload_start


三、boot_progress_preload_end


四、boot_progress_system_run

frameworks/base/services/java/com/android/server/SystemServer.java

    private void run() {...// Here we go!Slog.i(TAG, "Entered the Android system server!");final long uptimeMillis = SystemClock.elapsedRealtime();EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_SYSTEM_RUN, uptimeMillis);if (!mRuntimeRestart) {FrameworkStatsLog.write(FrameworkStatsLog.BOOT_TIME_EVENT_ELAPSED_TIME_REPORTED,FrameworkStatsLog.BOOT_TIME_EVENT_ELAPSED_TIME__EVENT__SYSTEM_SERVER_INIT_START,uptimeMillis);}...}

五、boot_progress_pms_start

frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java

    public PackageManagerService(Injector injector, boolean onlyCore, boolean factoryTest) {...mInjector = injector;mInjector.bootstrap(this);mLock = injector.getLock();mInstallLock = injector.getInstallLock();LockGuard.installLock(mLock, LockGuard.INDEX_PACKAGES);EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_START,SystemClock.uptimeMillis());...}

六、boot_progress_pms_system_scan_start

frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java

    public PackageManagerService(Injector injector, boolean onlyCore, boolean factoryTest) {...long startTime = SystemClock.uptimeMillis();EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_SYSTEM_SCAN_START,startTime);final String bootClassPath = System.getenv("BOOTCLASSPATH");final String systemServerClassPath = System.getenv("SYSTEMSERVERCLASSPATH");if (bootClassPath == null) {Slog.w(TAG, "No BOOTCLASSPATH found!");}if (systemServerClassPath == null) {Slog.w(TAG, "No SYSTEMSERVERCLASSPATH found!");}...}

七、boot_progress_pms_data_scan_start

frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java

    public PackageManagerService(Injector injector, boolean onlyCore, boolean factoryTest) {...// Remove any shared userIDs that have no associated packagesmSettings.pruneSharedUsersLPw();final long systemScanTime = SystemClock.uptimeMillis() - startTime;final int systemPackagesCount = mPackages.size();Slog.i(TAG, "Finished scanning system apps. Time: " + systemScanTime+ " ms, packageCount: " + systemPackagesCount+ " , timePerPackage: "+ (systemPackagesCount == 0 ? 0 : systemScanTime / systemPackagesCount)+ " , cached: " + cachedSystemApps);if (mIsUpgrade && systemPackagesCount > 0) {//CHECKSTYLE:OFF IndentationCheckFrameworkStatsLog.write(FrameworkStatsLog.BOOT_TIME_EVENT_DURATION_REPORTED,BOOT_TIME_EVENT_DURATION__EVENT__OTA_PACKAGE_MANAGER_SYSTEM_APP_AVG_SCAN_TIME,systemScanTime / systemPackagesCount);//CHECKSTYLE:ON IndentationCheck}if (!mOnlyCore) {EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_DATA_SCAN_START,SystemClock.uptimeMillis());scanDirTracedLI(sAppInstallDir, 0, scanFlags | SCAN_REQUIRE_KNOWN, 0,packageParser, executorService);}...}

八、boot_progress_pms_scan_end

frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java

    public PackageManagerService(Injector injector, boolean onlyCore, boolean factoryTest) {...// Now that we know all the packages we are keeping,// read and update their last usage times.mPackageUsage.read(mSettings.mPackages);mCompilerStats.read();EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_SCAN_END,SystemClock.uptimeMillis());Slog.i(TAG, "Time to scan packages: "+ ((SystemClock.uptimeMillis()-startTime)/1000f)+ " seconds");...}

九、boot_progress_pms_ready

frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java

    public PackageManagerService(Injector injector, boolean onlyCore, boolean factoryTest) {...// can downgrade to readert.traceBegin("write settings");mSettings.writeLPr();t.traceEnd();EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_READY,SystemClock.uptimeMillis());...}

十、boot_progress_ams_ready

frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.java

    public void systemReady(final Runnable goingCallback, @NonNull TimingsTraceAndSlog t) {...****t.traceEnd(); // KillProcessesSlog.i(TAG, "System now ready");EventLogTags.writeBootProgressAmsReady(SystemClock.uptimeMillis());t.traceBegin("updateTopComponentForFactoryTest");mAtmInternal.updateTopComponentForFactoryTest();t.traceEnd();...}

十一、boot_progress_enable_screen

frameworks/base/services/core/java/com/android/server/wm/ActivityTaskManagerService.java

        @Overridepublic void enableScreenAfterBoot(boolean booted) {writeBootProgressEnableScreen(SystemClock.uptimeMillis());mWindowManager.enableScreenAfterBoot();synchronized (mGlobalLock) {updateEventDispatchingLocked(booted);}}

十二、sf_stop_bootanim

frameworks/native/services/surfaceflinger/SurfaceFlinger.cpp

void SurfaceFlinger::bootFinished()
{...// stop boot animation// formerly we would just kill the process, but we now ask it to exit so it// can choose where to stop the animation.property_set("service.bootanim.exit", "1");const int LOGTAG_SF_STOP_BOOTANIM = 60110;LOG_EVENT_LONG(LOGTAG_SF_STOP_BOOTANIM,ns2ms(systemTime(SYSTEM_TIME_MONOTONIC)));sp<IBinder> input(defaultServiceManager()->getService(String16("inputflinger")));...
}

十三、wm_boot_animation_done

frameworks/base/services/core/java/com/android/server/wm/WindowManagerService.java

    private void performEnableScreen() {...try {IBinder surfaceFlinger = ServiceManager.getService("SurfaceFlinger");if (surfaceFlinger != null) {ProtoLog.i(WM_ERROR, "******* TELLING SURFACE FLINGER WE ARE BOOTED!");Parcel data = Parcel.obtain();data.writeInterfaceToken("android.ui.ISurfaceComposer");surfaceFlinger.transact(IBinder.FIRST_CALL_TRANSACTION, // BOOT_FINISHEDdata, null, 0);data.recycle();}} catch (RemoteException ex) {ProtoLog.e(WM_ERROR, "Boot completed: SurfaceFlinger is dead!");}EventLogTags.writeWmBootAnimationDone(SystemClock.uptimeMillis());Trace.asyncTraceEnd(TRACE_TAG_WINDOW_MANAGER, "Stop bootanim", 0);mDisplayEnabled = true;ProtoLog.i(WM_DEBUG_SCREEN_ON, "******************** ENABLING SCREEN!");...}

整体框架

在这里插入图片描述


http://www.ppmy.cn/ops/42612.html

相关文章

华为鲲鹏Arm架构+麒麟V10系统,源码编译Qt 5.12.0+ QtCreator4.8.2

前言 华为鲲鹏Arm架构目前系统源里面的Qt以及QtCreator版本都较低&#xff0c;不满足我们开发环境的要求。故通过源码编译开发工具。 升级gcc到7.5.0 Github 下载gcc7.5.0源码&#xff0c;解压源码&#xff0c;按顺序执行命令。 在编译gcc 源码前需要安装三个依赖。gmp-6.1…

Android Camerax 旋转角度(setTargetRotation)无效?

val preview : Preview Preview.Builder().setTargetRotation(Surface.ROTATION_270).build() 如果setTargetRotation无效哪基本上就是你没指定实现模式。 // viewFinder is a PreviewView instance viewFinder.implementationMode PreviewView.ImplementationMode.COMPATI…

Linux 内核开发 27 POSIX共享内存

Linux 内核开发 27 POSIX共享内存 1.定义 支持 POSIX 共享内存&#xff0c;linux 内核使用的是通过一个名为tmpfs的特殊文件系统来实现内存共享&#xff0c;并且将文件系统挂载在rootfs的/dev/shm上。 这种实现与linux 文件系统api 相互一致&#xff0c;所以每个文件都有inod…

SpringBoot(八)之JdbcTemplate

SpringBoot&#xff08;八&#xff09;之JdbcTemplate 文章目录 SpringBoot&#xff08;八&#xff09;之JdbcTemplate1.添加依赖项&#xff1a;2. 配置数据库连接3.创建表信息4. 创建数据模型5. 创建 Repository6.测试,创建TestController spring-boot-starter-jdbc 是 Spring…

每天一个数据分析题(三百三十五)

下图表中&#xff0c;适用于展示连续型数据的数据分布情况的是&#xff08;&#xff09; A. 条形图 B. 饼图 C. 直方图 D. 箱线图 数据分析认证考试介绍&#xff1a;点击进入 题目来源于CDA模拟题库 点击此处获取答案

深度学习之基于YoloV5钢材微小缺陷检测系统

欢迎大家点赞、收藏、关注、评论啦 &#xff0c;由于篇幅有限&#xff0c;只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景与目标 在钢材生产过程中&#xff0c;由于各种因素&#xff0c;钢材表面可能会出现微小缺陷&#xff…

视频批量剪辑神器大揭秘:一键删减片头片尾,高效打造精彩视频内容!

在数字化时代的浪潮中&#xff0c;视频已经成为人们传递信息、分享生活的重要载体。无论是制作一部精美的宣传片&#xff0c;还是剪辑一段有趣的短视频&#xff0c;视频时长都是至关重要的因素。然而&#xff0c;很多视频创作者在调整视频时长时遇到了困难&#xff0c;耗费了大…

YOLOv5/v7 引入 RepVGG 重参数化模块

YOLOv5/v7 中引入 RepVGG 重参数化模块 1. 介绍 RepVGG 是由 Megvii Research 团队于 2021 年提出的深度卷积神经网络架构&#xff0c;它通过重参数化 VGGNet 架构&#xff0c;显著提高了模型的性能和效率。RepVGG 架构在 YOLOv5 和 YOLOv7 等目标检测模型中得到了广泛应用&a…