主要log信息:
01-02 01:34:11.010 I/SystemServer( 1059): User Service
01-02 01:34:11.019 E/System ( 1059): ******************************************
01-02 01:34:11.019 E/System ( 1059): ************ Failure starting system services
01-02 01:34:11.019 E/System ( 1059): java.lang.RuntimeException: Unable to find android system package
01-02 01:34:11.019 E/System ( 1059): at com.android.server.am.ActivityManagerService.setSystemProcess(ActivityManagerService.java:2399)
01-02 01:34:11.019 E/System ( 1059): at com.android.server.SystemServer.startBootstrapServices(SystemServer.java:533)
01-02 01:34:11.019 E/System ( 1059): at com.android.server.SystemServer.run(SystemServer.java:355)
01-02 01:34:11.019 E/System ( 1059): at com.android.server.SystemServer.main(SystemServer.java:242)
01-02 01:34:11.019 E/System ( 1059): at java.lang.reflect.Method.invoke(Native Method)
01-02 01:34:11.019 E/System ( 1059): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:888)
01-02 01:34:11.019 E/System ( 1059): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
01-02 01:34:11.019 E/System ( 1059): Caused by: android.content.pm.PackageManager$NameNotFoundException: android
01-02 01:34:11.019 E/System ( 1059): at android.app.ApplicationPackageManager.getApplicationInfo(ApplicationPackageManager.java:312)
01-02 01:34:11.019 E/System ( 1059): at com.android.server.am.ActivityManagerService.setSystemProcess(ActivityManagerService.java:2374)
01-02 01:34:11.019 E/System ( 1059): ... 6 more
01-02 01:34:11.020 D/RecoveryManagerService( 1059): Catch exception
01-02 01:34:11.020 D/RecoveryManagerService( 1059): java.lang.RuntimeException: Unable to find android system package
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at com.android.server.am.ActivityManagerService.setSystemProcess(ActivityManagerService.java:2399)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at com.android.server.SystemServer.startBootstrapServices(SystemServer.java:533)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at com.android.server.SystemServer.run(SystemServer.java:355)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at com.android.server.SystemServer.main(SystemServer.java:242)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at java.lang.reflect.Method.invoke(Native Method)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:888)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): Caused by: android.content.pm.PackageManager$NameNotFoundException: android
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at android.app.ApplicationPackageManager.getApplicationInfo(ApplicationPackageManager.java:312)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): at com.android.server.am.ActivityManagerService.setSystemProcess(ActivityManagerService.java:2374)
01-02 01:34:11.020 D/RecoveryManagerService( 1059): ... 6 more
01-02 01:34:11.022 W/RecoveryManagerService( 1059): RMS is partial support, do not recover any files, just record the exception
01-02 01:34:11.022 D/AndroidRuntime( 1059): Shutting down VM
--------- beginning of crash
01-02 01:34:11.022 E/AndroidRuntime( 1059): *** FATAL EXCEPTION IN SYSTEM PROCESS: main
01-02 01:34:11.022 E/AndroidRuntime( 1059): java.lang.RuntimeException: Unable to find android system package
01-02 01:34:11.022 E/AndroidRuntime( 1059): at com.android.server.am.ActivityManagerService.setSystemProcess(ActivityManagerService.java:2399)
01-02 01:34:11.022 E/AndroidRuntime( 1059): at com.android.server.SystemServer.startBootstrapServices(SystemServer.java:533)
01-02 01:34:11.022 E/AndroidRuntime( 1059): at com.android.server.SystemServer.run(SystemServer.java:355)
01-02 01:34:11.022 E/AndroidRuntime( 1059): at com.android.server.SystemServer.main(SystemServer.java:242)
01-02 01:34:11.022 E/AndroidRuntime( 1059): at java.lang.reflect.Method.invoke(Native Method)
01-02 01:34:11.022 E/AndroidRuntime( 1059): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:888)
01-02 01:34:11.022 E/AndroidRuntime( 1059): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
01-02 01:34:11.022 E/AndroidRuntime( 1059): Caused by: android.content.pm.PackageManager$NameNotFoundException: android
01-02 01:34:11.022 E/AndroidRuntime( 1059): at android.app.ApplicationPackageManager.getApplicationInfo(ApplicationPackageManager.java:312)
01-02 01:34:11.022 E/AndroidRuntime( 1059): at com.android.server.am.ActivityManagerService.setSystemProcess(ActivityManagerService.java:2374)
01-02 01:34:11.022 E/AndroidRuntime( 1059): ... 6 more
01-02 01:34:11.026 E/ActivityManager( 1059): get crashInfo fail.
01-02 01:34:11.031 D/AudioTrackShared( 420): front(215040), mIsOut(1), mAvailToClient=14208 stepCount=1024 minimum=11264, FUTEX_WAKE
01-02 01:34:11.033 E/AndroidRuntime( 1059): Error reporting crash
01-02 01:34:11.033 E/AndroidRuntime( 1059): java.lang.SecurityException: Unable to find app for caller android.app.ActivityThread$ApplicationThread@5539661 (pid=1059) when getting content provider settings
01-02 01:34:11.033 E/AndroidRuntime( 1059): at com.android.server.am.ActivityManagerService.getContentProviderImpl(ActivityManagerService.java:11362)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at com.android.server.am.ActivityManagerService.getContentProvider(ActivityManagerService.java:11774)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at android.app.ActivityThread.acquireProvider(ActivityThread.java:4992)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at android.app.ContextImpl$ApplicationContentResolver.acquireProvider(ContextImpl.java:2004)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at android.content.ContentResolver.acquireProvider(ContentResolver.java:1501)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at android.provider.Settings$NameValueCache.lazyGetProvider(Settings.java:1317)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at android.provider.Settings$NameValueCache.getStringForUser(Settings.java:1371)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at android.provider.Settings$Global.getStringForUser(Settings.java:8658)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at android.provider.Settings$Global.getString(Settings.java:8647)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at android.provider.Settings$Global.getInt(Settings.java:8714)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at com.android.server.am.ActivityManagerService$20.run(ActivityManagerService.java:14593)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at com.android.server.am.ActivityManagerService.addErrorToDropBox(ActivityManagerService.java:14633)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at com.android.server.am.ActivityManagerService.handleApplicationCrashInner(ActivityManagerService.java:14181)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at com.android.server.am.ActivityManagerService.handleApplicationCrash(ActivityManagerService.java:14165)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at com.android.internal.os.RuntimeInit$UncaughtHandler.uncaughtException(RuntimeInit.java:109)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at java.lang.ThreadGroup.uncaughtException(ThreadGroup.java:693)
01-02 01:34:11.033 E/AndroidRuntime( 1059): at java.lang.ThreadGroup.uncaughtException(ThreadGroup.java:690)
平台:MT6755M分析:
1.通过公司下载工具(flashtool也可以)readback dump出手机分区内容下载到其他手机(称克隆机)能够正常开机(除了userdata,由于系统默认加密导致 userdata分区即使下载到其他手机也无法使用)。由此发现可能与userdata区域有关。
2.客退机通过刷对应版本的usedebug boot img文件,开启adb调试
3.adb pull 导出客退机data区域,然后分步push到克隆机发现当data/system/users/0/package-restrictions.xml被push进去后克隆机卡在开机动画界面,查看log和客退机一致:Caused by: android.content.pm.PackageManager$NameNotFoundException: android
4.逐步查看和<pkg name="android" inst="false" stopped="true" nl="true"/>,逐步排除发现和inst="false"有关。
5.由于缺少问题产生时log,最后反复查看代码也无法判断产生为什么会导致package-restrictions.xml重写异常,因此最后做了一个work around方案去规避此问题:在开机读文件package-restrictions.xml解析的时候发现有pkg name="android" inst="false"时就删除package-restrictions.xml文件,该文件在每次write的时候都会重新读取PMS信息完成write操作,验证无问题。