- 开机各个阶段描述
- 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_start | Zygote启动 |
boot_progress_preload_end | Zygote结束 |
boot_progress_system_run | SystemServer ready,开始启动Android系统服务 |
boot_progress_pms_start | PMS开始扫描安装的应用 |
boot_progress_pms_system_scan_start | PMS先行扫描/system目录下的安装包 |
boot_progress_pms_data_scan_start | PMS扫描/data目录下的安装包 |
boot_progress_pms_scan_end | PMS扫描结束 |
boot_progress_pms_ready | PMS就绪 |
boot_progress_ams_ready | AMS就绪 |
boot_progress_enable_screen | AMS启动完成后开始激活屏幕,从此以后屏幕才能响应用户的触摸,它在WindowManagerService发出退出开机动画的时间节点之前 |
sf_stop_bootanim | SF设置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);
}
}
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<IBinder> <span class="hljs-title">input</span><span class="hljs-params">(defaultServiceManager()->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>);
...
}
<div id="blog_post_info">
<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>
· 程序员是怎么存档并管理文件版本的?
· 小于5人公司极简研发构架
· 就这样,我走过了程序员的前五年
· 一次 RocketMQ 顺序消费延迟的问题定位
· .Net Core with 微服务 - Elastic APM
【推荐】阿里云云大使特惠:新用户购ECS服务器1核2G最低价87元/年
【推荐】大型组态、工控、仿真、CAD\GIS 50万行VC++源码免费下载!
【推荐】和开发者在一起:华为开发者社区,入驻博客园品牌专区