Android开机各个阶段(Android R)

本文详细解析了Android系统的开机流程,从boot_progress_start到wm_boot_animation_done,涵盖了Zygote启动、SystemServer运行、PMS服务扫描应用以及屏幕激活等关键步骤。通过对Android源码的分析,展示了每个阶段在系统启动中的作用,对于理解Android系统启动机制非常有帮助。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android开机各个阶段(Android R)

开机各个阶段描述

阶段描述
boot_progress_start系统进入用户空间,标志着kernel启动完成
boot_progress_preload_startZygote启动
boot_progress_preload_endZygote结束
boot_progress_system_runSystemServer ready,开始启动Android系统服务
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发出退出开机动画的时间节点之前
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);

        <span class="hljs-keyword">final</span> String bootClassPath = System.getenv(<span class="hljs-string">"BOOTCLASSPATH"</span>);
        <span class="hljs-keyword">final</span> String systemServerClassPath = System.getenv(<span class="hljs-string">"SYSTEMSERVERCLASSPATH"</span>);

        <span class="hljs-keyword">if</span> (bootClassPath == <span class="hljs-keyword">null</span>) {
            Slog.w(TAG, <span class="hljs-string">"No BOOTCLASSPATH found!"</span>);
        }

        <span class="hljs-keyword">if</span> (systemServerClassPath == <span class="hljs-keyword">null</span>) {
            Slog.w(TAG, <span class="hljs-string">"No SYSTEMSERVERCLASSPATH found!"</span>);
        }
    ...
}

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 packages
            mSettings.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 IndentationCheck
                FrameworkStatsLog.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();
        <span class="hljs-selector-tag">EventLog</span><span class="hljs-selector-class">.writeEvent</span>(EventLogTags.BOOT_PROGRESS_PMS_SCAN_END,
                SystemClock.uptimeMillis());
        <span class="hljs-selector-tag">Slog</span><span class="hljs-selector-class">.i</span>(TAG, <span class="hljs-string">"Time to scan packages: "</span>
                + ((SystemClock.uptimeMillis()-startTime)/<span class="hljs-number">1000</span>f)
                + <span class="hljs-string">" seconds"</span>);
    ...
}

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 reader
            t.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(); // KillProcesses
    <span class="hljs-selector-tag">Slog</span><span class="hljs-selector-class">.i</span>(TAG, <span class="hljs-string">"System now ready"</span>);

    <span class="hljs-selector-tag">EventLogTags</span><span class="hljs-selector-class">.writeBootProgressAmsReady</span>(SystemClock.uptimeMillis());

    <span class="hljs-selector-tag">t</span><span class="hljs-selector-class">.traceBegin</span>(<span class="hljs-string">"updateTopComponentForFactoryTest"</span>);
    <span class="hljs-selector-tag">mAtmInternal</span><span class="hljs-selector-class">.updateTopComponentForFactoryTest</span>();
    <span class="hljs-selector-tag">t</span><span class="hljs-selector-class">.traceEnd</span>();
    ...
}

boot_progress_enable_screen

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

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

boot_progress_ams_ready -> boot_progress_enable_screen

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");
<span class="hljs-keyword">const</span> <span class="hljs-keyword">int</span> LOGTAG_SF_STOP_BOOTANIM = <span class="hljs-number">60110</span>;
LOG_EVENT_LONG(LOGTAG_SF_STOP_BOOTANIM,
               ns2ms(systemTime(SYSTEM_TIME_MONOTONIC)));

<span class="hljs-function">sp&lt;IBinder&gt; <span class="hljs-title">input</span><span class="hljs-params">(defaultServiceManager()-&gt;getService(String16(<span class="hljs-string">"inputflinger"</span>)))</span></span>;
...

}

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_FINISHED
                            data, 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, <span class="hljs-string">"Stop bootanim"</span>, <span class="hljs-number">0</span>);
        mDisplayEnabled = <span class="hljs-literal">true</span>;
        ProtoLog.i(WM_DEBUG_SCREEN_ON, <span class="hljs-string">"******************** ENABLING SCREEN!"</span>);
    ...
}

分类: Android
<div id="blog_post_info">
0
0
<div class="clear"></div>
<div id="post_next_prev">

<br>
<a href="https://www.cnblogs.com/forrest-lin/p/14530804.html" class="p_n_p_prefix">» </a> 下一篇:    <a href="https://www.cnblogs.com/forrest-lin/p/14530804.html" title="发布于 2021-03-13 22:45">Android开机动画(Android R)</a>
posted @ 2021-03-13 22:36  Forrest_Lin  阅读( 128)  评论( 0编辑  收藏  举报

· 程序员是怎么存档并管理文件版本的?


· 小于5人公司极简研发构架


· 就这样,我走过了程序员的前五年


· 一次 RocketMQ 顺序消费延迟的问题定位


· .Net Core with 微服务 - Elastic APM

最新新闻
· 被150万商家扶上市,“天鹅”能高飞吗?
· 极氪车主维权疑云:套路“割韭菜”、营销误导、变相加价?
· 除了数据隐患,满帮的商业模式是否真的靠谱?
· 让公鼠怀孕的作者被狂喷!可网友们这次好像骂偏了
· 蹭古剑奇谭热度 贪玩蓝月公司被判赔偿26万元
» 更多新闻...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值